

Verification Continuum™

# **VC Verification IP**

## **PCIe**

## **SVC 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 .....                                                                                | 9  |
| Chapter 1 Introduction .....                                                                 | 13 |
| 1.1 Overview of Models .....                                                                 | 13 |
| 1.2 PCIe Device and MAC Model Instantiation .....                                            | 15 |
| 1.2.1 Model Names .....                                                                      | 15 |
| 1.2.2 Model Wire Interface Options .....                                                     | 16 |
| 1.2.3 Configuring the PIPE Data Bus Width .....                                              | 25 |
| 1.2.4 Configuring the PIPE Data Bus Width .....                                              | 25 |
| 1.2.5 Using ifdefs with PIPE 4.0 To Select Additional Signals .....                          | 26 |
| 1.2.6 Model Configuration Overview .....                                                     | 26 |
| 1.2.7 Model Parameters .....                                                                 | 27 |
| 1.2.8 Multiple Root Hierarchies .....                                                        | 27 |
| 1.2.9 Fast Link Training .....                                                               | 28 |
| 1.3 Test Environment Requirements .....                                                      | 28 |
| 1.3.1 Gen3 Requirements .....                                                                | 28 |
| 1.4 System Verilog APIs .....                                                                | 29 |
| 1.5 Running Multiple Simulations in the Same Directory .....                                 | 29 |
| 1.6 SVC Memory Usage .....                                                                   | 29 |
| 1.7 Compliance Patterns .....                                                                | 30 |
| Chapter 2 Installing and Running the PCIe VIP .....                                          | 31 |
| 2.1 Accessing Product Documentation .....                                                    | 31 |
| 2.2 Process Overview .....                                                                   | 31 |
| 2.3 Verifying Hardware Requirements .....                                                    | 32 |
| 2.4 Verifying Software Requirements .....                                                    | 32 |
| 2.4.1 Platform/OS and Simulator Software .....                                               | 32 |
| 2.4.2 Synopsys Common Licensing (SCL) Software .....                                         | 32 |
| 2.4.3 Other Third Party Software .....                                                       | 32 |
| 2.5 Setting Environment Variables .....                                                      | 32 |
| 2.5.1 Setting Common Environment Variables .....                                             | 32 |
| 2.6 Downloading and Installing the Synopsys PCIe VIP .....                                   | 33 |
| 2.6.1 Downloading From the Electronic Software Transfer (EST) System (Download Center) ..... | 34 |
| 2.6.2 Downloading Using FTP with a Web Browser .....                                         | 34 |
| 2.6.3 Setting Up FlexLM Licensing .....                                                      | 34 |

|                                                                                   |     |
|-----------------------------------------------------------------------------------|-----|
| 2.6.4 32-bit and 64-bit Simulation Modes .....                                    | 35  |
| 2.7 Building the Tools, Header Files and PLI Libraries .....                      | 37  |
| 2.7.1 Makefiles .....                                                             | 37  |
| 2.7.2 Proper Path for Setup .....                                                 | 38  |
| 2.7.3 Helper Scripts .....                                                        | 38  |
| 2.7.4 Setting Up an Example .....                                                 | 38  |
| 2.8 Running a Test .....                                                          | 39  |
| 2.8.1 VCS/VCS MX .....                                                            | 39  |
| 2.8.2 NC .....                                                                    | 39  |
| 2.8.3 MTI/Questa .....                                                            | 39  |
| 2.9 Licensing .....                                                               | 39  |
| 2.10 Controlling License Usage .....                                              | 41  |
| 2.10.1 License Polling .....                                                      | 41  |
| 2.10.2 Simulation License Suspension .....                                        | 42  |
| 2.11 Troubleshooting .....                                                        | 42  |
| 2.11.1 Licensing Problems .....                                                   | 42  |
| 2.11.2 Problems with Compiling or Running .....                                   | 42  |
| 2.12 Downloading Protocol Analyzer .....                                          | 43  |
| <br>Chapter 3 Applications .....                                                  | 45  |
| 3.1 Driver Application .....                                                      | 45  |
| 3.1.1 Driver Parameters .....                                                     | 45  |
| 3.1.2 Driver User Tasks .....                                                     | 47  |
| 3.1.3 Driver Memory Management Requirements .....                                 | 56  |
| 3.1.4 Driver Events .....                                                         | 57  |
| 3.2 Request Initiator Application .....                                           | 57  |
| 3.2.1 Requester Parameters .....                                                  | 57  |
| 3.2.2 Requester User Tasks .....                                                  | 60  |
| 3.2.3 Requester Statistics .....                                                  | 62  |
| 3.3 Completion Target Application .....                                           | 62  |
| 3.3.1 Completion Target Parameters .....                                          | 62  |
| 3.3.2 Controlling Completion Timing and Size Using Callbacks in Verilog VIP ..... | 72  |
| 3.4 Target Memory .....                                                           | 78  |
| 3.4.1 Memory Target Parameters .....                                              | 78  |
| 3.4.2 Ignoring Memory Ranges .....                                                | 81  |
| 3.5 Mid-Sim Reset .....                                                           | 82  |
| <br>Chapter 4 Transaction Layer .....                                             | 83  |
| 4.1 Transaction Layer Module IOs .....                                            | 83  |
| 4.2 Transaction Layer Configuration Tasks .....                                   | 83  |
| 4.3 Transaction Layer User Tasks .....                                            | 84  |
| 4.4 Transaction Layer Parameters .....                                            | 88  |
| 4.5 Transaction Layer Events .....                                                | 92  |
| 4.6 Transaction Layer ASCII Signals .....                                         | 92  |
| 4.7 Transaction Layer Statistics .....                                            | 93  |
| 4.8 Transaction Layer Internal Interface Tasks .....                              | 96  |
| <br>Chapter 5 Data Link Layer .....                                               | 101 |
| 5.1 Date Link Layer Module I/Os .....                                             | 101 |
| 5.2 Data Link Layer Configuration Tasks .....                                     | 102 |

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| 5.3 Data Link Layer User Tasks . . . . .                            | 102 |
| 5.4 Data Link Layer Parameters . . . . .                            | 107 |
| 5.5 Data Link Layer Events . . . . .                                | 112 |
| 5.6 Data Link Layer ASCII Signals . . . . .                         | 113 |
| 5.7 Data Link Layer Statistics . . . . .                            | 114 |
| 5.8 Data Link Layer Transmit TLP Error Injection . . . . .          | 117 |
| 5.9 Data Link Layer Transmit DLLP Error Injection . . . . .         | 120 |
| 5.10 Data Link Layer Receive TLP Error Injection . . . . .          | 121 |
| 5.11 Data Link Layer Multiple Packet Error Injection . . . . .      | 123 |
| 5.12 Data Link Layer Packet Alignment Error Injection . . . . .     | 123 |
| 5.13 Data Link Layer Internal Interface Tasks . . . . .             | 124 |
| 5.14 Data Link Layer to Physical Layer Interface Tasks . . . . .    | 125 |
| <br>Chapter 6 Physical Layer . . . . .                              | 127 |
| 6.1 Physical Layer Module IOs . . . . .                             | 127 |
| 6.2 Physical Layer Configuration Tasks . . . . .                    | 127 |
| 6.3 Physical Layer User Tasks . . . . .                             | 132 |
| 6.4 LTSSM User Training Set Tasks . . . . .                         | 134 |
| 6.5 Equalization Tasks . . . . .                                    | 140 |
| 6.6 Physical Layer Parameters . . . . .                             | 144 |
| 6.6.1 General Parameters . . . . .                                  | 144 |
| 6.6.2 Physical Layer LTSSM-specific Parameters . . . . .            | 149 |
| 6.6.3 Equalization Parameters . . . . .                             | 154 |
| 6.7 Physical Layer Events . . . . .                                 | 156 |
| 6.8 Physical Layer ASCII Signals . . . . .                          | 157 |
| 6.9 Physical Layer Statistics . . . . .                             | 157 |
| 6.10 LTSSM Error Injection Controls . . . . .                       | 160 |
| 6.11 TS1 Error Injection Controls . . . . .                         | 161 |
| 6.11.1 TS1 Randomized Injections . . . . .                          | 161 |
| 6.11.2 Directed Sequences of TS1 Injected Errors . . . . .          | 163 |
| 6.12 TS2 Error Injection Controls . . . . .                         | 163 |
| 6.12.1 TS2 Randomized Injections . . . . .                          | 163 |
| 6.12.2 Directed Sequences of TS2 Injected Errors . . . . .          | 165 |
| 6.13 Ordered Set Error Injection Controls . . . . .                 | 165 |
| 6.13.1 EIOS Injected Errors . . . . .                               | 165 |
| 6.13.2 EEIOS Injected Errors . . . . .                              | 167 |
| 6.13.3 FTS Injected Errors . . . . .                                | 170 |
| 6.13.4 SKP Injected Errors . . . . .                                | 172 |
| 6.13.5 SDS Injected Errors . . . . .                                | 174 |
| 6.13.6 EDS Injected Errors . . . . .                                | 175 |
| 6.13.7 IDLE Data Injected Errors . . . . .                          | 176 |
| 6.13.8 Directed Sequences of IDLE Injected Errors . . . . .         | 176 |
| 6.14 Physical Layer Internal Interface Tasks . . . . .              | 177 |
| 6.15 Using Local Preset Coefficients . . . . .                      | 178 |
| <br>Chapter 7 Physical Coding Sublayer (2.5Gb / 5Gb/ 8Gb) . . . . . | 183 |
| 7.1 Physical Coding Sublayer Parameters . . . . .                   | 183 |
| 7.2 Physical Coding Sublayer Interface Tasks . . . . .              | 184 |

|                                                                |     |
|----------------------------------------------------------------|-----|
| Chapter 8 Serializer/Deserializer (pciesvc_serdes.v) . . . . . | 187 |
| 8.1 Module Port List . . . . .                                 | 187 |
| 8.2 SERDES Parameters . . . . .                                | 188 |
| Chapter 9 PCIE Verification Tools . . . . .                    | 191 |
| 9.1 The Global PCIE Address Space Shadow . . . . .             | 191 |
| 9.1.1 Instantiating and Enabling the Global Shadow . . . . .   | 192 |
| 9.1.2 Shadow Tasks . . . . .                                   | 193 |
| 9.1.3 Example Global Shadow Memory Usage . . . . .             | 196 |
| 9.1.4 Example Global Shadow Configuration Usage . . . . .      | 196 |
| 9.2 The Transaction Logger . . . . .                           | 197 |
| 9.3 The Protocol Analyzer Logger . . . . .                     | 198 |
| 9.4 Symbol Logging . . . . .                                   | 202 |
| Chapter 10 Functional Coverage . . . . .                       | 205 |
| 10.1 Enabling Functional Coverage . . . . .                    | 205 |
| 10.2 Class Structure and Callbacks . . . . .                   | 205 |
| 10.3 Overriding the Default Coverage Class . . . . .           | 206 |
| 10.3.1 Overriding With UVM . . . . .                           | 206 |
| 10.3.2 Overriding for SystemVerilog Users . . . . .            | 206 |
| 10.4 Transaction Layer . . . . .                               | 206 |
| 10.4.1 Transaction Layer Functional Coverage . . . . .         | 206 |
| 10.4.2 Transaction Layer Callbacks . . . . .                   | 208 |
| 10.5 Data Link Layer . . . . .                                 | 208 |
| 10.5.1 Data Link Layer Functional Coverage . . . . .           | 208 |
| 10.5.2 Link Layer Callbacks . . . . .                          | 225 |
| 10.6 Physical Layer . . . . .                                  | 230 |
| 10.6.1 Physical Layer Functional Coverage . . . . .            | 230 |
| 10.6.2 Physical Layer Callbacks . . . . .                      | 234 |
| 10.7 PIPE Interface . . . . .                                  | 236 |
| 10.7.1 PIPE Functional Coverage . . . . .                      | 236 |
| 10.7.2 PIPE Interface Callbacks . . . . .                      | 236 |
| Chapter 11 PCIe VIP Verification Plans . . . . .               | 239 |
| 11.1 Top-level Plans . . . . .                                 | 239 |
| 11.2 Subplans . . . . .                                        | 239 |
| 11.3 Back-annotation with VCS Verification Planner . . . . .   | 240 |
| Chapter 12 Debugging the PCIe VIP . . . . .                    | 241 |
| 12.1 Using Run Logs for Debugging . . . . .                    | 241 |
| 12.1.1 Setting Log Severity Levels . . . . .                   | 242 |
| 12.1.2 Logging Transactions . . . . .                          | 242 |
| 12.1.3 Searching the Log . . . . .                             | 242 |
| 12.1.4 Logging Symbols . . . . .                               | 242 |
| 12.2 Analyzing Runtime Statistics . . . . .                    | 243 |
| 12.3 Debugging Using the Protocol Analyzer . . . . .           | 243 |
| 12.3.1 Protocol Analyzer Settings File . . . . .               | 243 |
| 12.3.2 Enabling the Protocol Analyzer for PCIE . . . . .       | 243 |
| 12.3.3 Protocol Analyzer Controls . . . . .                    | 243 |
| 12.3.4 Protocol Analyzer Flow with DVE . . . . .               | 244 |
| 12.3.5 Launching the DVE Connection Wizard . . . . .           | 246 |

|                                                          |     |
|----------------------------------------------------------|-----|
| 12.4 Using ASCII Signals . . . . .                       | 248 |
| 12.4.1 Transaction Layer ASCII Signals . . . . .         | 248 |
| 12.4.2 Data Link Layer ASCII Signals . . . . .           | 249 |
| 12.4.3 Physical Layer ASCII Signals . . . . .            | 249 |
| Chapter 13 Memory Model Utility . . . . .                | 251 |
| 13.1 Overview . . . . .                                  | 251 |
| 13.2 Memory Model Interface . . . . .                    | 251 |
| 13.3 Memory Size Parameters . . . . .                    | 253 |
| 13.4 Model Instantiation . . . . .                       | 254 |
| Chapter 14 Message Logging Facility . . . . .            | 257 |
| 14.1 Overview . . . . .                                  | 257 |
| 14.1.1 Basic Logging Goals . . . . .                     | 257 |
| 14.1.2 Logging Levels . . . . .                          | 257 |
| 14.2 Message Logging Utility Routines . . . . .          | 258 |
| 14.2.1 PLI Task \$msglog . . . . .                       | 258 |
| 14.2.2 PLI Task \$msglog_clear . . . . .                 | 260 |
| 14.2.3 PLI Function \$msglog_count . . . . .             | 261 |
| 14.2.4 PLI Task \$msglog_exit_threshold . . . . .        | 261 |
| 14.2.5 PLI Task \$msglog_level . . . . .                 | 262 |
| 14.2.6 PLI Function \$msglog_level_get . . . . .         | 262 |
| 14.2.7 PLI Task \$msglog_suppress . . . . .              | 263 |
| 14.2.8 PLI Task \$msglog_unsuppress . . . . .            | 265 |
| 14.2.9 PLI Task \$msglog_get_suppression_count . . . . . | 265 |
| 14.2.10 PLI Task \$msglog_control . . . . .              | 266 |
| Chapter 15 Controlling SVC from C Testbenches . . . . .  | 271 |
| 15.1 Overview . . . . .                                  | 271 |
| 15.2 DPI Exports . . . . .                               | 271 |
| 15.2.1 Compiling the DPI Exports . . . . .               | 271 |
| 15.2.2 Using Exported Tasks in C . . . . .               | 272 |
| 15.3 Notes About System Stability . . . . .              | 272 |
| 15.4 VPI Access to SVC Variables . . . . .               | 272 |
| 15.4.1 Sample VPI Access Routines . . . . .              | 273 |
| Appendix A Media Module . . . . .                        | 277 |
| A.1 Media Module svc_media . . . . .                     | 277 |
| A.1.1 Media ModuleTasks . . . . .                        | 277 |
| A.1.2 Media Module Parameters . . . . .                  | 281 |
| A.2 Media Builder (module: svc_media_builder) . . . . .  | 282 |
| A.2.1 Media Builder Parameters . . . . .                 | 282 |
| A.3 Media Initialization Content Data File . . . . .     | 283 |
| A.3.1 Media Initialization Data File Format . . . . .    | 284 |
| A.3.2 Media Builder Usage Example . . . . .              | 284 |
| Appendix B Protocol Checks . . . . .                     | 289 |
| Appendix C Implemented ECNs . . . . .                    | 309 |
| Appendix D SVC to SVT Migration . . . . .                | 311 |
| D.1 SVC Verilog to SVT . . . . .                         | 311 |

|                                            |            |
|--------------------------------------------|------------|
| D.2 SVC UVM to SVT .....                   | 314        |
| <b>Appendix E Reporting Problems .....</b> | <b>317</b> |
| E.1 Introduction .....                     | 317        |
| E.2 Initial Customer Information .....     | 317        |

# Preface

## About This Manual

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

## Manual Organization

The chapters of this databook are organized as follows:

- ❖ Chapter 1, “[Introduction](#)”, introduces the Synopsys PCIe VIP and its features.
- ❖ Chapter 2, “[Installing and Running the PCIe VIP](#)”, describes system requirements and provides instructions on how to install, configure, and begin using the Synopsys PCIe VIP.
- ❖ Chapter 3, “[Applications](#)”, provides information about the software application layer, where transactions are handled.
- ❖ Chapter 4, “[Transaction Layer](#)”, describes the layer that encapsulates transactions into TLPs, performs traffic class to virtual channel mapping, controls the flow of transactions, and checks and enforces TLP ordering rules.
- ❖ Chapter 5, “[Data Link Layer](#)”, describes the layer that processes TLPs from the Transaction Layer or sends TLPs to the Transaction Layer.
- ❖ Chapter 6, “[Physical Layer](#)”, describes the layer that contains the LTSSM, performs data scrambling and descrambling, lane deskewing and interfacing with the link for transmit/receive data.
- ❖ Chapter 7, “[Physical Coding Sublayer \(2.5Gb / 5Gb/ 8Gb\)](#)”, provides information about the Physical Coding Sublayer (PCS). The PCS performs symbol lock at 2.5GT/s, 5GT/s, and 8GT/s., does 8b/10b encoding at 2.5GT/s and 5GT/s and inserts data sync headers at 8GT/s. The PCS also contains the elastic buffer which inserts/deletes SKP symbols from skip ordered sets.
- ❖ Chapter 8, “[Serializer/Deserializer \(pciesvc\\_serdes.v\)](#)”, describes the component that converts the serial bit stream into a stream of 10-bit bytes, and does signal-level validation, receiver clock-recovery and bit alignment.
- ❖ Chapter 9, “[PCIE Verification Tools](#)”, describes the component that provides a shadow of the DUT’s PCI Express address space for Write and Read transaction checking. The Global PCIE Address Space Shadow is an optional component.
- ❖ Chapter 10, “[Functional Coverage](#)”, provides information about callback routines that you can use for functional coverage.
- ❖ Chapter 11, “[PCIe VIP Verification Plans](#)”, provides information about predefined verification plans that you can use in the VCS Verification Planner.

- ❖ Chapter 12, “Debugging the PCIe VIP”, describes how to use waveform viewers, log files, and the Protocol Analyzer to analyze and resolve problems with your tests.
- ❖ Chapter 13, “Memory Model Utility”, describes the component that provides a mechanism to manage data, store data structures, and pass arguments in a Verilog environment.
- ❖ Chapter 14, “Message Logging Facility”, provides information about the facility that enables all components in the VIP to use a common logging facility.
- ❖ Chapter 15, “Controlling SVC from C Testbenches”, provides information on the controlling of SVC from C testbenches using the DPI and VPI.
- ❖ Appendix A, “Media Module”, describes the facility that enables backing up to disk, tape, or other media.
- ❖ Appendix B, “Protocol Checks”, lists the protocol checks that are performed automatically by the VIP.
- ❖ Appendix C, “Implemented ECNs”, contains a list of Engineering Change Notices for the current version of the PCIe VIP.
- ❖ Appendix D, “SVC to SVT Migration”, describes the steps to migrate from SVC package to use SVT installation.
- ❖ Appendix E, “Reporting Problems”, provides information about how to get help from Synopsys for problems with the product.

## 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 E, “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 E, “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

---

The Synopsys PCIe Verification IP package is constructed as a collection of Verilog tasks organized in layer specific modules. The modules themselves do not provide the wiring as in a design, but rather serve to create instantiations of a device and hold common states for a given instantiation. The VIP is constructed in a verification language-neutral manner using current state-of-the-art verification techniques such as constrained randomization, transaction and checking modules. Using tasks and passing arguments allows greater flexibility for reuse of the functionality in the test bench and in the test cases. By providing the arguments on the fly to the tasks, the values passed in can be arbitrarily changed by a directed test case. Using tasks also provides for processing in zero time, so that an VIP can be as fast or slow in response as desired.

The functionality within the various layers of the PCIe VIP is compliant to the following specifications:

- PCI Express Base 2.1 (supported by the PCIe Gen2 VIP)
- PCI Express Base 3.0 (supported by the PCIe Gen3 add-on VIP))

The functionality within the Physical Layer of the PCIe VIP is compliant to the following specifications:

- PIPE 2.1 (Support for Gen1 and Gen2 speeds only)
- PIPE 4.0 (Support for Gen1, Gen2, and Gen3 speeds)

## 1.1 Overview of Models

The PCIe VIP includes a Root Complex model and an Endpoint model. The Root Complex and Endpoint models each contain an instantiated Port model as well as appropriate requester and completer applications.

The PCIe Port (MAC) model consists of components that mirror the functionality of the layers defined in the PCIe standard: a Transaction Layer, a Data Link Layer, a Physical Layer (Phy Layer), and 1-to-n PCS and SERDES (see [Figure 1-1](#)). The Transaction Layer takes commands from the application layer and translate them into Transaction Layer Packets (TLPs). The Transaction Layer is also responsible for monitoring available credits and managing the traffic class and virtual channel queues. The Data Link Layer adds framing and CRC to the TLPs and also generates and receives Data Link Layer Packets (DLLPs). The Physical Layer contains the LTSSM and is responsible for link training. The Physical Layer is also used for assembling and disassembling packets to and from the multiple lanes, performing lane deskew, scrambling

and descrambling, and sync header insertion. The PCS model has an Intel PIPE interface, contains an 8b/10b decoder, detects symbol errors, and contains an elastic FIFO for skip insertion and deletion.

**Figure 1-1 PCIe port model with optional SERDES**



**Figure 1-2 Port model with application layer**

A Root Complex or Endpoint mode contains application layers as well as a port model (see [Figure 1-2](#)).



Multiple Endpoint models can be instantiated along with a root complex model and switch DUT (see [Figure 1-3](#)).



**Figure 1-3 A 2x2 PCIe switch with four PCIe port models**

## 1.2 PCIe Device and MAC Model Instantiation

The PCIe device model contains the connectivity, clocking, and basic configuration for the application layer, Transaction Layer, Data Link Layer, and Physical Layer. The MAC model is instantiated internally within the device model.

Generally customers should use the device model.

The device model is generic – it can be personalized to be either a Root Complex or an Endpoint.

### 1.2.1 Model Names

Models are briefly described in [Table 1-1](#).

**Table 1-1 Descriptions of models**

| Model Name                     | Description                                                                                                                                           |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| pciesvc_device_serdes_xn_model | This is a full device model that connects via a serdes interface and has support for a maximum of $n$ lanes (they do not all have to be used).        |
| pciesvc_device_pma_xn_model    | This is a full device model that connects via 10bit PMA interface and has support for a maximum of $n$ lanes (they do not all have to be used).       |
| pciesvc_device_mpipe_xn_model  | This is a full device (rc or endpoint) model that has a standard master PIPE interface to a DUT Phy.                                                  |
| pciesvc_device_spipe_xn_model  | This is a full device (rc or endpoint) model that has a slave PIPE interface designed to connect directly to a DUT MAC master PIPE interface.         |
| pciesvc_mac_mpipe_xn_model     | This is a MAC only model (no applications) for use in the compliance environment. It is also automatically instantiated within the full device model. |
| pciesvc_mac_spipe_xn_model     | This is a MAC only model (no applications) for use in the compliance environment. It is also automatically instantiated within the full device model. |
| pciesvc_phy_serdes_xn_model    | This is a phy model used only in the compliance environment.                                                                                          |

NOTE: Models supporting 8G have “\_8g” appended to the model name.

## 1.2.2 Model Wire Interface Options

The VIP is connected to a DUT via either a Serdes, 10-bit PMA, or PIPE (both “master” and “slave”) interface. The PIPE interface supports PIPE specification versions 2 or 3 depending on the model used.

**Table 1-2** defines the port list for each interface configuration of the pciesvc\_model instantiation.

Reset to all VIP models is active high. Reset must be de-asserted at time 0 such that a posedge is seen by the VIP. Reset must be asserted for exactly 100ns. 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.

 **Note** 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 a 1.

**Table 1-2** pciesvc\_model ports

| Model Interface Type |                                                                                                                                       | I/O | Description                                                                                                                                                                                                |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serdes Interface.    | Reset<br><br><code>phyn_rx_datap</code><br><code>phyn_rx_datan</code><br><br><code>phyn_tx_datap</code><br><code>phyn_tx_datan</code> |     | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.<br><br>Serial datap in to VIP<br>Serial datan in to VIP<br><br>serial datap out of VIP<br>serial datan out of VIP |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b>                                                                                                                                         |                     | <b>I/O</b> | <b>Description</b>                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------|------------------------------------------------------------------------------------------------------------------|
| “Master” PIPE Version 3 Interface<br><br>This type of interface is a standard PIPE interface to a phy. PIPE 3 models do not have a _8g postfix in their file names. | reset               | I          | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.                         |
|                                                                                                                                                                     | pipe_reset_n        | O          | pipe reset signal to phy                                                                                         |
|                                                                                                                                                                     | pipe_clk            | I          | pipe clock from phy                                                                                              |
|                                                                                                                                                                     | powerdown[1:0]      | O          | Command to change power state of the phy                                                                         |
|                                                                                                                                                                     | rate[1:0]           | O          | Link signaling rate control                                                                                      |
|                                                                                                                                                                     | txdetectrx          | O          | Command to detect receiver                                                                                       |
|                                                                                                                                                                     | phy_status[31:0]    | I          | Phy response to rate or power change. For pipe 2, only bit 0 is used.                                            |
|                                                                                                                                                                     | data_bus_width[1:0] | I          | Indicates the per lane pipe data bus width                                                                       |
|                                                                                                                                                                     | rx_data_n[31:0]     | I          | Per lane receive data into the VIP. Supports 8, 16, and 32bit bus widths                                         |
|                                                                                                                                                                     | rx_data_k_n[3:0]    | I          | Per lane control indication. Supports 8, 16, and 32 bit bus widths.                                              |
|                                                                                                                                                                     | rx_status_n[2:0]    | I          | Per lane receiver status. See PIPE spec for encodings.<br>Note: Any unused ports must be tied to a 0.            |
|                                                                                                                                                                     | rx_valid_n          | I          | Per lane indication that data coming into the VIP is valid and symbol lock has been achieved.                    |
|                                                                                                                                                                     | rx_data_valid_n     | I          | Per lane indication that data coming into the VIP is valid. Used primarily for rate matching. NOTE: pipe 3 only. |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b> |                             | <b>I/O</b> | <b>Description</b>                                                                                                                                                           |
|-----------------------------|-----------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | <i>rx_elec_idle_n</i>       | I          | Per lane indication that electrical idle is being received into the VIP<br><br>Note: Any unused ports must be tied to a 1.                                                   |
|                             | <i>invert_rx_polarity_n</i> | O          | Per lane indication to perform polarity inversion on data into the VIP                                                                                                       |
|                             | <i>tx_data_n[31:0]</i>      | O          | Per lane transmit data out from the VIP                                                                                                                                      |
|                             | <i>tx_data_k_n[3:0]</i>     | O          | Per lane transmit_control from the VIP                                                                                                                                       |
|                             | <i>tx_ei_code_n[31:0]</i>   | O          | Per lane error injection code. Indicates to the phy that an EI was either injected, or phy needs to inject the EI indicated by the code. For VIP only. No connection to DUT. |
|                             | <i>tx_compliance_n</i>      | O          | Per lane transmit compliance pattern enable from the VIP                                                                                                                     |
|                             | <i>tx_elect_idle_n</i>      | O          | Per lane transmit electrical idle/transmit enable from the VIP                                                                                                               |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b>                                                                                                                                                                                                         |                              | <b>I/O</b> | <b>Description</b>                                                                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------|---------------------------------------------------------------------------------------------------------|
| “Slave” PIPE Version 3 Interface<br><br>The signals prefixed “attached_” are relative to the DUT and are designed to connect up in a slave-like manner to a MAC DUT.<br>PIPE 3 models do not have a _8g postfix in their file name. | reset                        | I          | Active high master reset. Must only be asserted for 100ns ONCE per simulation at the beginning.         |
|                                                                                                                                                                                                                                     | attached_pipe_reset_n        | I          | pipe reset signal from the mac.                                                                         |
|                                                                                                                                                                                                                                     | pipe_clk                     | O          | pipe clock generated by the pipe slave for use by the DUT mac.                                          |
|                                                                                                                                                                                                                                     | attached_powerdown[1:0]      | I          | Command from the DUT MAC to change power state of the phy.                                              |
|                                                                                                                                                                                                                                     | attached_rate[1:0]           | I          | Link signaling rate control from the DUT MAC. NOTE: Port width is 1 bit for pipe2 and 2 bits for pipe3. |
|                                                                                                                                                                                                                                     | attached_txdetectrx          | I          | Command from the DUT mac to detect receiver.                                                            |
|                                                                                                                                                                                                                                     | attached_block_align_control | I          | Controls slave block alignment. NOTE: pipe 3 only.                                                      |
|                                                                                                                                                                                                                                     | attached_phy_status[31:0]    | O          | Phy response to rate or power change. Bit 0 only used for pipe2.                                        |
|                                                                                                                                                                                                                                     | attached_data_bus_width[1:0] | O          | Defines the bus width of per lane data.                                                                 |
|                                                                                                                                                                                                                                     | attached_rx_data_n           | O          | Per lane receive data into the DUT. Supports 8, 16, and 32bit bus widths                                |
|                                                                                                                                                                                                                                     | attached_rx_data_k_n         | O          | Per lane control indication. Supports 8, 16, and 32 bit bus widths.                                     |
|                                                                                                                                                                                                                                     | attached_rx_status_n[2:0]    | O          | Per lane receiver status. See PIPE spec for encodings.                                                  |
|                                                                                                                                                                                                                                     | attached_rx_valid_n          | O          | Per lane lindication that data coming into the DUT is valid and symbol lock has been achieved.          |
|                                                                                                                                                                                                                                     | attached_rx_elec_idle_n      | I/O        | Per lane indication that electrical idle is being received into the DUT                                 |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b>                                                                                                                                                                                                              |                               | <b>I/O</b> | <b>Description</b>                                                                                                                                                           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| “Slave” PIPE Version 3 Interface<br>(continued)                                                                                                                                                                                          | attached_invert_rx_polarity_n | I          | Per lane indication to perform polarity inversion on data into the DUT                                                                                                       |
|                                                                                                                                                                                                                                          | attached_tx_data_n[31:0]      | I          | Per lane transmit data out from the DUT.                                                                                                                                     |
|                                                                                                                                                                                                                                          | attached_tx_data_k_n[3:0]     | I          | Per lane transmit_control from the DUT.                                                                                                                                      |
|                                                                                                                                                                                                                                          | attached_tx_ei_code_n[31:0]   | I          | Per lane error injection code. Indicates to the phy that an EI was either injected, or phy needs to inject the EI indicated by the code. For VIP only. No connection to DUT. |
|                                                                                                                                                                                                                                          | attached_tx_compliance_n      | I          | Per lane transmit compliance pattern enable from the DUT                                                                                                                     |
|                                                                                                                                                                                                                                          | attached_tx_elect_idle_n      | I          | Per lane transmit electrical idle/transmit enable from the DUT<br><br>Note: Any unused ports must be tied to a 1.                                                            |
| “Master” PIPE Version 4 Interface<br><br>This type of interface is a standard PIPE interface to a phy. The 8G models require a PIPE4 interface, hence all models in the InstantiationModels directory with the _8g suffix use the PIPE4. | reset                         | I          | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.                                                                                     |
|                                                                                                                                                                                                                                          | pipe_reset_n                  | O          | Pipe reset signal to phy                                                                                                                                                     |
|                                                                                                                                                                                                                                          | pipe_clk                      | I          | Pipe clock from phy                                                                                                                                                          |
|                                                                                                                                                                                                                                          | powerdown[2:0]                | O          | Command to change power state of the phy. No vendor specific power levels are supported.                                                                                     |
|                                                                                                                                                                                                                                          | rate[1:0]                     | O          | Link signaling rate control                                                                                                                                                  |
|                                                                                                                                                                                                                                          | pclk_rate[2:0]                | O          | Specifies the value of the pipe clock.                                                                                                                                       |
|                                                                                                                                                                                                                                          | txdetectrx                    | O          | Command to detect receiver                                                                                                                                                   |
|                                                                                                                                                                                                                                          | block_align_contro            | O          | Controls slave block alignment. NOTE: Pipe 3 only.                                                                                                                           |
|                                                                                                                                                                                                                                          | tx_margin[2:0]                | O          | Selects transmitter voltage levels                                                                                                                                           |
|                                                                                                                                                                                                                                          | tx_swing                      | O          | Controls transmitter voltage swing level.                                                                                                                                    |
|                                                                                                                                                                                                                                          | lf[5:0]                       | O          | Provides the LF value advertised by the link partner.                                                                                                                        |
|                                                                                                                                                                                                                                          | fs[5:0]                       | O          | Provides the full swing value advertised by the link partner.                                                                                                                |
|                                                                                                                                                                                                                                          | width[1:0]                    | O          | Outputs the width of the per-lane data bus the mac is currently using.                                                                                                       |
|                                                                                                                                                                                                                                          | rx_standby[31:0]              | O          | Controls whether the phy RX is active when in L0 or L0s.                                                                                                                     |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b> |                         | <b>I/O</b> | <b>Description</b>                                                                                                                                                           |
|-----------------------------|-------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | phy_status[31:0]        | I          | Phy response to rate or power change.<br>For pipe 2, only bit 0 is used.                                                                                                     |
|                             | rx_standby_status[31:0] | I          | Reflects the active/standby state of the rx receiver.                                                                                                                        |
|                             | data_bus_width[1:0]     | I          | Indicates the per lane pipe data bus width.                                                                                                                                  |
|                             | rx_data_n[31:0]         | I          | Per lane receive data into the SVC.<br>Supports 8, 16, and 32bit bus widths.                                                                                                 |
|                             | rx_data_k_n[3:0]        | I          | Per lane control indication. Supports 8, 16, and 32 bit bus widths.                                                                                                          |
|                             | rx_status_n[2:0]        | I          | Per lane receiver status. See PIPE spec for encodings.<br>Note: Any unused ports must be tied to a 0.                                                                        |
|                             | rx_valid_n              | I          | Per lane indication that data coming into the SVC is valid and symbol lock has been achieved.                                                                                |
|                             | rx_data_valid_n         | I          | Per lane indication that data coming into the SVC is valid. Used primarily for rate matching.                                                                                |
|                             | rx_elec_idle_n          | I          | Per lane indication that electrical idle is being received into the SVC.<br>Note: Any unused ports must be tied to a 1.                                                      |
|                             | rx_start_block_n        | I          | Per lane indication that electrical idle is being received into the SVC is the first byte of data in the block.                                                              |
|                             | rx_sync_header_n        | I          | Per lane block sync header.                                                                                                                                                  |
|                             | invert_rx_polarity_n    | O          | Per lane indication to perform polarity inversion on data into the SVC.                                                                                                      |
|                             | tx_data_n[31:0]         | O          | Per lane transmit data out from the SVC.                                                                                                                                     |
|                             | tx_data_k_n[3:0]        | O          | Per lane transmit_control from the SVC                                                                                                                                       |
|                             | tx_ei_code_n[31:0]      | O          | Per lane error injection code. Indicates to the phy that an EI was either injected, or phy needs to inject the EI indicated by the code. For SVC only. No connection to DUT. |
|                             | tx_compliance_n         | O          | Per lane transmit compliance pattern enable from the SVC.                                                                                                                    |
|                             | tx_elect_idle_n         | O          | Per lane transmit electrical idle/transmit enable from the SVC.                                                                                                              |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b> |                                            | <b>I/O</b> | <b>Description</b>                                                                               |
|-----------------------------|--------------------------------------------|------------|--------------------------------------------------------------------------------------------------|
|                             | tx_data_valid_n                            | O          | Per lane indication that data transmitted by the SVC is valid. Used primarily for rate matching. |
|                             | tx_start_block_n                           | O          | Per lane indication that data transmitted by the SVC is the first byte of data in the block.     |
|                             | tx_sync_header_n[1:0]                      | O          | Per lane block sync header.                                                                      |
|                             | local_tx_preset_coefficientsn[17:0]        | I          | Coefficients returned from a coefficient lookup request.                                         |
|                             | link_eval_feedback_figure_of_meritn[7:0]   | I          | Figure of merit value from a link equalization evaluation request.                               |
|                             | link_eval_feedback_direction_change_n[5:0] | I          | Coefficient direction feedback from rx link eval request.                                        |
|                             | local_fsn[5:0]                             | I          | Provides the FS value for the phy.                                                               |
|                             | local_lfn[5:0]                             | I          | Provides the LF value for the phy.                                                               |
|                             | local_tx_coefficients_validn               | I          | Indicates that the values in local_tx_preset_coefficients[] are valid.                           |
|                             | tx_deemphn[17:0]                           | O          | Selects transmitter deemphasis.                                                                  |
|                             | local_preset_indexn[3:0]                   | O          | Index for the local phy preset coefficients requested by the mac.                                |
|                             | rx_preset_hintn[2:0]                       | O          | RX preset hint for the receiver.                                                                 |
|                             | get_local_preset_coefficientsn             | O          | Request a preset to coefficient mapping lookup.                                                  |
|                             | rx_eq_evaln                                | O          | Request from the mac for the receiver to perform an equalization evaluation.                     |
|                             | invalid_requestn                           | O          | Indicates the link eval feedback requested was out of range                                      |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b>                                                                                                                                                                                                                                 |                                  | <b>I/O</b> | <b>Description</b>                                                                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|------------|---------------------------------------------------------------------------------------------------------|
| "Slave" PIPE Version 4 interface                                                                                                                                                                                                                            | reset                            | I          | Active high master reset. Must only be asserted for 100ns ONCE per simulation at the beginning.         |
| The signals prefixed "attached_" are relative to the DUT and are designed to connect up in a slave like manner to a MAC DUT. The 8G models require a PIPE4 interface, hence all models in the InstantionModels directory with the _8g suffix use the PIPE4. | attached_pipe_reset_n            | I          | pipe reset signal from the mac.                                                                         |
|                                                                                                                                                                                                                                                             | pipe_clk                         | O          | pipe clock generated by the pipe slave for use by the DUT mac.                                          |
|                                                                                                                                                                                                                                                             | max_pclk                         | O          | Maximum pclk rate for a given speed.                                                                    |
|                                                                                                                                                                                                                                                             | attached_powerdown[2:0]          | I          | Command from the DUT MAC to change power state of the phy.                                              |
|                                                                                                                                                                                                                                                             | attached_rate[1:0]               | I          | Link signaling rate control from the DUT MAC. NOTE: port width is 1 bit for pipe2 and 2 bits for pipe3. |
|                                                                                                                                                                                                                                                             | attached_pclk_rate[2:0]          | I          | PCLK rate requested by the mac.                                                                         |
|                                                                                                                                                                                                                                                             | attached_txdetectrx              | I          | Command from the DUT mac to detect receiver.                                                            |
|                                                                                                                                                                                                                                                             | attached_block_align_control     | I          | Controls slave block alignment. NOTE: pipe 3 only.                                                      |
|                                                                                                                                                                                                                                                             | attached_tx_margin[2:0]          | I          | Selects transmitter voltage levels.                                                                     |
|                                                                                                                                                                                                                                                             | attached_tx_swing                | I          | Controls transmitter voltage swing level.                                                               |
|                                                                                                                                                                                                                                                             | attached_lf[5:0]                 | I          | Provides the LF value advertised by the link partner.                                                   |
|                                                                                                                                                                                                                                                             | attached_fs[5:0]                 | I          | Provides the full swing value advertised by the link partner.                                           |
|                                                                                                                                                                                                                                                             | attached_width[1:0]              | I          | Reflects the width of the data bus the mac wants to use.                                                |
|                                                                                                                                                                                                                                                             | attached_rx_standby[31:0]        | I          | Controls whether the phy RX is active when in L0 or L0s.                                                |
|                                                                                                                                                                                                                                                             | attached_phy_status[31:0]        | O          | Phy response to rate or power change. Bit 0 only used for pipe2.                                        |
|                                                                                                                                                                                                                                                             | attached_rx_standby_status[31:0] | O          | Reflects the active/standby state of the rx receiver.                                                   |
|                                                                                                                                                                                                                                                             | attached_data_bus_width[1:0]     | O          | Defines the bus width of per lane data.                                                                 |
|                                                                                                                                                                                                                                                             | attached_rx_data_n[              | O          | Per lane receive data into the DUT. Supports 8, 16, and 32bit bus widths.                               |
|                                                                                                                                                                                                                                                             | attached_rx_data_k_n[            | O          | Per lane control indication. Supports 8, 16, and 32 bit bus widths.                                     |
|                                                                                                                                                                                                                                                             | attached_rx_status_n[[2:0]       | O          | Per lane receiver status. See PIPE spec for encodings.                                                  |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b> |                                                    | <b>I/O</b> | <b>Description</b>                                                                                                                                                           |
|-----------------------------|----------------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | attached_rx_valid_n[                               | O          | Per lane lindication that data coming into the DUT is valid and symbol lock has been achieved.                                                                               |
|                             | attached_rx_data_valid_n[                          | O          | Per lane lindication that data coming into the DUT is valid. Used primarily for rate matching. NOTE: pipe 3 only.                                                            |
|                             | attached_rx_elec_idle_n                            | IO         | Per lane indication that electrical idle is being received into the DUT                                                                                                      |
|                             | attached_rx_start_block_n[                         | O          | Per lane lindication that data transmitted by the DUT is the first byte of data in the block. NOTE: pipe 3 only.                                                             |
|                             | attached_rx_sync_header_n[[1:0]                    | O          | Per lane block sync header. NOTE: pipe 3 only.                                                                                                                               |
|                             | attached_invert_rx_polarity_n[                     | I          | Per lane indication to perform polarity inversion on data into the DUT.                                                                                                      |
|                             | attached_tx_data_n[[31:0]                          | I          | Per lane transmit data out from the DUT.                                                                                                                                     |
|                             | attached_tx_data_k_n[[3:0]                         | I          | Per lane transmit_control from the DUT.                                                                                                                                      |
|                             | attached_tx_ei_code_n[[31:0]                       | I          | Per lane error injection code. Indicates to the phy that an EI was either injected, or phy needs to inject the EI indicated by the code. For SVC only. No connection to DUT. |
|                             | attached_tx_compliance_n[                          | I          | Per lane transmit compliance pattern enable from the DUT                                                                                                                     |
|                             | attached_tx_elect_idle_n[                          | I          | Per lane transmit electrical idle/transmit enable from the DUT. Note: Any unused ports must be tied to a 1.                                                                  |
|                             | attached_tx_data_valid_n[                          | I          | Per lane lindication that data transmitted to the SVC is valid. Used primarily for rate matching. NOTE: pipe 3 only.                                                         |
|                             | attached_tx_start_block_n[                         | O          | Per lane lindication that data transmitted to the SVC is the first byte of data in the block. NOTE: pipe 3 only.                                                             |
|                             | attached_tx_sync_header_n[[1:0]                    |            | Per lane block sync header. NOTE: pipe 3 only.                                                                                                                               |
|                             | attached_local_tx_preset_coefficients_n[[17:0]     |            | Coefficients returned from a coefficient lookup request.                                                                                                                     |
|                             | attached_link_eval_feedback_figure_of_meritn[7:0]  | O          | Figure of merit value from a link equalization evaluation request..                                                                                                          |
|                             | attached_link_eval_feedback_direction_changen[5:0] | O          | Coefficient direction feedback from rx link eval request.                                                                                                                    |

**Table 1-2 pciesvc\_model ports (Continued)**

| <b>Model Interface Type</b> |                                          | <b>I/O</b> | <b>Description</b>                                                           |
|-----------------------------|------------------------------------------|------------|------------------------------------------------------------------------------|
|                             | attached_local_fsn[5:0]                  | O          | Provides the FS value for the phy.                                           |
|                             | attached_local_lfn[5:0]                  | O          | Provides the LF value for the phy.                                           |
|                             | attached_local_tx_coefficients_validn    | O          | Indicates that the values in local_tx_preset_coefficients[] are valid.       |
|                             | attached_tx_deemphn[17:0]                | I          | Selects transmitter deemphasis.                                              |
|                             | attached_local_preset_indexn[3:0]        | I          | Index for the local phy preset coefficients requested by the mac.            |
|                             | attached_rx_preset_hintn[2:0]            | I          | RX preset hint for the receiver.                                             |
|                             | attached_get_local_preset_coefficient_sn | I          | Request a preset to coefficient mapping lookup.                              |
|                             | attached_rx_eq_evaln                     | I          | Request from the mac for the receiver to perform an equalization evaluation. |
|                             | attached_invalid_requestn                | I          | Indicates the link eval feedback requested was out of range.                 |

### 1.2.3 Configuring the PIPE Data Bus Width

For PIPE4 users, the per-lane data bus width and rate of the pipe clock are determined by the pipe signals pclk\_rate and width (not to be confused with the pipe signal data\_bus\_width). If you are using the SPIPE model, simply connect up the pclk\_rate and width pipe signals to your MAC. If you are using the MPIPE model, use the ConfigurePipeWidthPclkTable task call, in order for the mac to properly drive pclk\_rate and width. See [Table 6-2](#) for details about the ConfigurePIpeWidthPclkTable task.

The pipe models that do not end with “\_8g” support PIPE 2.1/PIPE 3.0. In these versions the pclk\_rate signal does not exist, and the ConfigurePipeWidthTable task should be called on the spipe model to tell it at what width to operate for various speeds. See [“Physical Layer”](#) for more details. The mpipe model for PIPE2.1/PIPE3.0 takes the width reflected on the data\_bus\_width signal. Refer to PIPE2.1/PIPE3.0 for more information on the data\_bus\_width signal.

If you are using the SERDES model or the PMA model, do not use the ConfigurePipeWidthTable task or the ConfigurePipeWidthPclkTable task.

### 1.2.4 Configuring the PIPE Data Bus Width

For PIPE4 users, the per-lane data bus width and rate of the pipe clock are determined by the pclk\_rate and width pipe signals, (not to be confused with the pipe signal data\_bus\_width). If you are using the SPIPE model you simply need to connect up the pclk\_rate and width pipe signals to their MAC. MPIPE users need to call the ConfigurePIpeWidthPclkTable task in order for the mac to properly drive pclk\_rate and width signals. See [“Physical Layer Configuration Tasks”](#) for information about the ConfigurePipeWidthPclkTable task.

The pipe models that do not end with \_8g support PIPE 2.1/PIPE 3.0. In these versions of the pipe spec the mac does not specify the width and rate of the pipe clock, so you should call the ConfigurePipeWidthTable task on the spipe model to tell it the width at which to operate at various speeds. See [“Physical Layer”](#)

[Configuration Tasks](#)” for more details. The mpipe model for PIPE2.1/PIPE3.0 will take the width reflected on the data\_bus\_width signal. See [Table 1-2](#) for information about the data\_bus\_width signal.

If you are using the SERDES or PMA models, do not use the ConfigurePipeWidthTable task or the ConfigurePipeWidthPclkTable task.

### 1.2.5 Using ifdefs with PIPE 4.0 To Select Additional Signals

Two “`ifdef`’s that are used to by the PIPE 4.0 (and above) instantiation models (“InstantiationModels/pciesvc\_\*pipe\*\_8g.v”) to select additional interface signals for PIPE 4.2 and PIPE 4.3. These “`ifdef`’s are:

- ❖ `ifdef PCIESVC\_PIPE\_SPEC\_VER\_GTR\_4\_0 This “define” selects the additional signals associated with PIPE 4.2 versus PIPE 4.0. Signals such as “rx\_eq\_in\_progress\_0” (through \_n), “lf\_0” (through \_n), “fs\_0” (through \_n). It is also used to determine the “PIPE\_SPEC\_VER” assigned to the “p10” PHY instance in the “InstantiationModels/pciesvc\_mac\_\*pipe\*\_8g.v” models.
- ❖ `ifdef PCIESVC\_PIPE\_SPEC\_VER\_4\_3 This “define” selects the additional signals associated with PIPE 4.3 versus PIPE 4.2. Signals such as “async\_power\_change\_ack” and “powerdown[3:0] (versus [2:0]). It is also used with “`ifdef PCIESVC\_PIPE\_SPEC\_VER\_GTR\_4\_0” to determine whether “4.2” or “4.3” is assigned to “PIPE\_SPEC\_VER” that is then assigned to the “p10” PHY instance in the “InstantiationModels/pciesvc\_mac\_\*pipe\*\_8g.v” models.

As a result:

- ❖ PIPE 4.0 usage would have neither of the above two “`ifdef`’s defined.
- ❖ PIPE 4.2 usage would have “PCIESVC\_PIPE\_SPEC\_VER\_GTR\_4\_0” defined.
- ❖ PIPE 4.3 usage would have “PCIESVC\_PIPE\_SPEC\_VER\_GTR\_4\_0” and “PCIESVC\_PIPE\_SPEC\_VER\_4\_3” defined.

### 1.2.6 Model Configuration Overview

It is recommended that configuration tasks be used after reset is de-asserted from the pciesvc\_model.

Recommended tasks to be set prior to usage are described in [Table 1-3](#). The details of the task may be found in the respective section of the documentation.

**Table 1-3 Configuration tasks to set before usage**

| Name                     | Layer             | Description                                                                           |
|--------------------------|-------------------|---------------------------------------------------------------------------------------|
| SetAllocatedCredits      | Transaction Layer | Set Initial credits for a VC                                                          |
| SetVcEnable              | Transaction Layer | Enable / Disable VCs                                                                  |
| SetTrafficClassMap       | Transaction Layer | Maps TCs to VCs                                                                       |
| AddMemAddrApplIdMapEntry | Transaction Layer | If not using the default, sets the Application ID for the memory target address range |
| AddIOAddrApplIdMapEntry  | Transaction Layer | If not using the default, sets the Application ID for the I/O target address range    |

**Table 1-3 Configuration tasks to set before usage (Continued)**

| Name               | Layer           | Description                                                                                                                                     |
|--------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| SetLinkEnable      | Data Link Layer | Enable / disable the Data Link Layer                                                                                                            |
| SetSupportedSpeeds | Physical Layer  | Sets the supported speeds that will be advertised during link training. If link training is bypassed, the highest supported speed will be used. |
| SetLinkWidth       | Physical Layer  | Sets the width of the link, enable the state machine to start                                                                                   |

## 1.2.7 Model Parameters

Several parameters are set at the model. They typically ‘trickle-down’ to the individual layers. [Table 1-4](#) lists those parameters.

**Table 1-4 Parameters set in the model**

| Parameter Name                | Settable VAR?* | Type    | Range               | Default Value                                        | Description                                                                                                                                        |
|-------------------------------|----------------|---------|---------------------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| DEVICE_IS_ROOT                | No             | Integer | 0-1                 | (Per model)                                          | This value is ‘1’ if the particular model is for a root, else it is ‘0’.                                                                           |
| NUM_PMA_INTERFACE_BITS        | No             | Integer | 10, 16, 32, 64, 128 | 10                                                   | Number of bits on the PMA interface                                                                                                                |
| PCIE_SPEC_VER                 | No             | Real    | 1.1, 2.0, 2.1, 3.0  | PCIE_SPEC_VER_3_0                                    | See <code>Include/pciesvc_parms.v: PCIE_SPEC_VER_*</code><br>Note: Please set this here, not in the individual layers.                             |
| HIERARCHY_NUMBER              | No             | Integer | 0 - large value     | 0                                                    | The per-root hierarchy number – these start at 0 and count upwards. Set this to the root hierarchy that this model belongs to.                     |
| ENABLE_SHADOW_MEMORY_CHECKING | No             | Integer | 0-1                 | 1                                                    | If set, applications will check memory reads against the shadow memory.<br>Make sure this is not enabled if the shadow memory is not instantiated. |
| DISPLAY_NAME                  | No             | String  |                     | “pciesvc_xx_yy_mod_el_zz.” (Specific to each model). | String prefixed to messages to display in the output log.                                                                                          |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “\_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

## 1.2.8 Multiple Root Hierarchies

If you need to instantiate multiple root hierarchies, then each one must be marked uniquely to distinguish it. This is done via the HIERARCHY\_NUMBER parameter. For each root (and associated endpoint) model

you instantiate, you need to defparam the appropriate hierarchy number to that model. If you are using the Shadow Memory mechanism for doing automatic checking of data, you also need to defparam those shadows respectively (See “[The Global PCIE Address Space Shadow](#)”).

### 1.2.9 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 parameter NUM\_TX\_TS1\_IN\_POLLING\_ACTIVE (see [Table 6-8](#)). 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.

## 1.3 Test Environment Requirements

This section details requirements for the PCIE model to function properly in the customer’s test environment. Refer to the PCIE/Verilog/Example directory for example of model usage.

The global memory svc\_mem must be instantiated in the test environment. It is recommended that only one instantiation of the memory be used. For further information regarding the svc\_mem module, refer to “[Memory Model Utility](#)”. To properly use the svc\_mem model, the define PCIESVC\_MEM\_PATH must be set to the full instantiation name of the global memory model.

A reset signal applied to the VIP must be in the reset state at time zero. There is no limit in the length of time the reset is held asserted. However, once the reset is de-asserted, it may not be asserted again. Thus, for proper DUT verification, it is advisable to separate the VIP model reset from the DUT reset

The various parameters described in the following chapters that control the behaviors of the VIP may be controlled using the defparam syntax OR by modifying the associated \*\_VAR during simulation runtime. The \*\_VAR complement is commonly used in environments where the VIP is wrapped around an abstract verification language such as SystemC, e, or OpenVera. Verilog only or System Verilog test environments often make use of the \*\_VAR complement as well. When using the \*\_VAR feature, a \*\_VAR may not be assigned until at least 1 simulation time tick has passed as the \_VARs will be assigned in the model at time 0 to the value of the corresponding parameter. In the top level example, INVERT\_TX\_POLARITY in the pcs is assigned after a #1 delay. (Note: An acceptable alternative solution is to add defparam port0.pcs0.INVERT\_TX\_POLARITY = 1 after a pcie\_port\_model instantiation).

At the completion of the test, it is useful to output the various statistics kept by the VIP to the log file. This helps in determining corner case coverage and debug info.

A set of SystemVerilog APIs can optionally be used if desired. To include these APIs into the model, you must set the two defines PCIESVC\_INCLUDE\_SYSTEMVERILOG\_API and SVC\_INCLUDE\_SYSTEMVERILOG\_API in order for the SystemVerilog API routines to be pulled into the VIP.

### 1.3.1 Gen3 Requirements

Enabling Gen3 support in the VIP requires the instantiation of \*\_8g.v model and EXPERTIO\_PCIESVC\_INCLUDE\_8G defined on the command line. Even if EXPERTIO\_PCIESVC\_INCLUDE\_8G is not defined, \*\_8g.v models will still work correctly as long as Gen3 functionality is not exercised. Gen3 functionality includes 8G speeds, L1 substates, and so on.

## 1.4 System Verilog APIs

The product is methodology neutral, and may be controlled from any high level language including SystemVerilog.

There are two common SystemVerilog methodology approaches: UVM/OVM/VMM and the “Two Kingdoms” methodology. The PCIe VIP application programming interfaces (APIs) are neutral to both of these approaches.

For test environments that use SystemVerilog constructs such as program blocks and other elements that do not allow direct scope resolution, a set of SystemVerilog class object APIs are provided. The top level class is instantiated, then new is called with the hierarchical path to the model that the class should be bound to. The class constructor locates all the layers in the VIP model referred to, and instantiate subclasses per layer in the model.

Once this is done, you may set any *constraint\_VAR* in the model by calling a SystemVerilog API method to set or get the constraint value. The method name is formed by:

1. Prepending “Set” or “Get” to the \_VAR name.
2. Making the name of the \_VAR into mixed “camel” case
3. Removing the “\_”.
4. Dropping the \_VAR suffix.
5. Appending “Api” to the end.

For example, the Data Link Layer MIN\_INITFC\_DELAY constraint VAR becomes root0.port[0].dl[0].SetMinInitfcDelayApi(*value*). Although this looks like a hierarchical path, it is actually a navigation through a structure of classes, hence use of the “[ ]”.

Likewise there are SystemVerilog APIs for all user and configuration tasks and functions documented: Just append “Api” to the end of the Verilog task or function listed. For example, the Transaction Layer SetTrafficClassMap() task is called via the SystemVerilog root0.port[0].tl[0]SetTrafficClassMapApi().

There is an example of instantiating and using the SV APIs in PCIE/Verilog/Example/test\_basic\_sv.sv.

## 1.5 Running Multiple Simulations in the Same Directory

Many environments run multiple simulations; in general this is supported without any issues. However, if you need to run more than one simultaneously in the same directory, the VIP (and, of course, your particular simulator setup) must be configured specifically for this. To enable this configuration in the VIP, set the following plusarg in your simulation:

```
+expertio_unique_sim_str="XXX"
```

Set the string “XXX” to a per-simulation-unique string (one possibility is to use the process ID, or a global incrementing number). Note that you need to also take care of other per-simulation information (e.g. make sure log files, etc. are also unique) in your environment.

## 1.6 SVC Memory Usage

TLPs are passed with pointers to or from the SVC via the Verilog and SystemVerilog interfaces. The pointers reference a memory location in the svc\_mem. The svc\_mem instantiation is discussed in “[Test Environment Requirements](#)”, and the usage is described in “[Memory Model Utility](#)”.

To store a TLP in the svc\_mem, the memory must first be allocated via AllocMemory. The pointer (address) that is returned is used to store the TLP via WriteMemory task. The TLP can be passed to the SVC using that pointer. For TLPs received from the SVC, the TLP can be accessed in svc\_mem via a ReadMemory task

call. The pointer to the TLP will be provided as a task argument (\*ptr) in the SVC interface task call. Once the TLP is consumed, the memory space must be returned to the free pool via a FreeMemory task call to the svc\_mem. This applies to both sent and received TLPs.

The UVM interface does not use the svc\_mem to pass TLPs: it uses dynamic arrays defined in the sequence item.

NOTE: Neglecting free memory will result in the svc\_mem being completely consumed. If this occurs, any one of the AllocMemory task calls within the SVC may result in an error. The simulation will stop at this point. If this occurs, make sure svc\_mem is freed for all TLPs sent to or received from the SVC. See "[Driver Memory Management Requirements](#)" for further details about driver requirements.

## 1.7 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 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.

# 2 Installing and Running the PCIe VIP

This chapter provides information on how to install and set up the VC VIP for PCI Express.

## 2.1 Accessing Product Documentation

After the PCIe VIP is downloaded and installed, the documentation resides at:

\$EXPERTIO\_PCIE\_SVC\_INSTALL\_PATH/doc

## 2.2 Process Overview

To install PCIe VIP, you must follow the steps in this installation guide.



## 2.3 Verifying Hardware Requirements

Table 2-1 describes the system requirements for the VC VIP for PCI Express product.

**Table 2-1 System Requirements**

| Element             | Minimum System Requirement                                                                                                                                                                                                                                                                                                                                                               |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Platform/OS and VCS | See <a href="#">Platform/OS and Simulator Software</a>                                                                                                                                                                                                                                                                                                                                   |
| Disk Space          | <ul style="list-style-type: none"> <li>Approximately 20 MB available disk space for installation and basic use</li> </ul>                                                                                                                                                                                                                                                                |
| Memory              | <ul style="list-style-type: none"> <li>For users of VCS or VCS MX, see VCS Installation Notes or VCS MX Installation Notes, which are accessible from the Synopsys Installation Guide (search for “synopsys installation guide” on <a href="http://www.synopsys.com">www.synopsys.com</a>).</li> <li>For users of other simulators, see the documentation for your simulator.</li> </ul> |



**Note** You must have access to [SolvNetPlus](#) to download the release image. You can sign up to receive updates for any VIP component through this web site as well.

## 2.4 Verifying Software Requirements

The PCIe VIP is tested with certain versions of platforms and simulators. This section lists software that the PCIe VIP requires.

### 2.4.1 Platform/OS and Simulator Software

To see which platform/OS and simulator versions are qualified for use with the PCIe VIP, check the support matrix in the *Verification IP for PCIe VIP Release Notes*.

### 2.4.2 Synopsys Common Licensing (SCL) Software

The SCL software provides the licensing function for the PCIe VIP. Acquiring the SCL software is covered in [Licensing](#).

### 2.4.3 Other Third Party Software

- ❖ **Adobe Acrobat:** PCIe VIP documents are available in Acrobat PDF files. You can get Adobe Acrobat Reader for free from <http://www.adobe.com>.
- ❖ **HTML browser:** The VC VIP for PCI Express 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.5 Setting Environment Variables

### 2.5.1 Setting Common Environment Variables

Set the ARCH and SVC\_SIM variables as shown below:

`EXPERTIO_PCIE_SVC_INSTALL_PATH`

Set this variable to *installationPath/PCIE/Verilog*.

#### ARCH

Set this variable to your architecture. (In a Cadence environment, use the the UNIX `uname` command. If `uname` returns Linux or one of its variants, set ARCH to lnx86. If `uname` returns Solaris set it to sun4v.)

Supported values:

- lnx86 (Linux on x86)
- sun4v (sun-solaris)

Default: none

#### SVC\_SIM

Set to one of the following:

- VCS (Synopsys simulators: VCS, VCS-MX)
- NC (Cadence simulators: NC-Verilog, IUS)
- MT (Mentor simulators: MTI, Questa)

### 2.5.1.1 Simulator-Specific Variables and Command Options

The installation helper scripts (`vcs`, `ncs`, or `mts` – see “[Helper Scripts](#)”) attempt to set the command line appropriately, but you need to set environment variables as described below.

#### 2.5.1.1.1 VCS/VCS MX Environment Variable

**VCS\_HOME** Set to point to your local Synopsys installation tree  
Default: none

#### 2.5.1.1.2 MTI/Questa Environment Variable

**MT\_INST\_DIR** Set to point to your local MTI/Questa installation tree  
Default: none

#### 2.5.1.1.3 NC Environment Variables

**CDS\_INST\_DIR** Set to point to your local Cadence installation tree.  
Default: none

**LD\_LIBRARY\_PATH** Path to your shared libraries. Both the Cadence shared libraries and those that live under the Verilog sub-directory in the VIP installation directory are needed.  
Default: none

## 2.6 Downloading and Installing the Synopsys PCIe VIP



The Electronic Software Transfer (EST) system only displays products your site is entitled to download. If the product you are looking for is not visible please 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 <http://solvnet.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.6.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.
3. Enter your Synopsys SolvNetPlus password.
4. Click the "Sign In" button.
5. Choose the "VIP" from the list of available products under "My Product Releases".
6. Select the product version from the list of available versions.
7. Click the "Download Here" button for HTTPS download.
8. After reading the legal page, click on "Yes, I agree to the above terms".
9. Click the download button(s) next to the file name(s) of the file(s) you wish to download.

Note: The product names are appended with one of the letters "V", for the VCS/VCSMX version, or "M", for the MTI/Questa version, or "N", for the NC version.

10. Follow browser prompts to select a destination location.
11. You may download multiple files simultaneously.

### 2.6.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

### 2.6.3 Setting Up FlexLM Licensing

The VIP can be built to run in a FlexLM licensing environment. If you use FlexLM licensing, follow the instructions below (as well as those in README.64-bit if you are using a 64-bit system.)

#### 2.6.3.1 Downloading and Installing the DesignWare Libraries

A shared library in the Synopsys DesignWare suite is needed to interface between the VIP and the FlexLM mechanism. If you have not already installed the DesignWare library, follow these steps to do so:

1. Log into the Synopsys SolvNet Download Center at the following link:  
<https://solvnet.synopsys.com/DownloadCenter/dc/product.jsp>
2. Click on "VCS Verification Library" near the bottom of the list.
3. Click on the VCS version you are using, for example "F-2011.12".
4. Click "Download Here" button
5. Click "YES, I AGREE TO THE ABOVE TERMS" to acknowledge the download terms.

6. Click on the Download button for the dw\_vip\_common\_5.95a.run file.
7. Save the dw\_vip\_common\_5.95a.run file to a UNIX directory.
8. From a UNIX prompt create a dw\_home directory and execute the following:  

```
$ dw_vip_common_5.95a.run --dir path/dw_home
```
9. Use the following command to set the DESIGNWARE\_HOME environment variable to the *path* you specified for the dw\_home directory:  

```
$ setenv DESIGNWARE_HOME path/dw_home
```

### 2.6.3.2 Running Simulations in the FlexLM Environment

An additional command is needed to pull in the above DesignWare library. The additional command varies for the different simulators, as shown below. Where *platform* is specified in the command, replace it by the appropriate entry from the Platform column in [Table 2-2](#).

**Table 2-2 Platform designations for supported platform types**

| Platform type  | Simulator | Platform     |
|----------------|-----------|--------------|
| 64-bit Linux   | 64-bit    | amd64        |
| 64-bit Linux   | 32-bit    | linux        |
| 32-bit Linux   | 32-bit    | linux        |
| 32-bit Solaris | 32-bit    | solarisx86   |
| 64-bit Solaris | 64-bit    | x86solaris64 |

#### 2.6.3.2.1 VCS/VCS MX

To include the DW common library, add the following to your simulators command line:

```
"$DESIGNWARE_HOME/vip/common/latest/C/lib/platform/VipCommonNtb.so"
```

#### 2.6.3.2.2 NC

To include the DW common library, add the following to your simulators command line:

```
"-sv_lib $DESIGNWARE_HOME/vip/common/latest/C/lib/platform/VipCommonNtb.so"
```

#### 2.6.3.2.3 MTI/Questa

To include the DW common library, add the following to your simulators command line:

```
"-R -sv_lib $DESIGNWARE_HOME/vip/common/latest/C/lib/platform/VipCommonNtb -"
```

Note: Be sure to include the trailing hyphen (-).

When running commands with make, these additional command line arguments are added with the VC\_ARGS make variable. For example, to run the test named test\_basic.fl in the Example directory, use the following command line (where the simulator is VCS on a 32-bit system):

```
% make test_basic VC_ARGS="$DESIGNWARE_HOME/vip/common/latest/C/lib/linux/ \
VipCommonNtb.so"
```

## 2.6.4 32-bit and 64-bit Simulation Modes

On most simulators you can run in either a native 64-bit mode, or a legacy-emulated 32-bit mode.

Running in emulated 32-bit mode uses the same PLIs as those used on 32-bit machines. Generally they do not even need to be recompiled. This can be useful on a multi-machine heterogeneous grid with both 32 and 64-bit processors, since a single PLI can be shared across machines. The downside is that simulations that require very large amounts of memory (greater than 3GB) will be memory-constrained by the 32-bit library.

Compilation of the 32-bit PLI typically requires special command-line switches to inform the compiler/linker to create 32-bit object files (see “[Running in 32-bit mode](#)” and “[Run a 64-bit executable using 32-bit PLI object](#)”).

In the native 64-bit mode, you must use a 64-bit PLI. If a 64-bit mode compiler is available, there generally is no need for special methods to build the PLI objects.

#### **2.6.4.1 Settings for Synopsys VCS/VCS MX**

There are two basic ways to run VCS/VCS MX simulations on a 64-bit machine:

- ❖ “[Run a 64-bit executable using 32-bit PLI object](#)”
- ❖ “[Run a 64-bit executable using a 64-bit PLI object](#):”

##### **2.6.4.1.1 Run a 64-bit executable using 32-bit PLI object**

Compile VCS in 64-bit mode, but generate a 32-bit executable.

1. Rebuild the 32-bit PLIs, after cleaning out the old ones:

```
% setenv SVC_USE_64BIT_LNX 1
% cd installationDir/Verilog
% make clean
% make
```

2. When compiling or running VCS, add the -comp64 option (note that the -full164 option is not used here).

##### **2.6.4.1.2 Run a 64-bit executable using a 64-bit PLI object:**

Run VCS with the -full164 option, having it compile your PLI. The command to do this is similar to the following:

```
vcs -CFLAGS "-I$TOP/PCIE/Verilog" -sverilog -full164 -R -q -debug_access+r+w+nomemcbk -debug_region=cell+encrypt +plusarg_save +v2k -P $TOP/PCIE/Verilog/Util/pli.tab
$TOP/PCIE/Verilog/Util/Msglog/msglog.c +incdir+$TOP/PCIE/Verilog
-file test.fl
```

(Note that the msglog.c file is specified in the command, not the object.)

Alternatively, use the vcs script to run it. For example:

```
Util/vcs -f test_basic.fl
```

#### **2.6.4.2 Settings for Cadence NC**

There are two basic methods for running NC simulations on a 64-bit machine:

- ❖ “[Running in 32-bit mode](#)”, using 32-bit PLI library
- ❖ “[Running in 64-bit mode](#)” with a 64-bit PLI library

##### **2.6.4.2.1 Running in 32-bit mode**

1. Rebuild the 32-bit PLIs, after cleaning out the old ones:

```
% setenv SVC_USE_64BIT_LNX 1
% cd installationDir/Verilog
% make clean
% make
```

2. Run the simulation using the 32-bit version of NC. For example:

```
% cd Example
% make test
```

#### 2.6.4.2.2 Running in 64-bit mode

Running in 64-bit mode enables a much larger available memory. PLIs compiled for 64-bit must be used with the `irun` 64-bit command.

Your search path must be set to find a `gcc` version in a `*x86_64` directory. To check which version of the `gcc` tool is found in your search path, use the following command:

```
unix> gcc --version
```

After verifying that the desired version of `gcc` is being found, test your environment by typing the following command:

```
% gcc -dumpmachine
```

and make sure that it returns the `x86_64` variant.

To keep the compiler/linker from building 32-bit libraries, make sure the environment variable `SVC_USE_64BIT_LNX` is unset:

```
% unsetenv SVC_USE_64BIT_LNX
```

Build the libraries and create a `.so` file:

```
% cd installationDir/Verilog
% make clean
% make
```

Use the following command to verify that the libraries are 64-bit:

```
% file dyn_libpli_lnx86.so
```

When you run the `file` command on the `.so` file created above, it should return "ELF 64-bit ...". After you have verified that, rerun the simulation with the PATH to this 64-bit `.so` file, and you will be able to use the `.so` file in a 64-bit `irun` simulation.

## 2.7 Building the Tools, Header Files and PLI Libraries

### 2.7.1 Makefiles

The VIP comes with Makefiles for various platforms, which have a number of platform-specified variations. These include basic UNIX tools (such as `ls`, `cat`, `sed`, and so on), default development tools (such as `cc`, `make`, and so on), and additional site-specific tools and scripts.

The installer script runs `make` at the `installationDir/PCIE/Verilog` directory level to create shared libraries for each platform supported: Linux, Solaris, 32-bit, and 64-bit.

After the `make` completes, verify that the `dyn_libpli.so` file is present in the `installationDir/PCIE/Verilog` directory.

If you need to clean up everything and start from scratch, run a `make clobber`. To just rebuild the PLI libraries, run `make clean` followed by `make` in the `PCIE/Verilog` directory.

## 2.7.2 Proper Path for Setup

Check for the following and provide the proper path for your setup.

```
+define+PCIESVC_MEM_PATH=top.mem0
+define+EXPERTIO_PCIESVC_GLOBAL_SHADOW_PATH=top.global_shadow0
+define+SVC_RANDOM_SEED_SCOPE=top.global_random_seed
```

## 2.7.3 Helper Scripts

The VIP includes sample invocation scripts that are customized for each particular simulator. The helper scripts are located in the Util directory and are created when you run make. The scripts are named ncs, mts, vcs, and param2def.

vcs - Invokes the VCS compiler / simulator with appropriate arguments.

ncs - Invokes the NC-Verilog compiler / simulator with appropriate arguments.

mts - Invokes the MTS compiler / simulator with appropriate arguments.

param2def - Converts a file of Verilog parameters to the equivalent C header file.

To see information about using a helper script, call it with the -help option. For example:

```
vcs -help
```

You must set an additional environment variable before you use any of the invocation helper scripts:

*product*SVC\_INCDIRS (for example, PCIESVC\_INCDIRS)

Set the variable to the include path for include dirs. The syntax is similar to the +incdir syntax:

+DIR1+DIR2+...

If the *product*SVC\_INCDIRS variable is not set, the helper invocation script will attempt to infer the directory locations from the current (script) location, and set the variable to the top-level directory (*installationDir/PCIE/simulatorType*).

## 2.7.3.1 Running the Scripts

Change to the directory that contains the test you want to run, then execute the appropriate command below.

### 2.7.3.1.1 VCS/VCS MX

Run *topLevelDirectory*/Util/vcs -f filelist

NOTE:

See "[Running Simulations in the FlexLM Environment](#)" if you are running with FlexLM licensing.

### 2.7.3.1.2 NC

Run *topLevelDirectory*/Util/ncs -f filelist

### 2.7.3.1.3 MTI/Questa

Run *topLevelDirectory*/Util/mti -f filelist

## 2.7.4 Setting Up an Example

Examples are provided for all supported simulators.

To build the Verilog example in *installationDir*/PCIE/Verilog/Example, for instance, run make as follows:

```
make test_basic VC_ARGS="-V $DESIGNWARE_HOME/vip/common/latest/C/lib/amd64/  
VipCommonNtb.so"
```

where the *lib* directory matches your compiler (32 or 64 bit) and OS (linux, amd64, suse32, suse64, and so on).

VC\_ARGS is used to supply options to the scripts and simulator.

You can use -V to echo output to stdout, otherwise all output goes to /dev/null and only the log file will contain the output.

## 2.8 Running a Test

Note that your own environment may require additional libraries and defines.

Go to the directory that contains the test you want to run, and execute the command below that applies to your simulator:

The make and scripts provided are for illustration only, enabling the examples to run. You should review these and incorporate the appropriate commands into your environment.

### 2.8.1 VCS/VCS MX

```
vcs commandLineArguments [+define ...] -file filelist
```

### 2.8.2 NC

```
ncverilog commandLineArguments [+define ...] -f filelist
```

### 2.8.3 MTI/Questa

```
vlog commandLineArguments [+define ...] -f filelist
```

## 2.9 Licensing

The VC VIP for PCI Express uses the Synopsys Common Licensing (SCL) software to control its usage. You can find general SCL information at:

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

PCIe VIP licensing requirements vary depending on whether the Discovery VIP or the SVC VIP is being used, whether the VIP is a Gen2 or Gen3 VIP, and whether it is a Verilog or SVT VIP. [Figure 2-1](#) shows the license search sequence for Discovery VIPs. [Figure 2-2](#) shows the license search sequence for SVC VIPs.

**Figure 2-1** Discovery PCIe VIP license acquisition sequences

**Figure 2-2 PCIe SVC VIP license acquisition sequences**

Only one license is consumed per simulation session, no matter how many VIP products are instantiated in the design.

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

## 2.10 Controlling License Usage

### 2.10.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.10.2 Simulation License Suspension

All VIP 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.11 Troubleshooting

This section provides troubleshooting tips if you encounter problems with licensing, installation, setting up your environment, and supported tools.

### 2.11.1 Licensing Problems

**Q:** *My simulations are exiting with an error. I suspect it is a licensing issue. How do I fix this?*

**A:** By default, simulations exit with an error when a license cannot be secured. Alternatively, the DW\_NOAUTH\_CONTINUE environment variable can be set to allow simulations to continue when one or more VIP models fail to authorize. Unauthorized VIP models essentially become disabled when DW\_NOAUTH\_CONTINUE is set to any value.

```
% setenv DW_NOAUTH_CONTINUE
```

Also, some simulation environments allow *license polling*, which pauses the simulation until a license is available. For more information about license polling, see [License Polling](#). If you encounter further licensing issues, contact customer support using the process described in [Customer Support](#).

### 2.11.2 Problems with Compiling or Running

- ❖ Examine the initial lines of output to determine problems. Sometimes “cascading” problems cause a single simple issue to look like multiple problems.
- ❖ Typically, problems compiling the Verilog are caused by an incorrect include search path. Make sure that either the default path will work for you or that the *productSVC\_INCDIRS* environment variable is set to the correct path.
- ❖ For problems with a missing PLI library (dyn\_libpli.so or plilib.so), check the following:
  - ◆ Verify that the library is where you expect it to be.
  - ◆ Check the setting of the LD\_LIBRARY\_PATH environment variable.
  - ◆ Did you run make at the beginning to build the object files and shared libraries?
  - ◆ Make sure the permissions on the library are set so that it is readable by you.
  - ◆ Did you compile a different type (such as 64-bit) PLI than you are simulating with?
- ❖ For compiler problems, make sure that the compiler is not an old K&R compiler because those compilers are not ANSI compatible. Use an ANSI-compatible compiler.
- ❖ For runtime errors reported in encrypted segments of VIP models, check that all the necessary +define statements are provided and that the paths are correct.

## 2.12 Downloading Protocol Analyzer

Protocol Analyzer is a separate download from the PCIe VIP. To find the latest version, login to SolvNet and then perform the following steps:

1. Select Downloads from the top menu bar.
2. Select the Complete Product List tab.
3. Select view products for A-G.
4. Under A-G > view products, select Discovery Verification IP.
5. Select the version you want to download. .
6. Select one of these three options:

[Download Here](#) | [via FTP](#) | [FTP Download Instructions](#)

7. Click the YES, I AGREE TO THE ABOVE TERMS button to accept the download agreement terms.
8. Under "File" in the table, look for "vip\_pa\*", where "\*" represents a version, and click the Download button for the version you want to download.



# 3 Applications

---

The software application layer is responsible for generating and handling transactions. To accelerate testcase development, Synopsys provides a *driver* for creating transaction requests and tracking completions as well as a *completion target* for handling the transactions and returning completions.

## 3.1 Driver Application

The driver provides a simple interface for users to quickly create transactions and track the corresponding completions. Transactions are created by calling tasks, though some TLP fields will be set through configuring \_VARs discussed in the next section.

### 3.1.1 Driver Parameters

Driver parameters are listed in [Table 3-1](#).

**Table 3-1** Driver parameters

| Parameter Name                   | Settable VAR?* | Type    | Range                 | Default               | Description                                                                                                      |
|----------------------------------|----------------|---------|-----------------------|-----------------------|------------------------------------------------------------------------------------------------------------------|
| <b>PCIE_SPEC_VER</b>             |                |         |                       |                       |                                                                                                                  |
|                                  | Yes            | Real    | 1.1, 2.0,<br>2.1, 3.0 | PCIE_SPEC_<br>VER_2_1 | See <code>Include/pciesvc_parms.v:</code><br><code>PCIE_SPEC_VER_*</code><br>Note: Please set this in the model. |
| <b>PERCENTAGE_USE_TLP_DIGEST</b> |                |         |                       |                       |                                                                                                                  |
|                                  | Yes            | Integer | 0-100                 | 0                     | Percentage probability of the TD bit being set, indicating that the packet has a TLP digest.                     |
| <b>SET_NO_SNOOP_FIELD</b>        |                |         |                       |                       |                                                                                                                  |
|                                  | Yes            | Integer | 0-1                   | 0                     | Sets the value of the no snoop bit on all outgoing TLPs, when applicable.                                        |

**Table 3-1 Driver parameters (Continued)**

| Parameter Name                      | Settable VAR?* | Type    | Range              | Default | Description                                                                                                                                                                                                                                              |
|-------------------------------------|----------------|---------|--------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SET_IDO_FIELD                       | Yes            | Integer | 0-1                | 0       | Sets the value of the IDO bit in all TLPs, if applicable.                                                                                                                                                                                                |
| SET_RELAXED_ORDERING_FIELD          | Yes            | Integer | 0-1                | 0       | Sets the value of the relaxed ordering bit in all TLPs, if applicable for that TLP type.                                                                                                                                                                 |
| MIN_TIME_TO_NEXT_TRANSACTION        | Yes            | Integer | 0-large value      | 0       | Minimum time between transactions before the driver will transmit another queued request.                                                                                                                                                                |
| MAX_TIME_TO_NEXT_TRANSACTION        | Yes            | Integer | 0-large value      | 0       | Maximum time between transactions in before the driver will transmit another queued request.                                                                                                                                                             |
| DISPLAY_OUTSTANDING_COMMANDS_PERIOD | Yes            | Integer | 10_000-large value | 50_000  | Driver will display all outstanding/pending commands periodically according to this parameter.                                                                                                                                                           |
| READ_CPL_BOUNDARY                   | Yes            | Integer | 64, 128            | 64      | Driver will check that all read completions that do not terminate the transaction have a data payload in bytes that is modulo of this value.                                                                                                             |
| COMPLETION_TIMEOUT_NS               | Yes            | Integer | 10,000-large value | 500_000 | If the request is not completed by the time COMPLETION_TIMEOUT has elapsed, the request has timed out and the driver will issue a warning.                                                                                                               |
| MAX_NUM_TAGS                        | No             | Integer | 1-256              | 32      | Maximum number of tags that can be used. If greater than 32 it is assumed that the extended tag bits are legal to use.                                                                                                                                   |
| DISCARD_COMPLETIONS                 | Yes            | Integer | 0-1                | 0       | When set to a 1, the driver will immediately upon reception of a completion discard the status of completed commands. Completion status cannot be checked in this mode. Users should only set this to 1 if they will not be checking completion results. |

**Table 3-1 Driver parameters (Continued)**

| Parameter Name                       | Settable VAR?* | Type    | Range  | Default           | Description                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------|----------------|---------|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CMB_TABLE_SIZE</b>                |                |         |        |                   |                                                                                                                                                                                                                                                                                                                              |
|                                      | No             | Integer | 16-256 | 256               | Size of the command management block, which is used to track pending and outstanding transactions.                                                                                                                                                                                                                           |
| <b>ENABLE_TX_TLP_REPORTING</b>       |                |         |        |                   |                                                                                                                                                                                                                                                                                                                              |
|                                      | Yes            | Integer | 0-1    | 0                 | If enabled, transmitted TLPs will be reported to the global shadow memory. This should only be turned on if the corresponding LinkLayer parameter is not turned on (or the VIP LinkLayer doesn't exist, as when using the driver to drive a DUT.)<br>Make sure this is not enabled if the shadow memory is not instantiated. |
| <b>ENABLE_SHADOW_MEMORY_CHECKING</b> |                |         |        |                   |                                                                                                                                                                                                                                                                                                                              |
|                                      | Yes            | Integer | 0-1    | 1                 | When set to 1, the returned read transactions are checked against their expected value in the Global Shadow Memory. If the Global Shadow is not being used, this should be set to 0.                                                                                                                                         |
| <b>DISPLAY_NAME</b>                  |                |         |        |                   |                                                                                                                                                                                                                                                                                                                              |
|                                      | No             | String  |        | "pciesvc_drive_r" | Default display name for the driver.                                                                                                                                                                                                                                                                                         |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with "\_VAR". This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

### 3.1.2 Driver User Tasks

The tasks listed in [Table 3-2](#) may be called to generate transactions and check for completion status. Certain bits that are less frequently user or changed must be set using the variables mentioned in the previous section.

Note that data used with the QueueCfgWrite and QueueCfgRead tasks is byte swapped from the received TLP format. All other transaction types are endian neutral and use the same format as contained in the TLP.

**Table 3-2 Driver user tasks**

| Task Name                                                                                                                                  | Arguments                | I/O | Values                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| SetRequesterID                                                                                                                             | req_id(16)               | I   | Requester ID that the driver is supposed to use. This ID is a concatenation of the bus number, device number and function number. |
| QueueMemRead<br><br>Queue a memory read TLP request for transmission.<br>Memory read transactions are non-posted and require a completion. | address(64)              | I   | Destination address.                                                                                                              |
|                                                                                                                                            | length(32)               | I   | Length of the data read request                                                                                                   |
|                                                                                                                                            | first_dw_be(4)           | I   | First data word byte enable                                                                                                       |
|                                                                                                                                            | last_dw_be(4)            | I   | Last data word byte enable                                                                                                        |
|                                                                                                                                            | traffic_class(32)        | I   | Traffic class of the request                                                                                                      |
|                                                                                                                                            | address_translation(2)   | I   | Address translation field. See PCIE base spec for more details.                                                                   |
|                                                                                                                                            | buffer_ptr(32)           | I   | Buffer that the read data should be written to when the transaction is completed.                                                 |
|                                                                                                                                            | buffer_len(32)           | I   | Buffer size in 32bit dwords                                                                                                       |
|                                                                                                                                            | error_injection_code(32) | I   | Error injection code.*                                                                                                            |
|                                                                                                                                            | block(1)                 | I   | Indication on whether or not task will block until a completion is returned.                                                      |
| command_num (32)                                                                                                                           |                          | O   | Unique command number for this transaction.                                                                                       |
| completion_status(32)                                                                                                                      |                          | O   | Completion status of transaction. Valid only if blocking.**                                                                       |

**Table 3-2 Driver user tasks (Continued)**

| <b>Task Name</b>                                                                                                           | <b>Arguments</b>         | <b>I/O</b> | <b>Values</b>                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------|--------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Queue a memory read locked TLP request for transmission. Memory read transactions are non-posted and require a completion. | address(64)              | I          | Address to be read                                                                                                                                                                     |
|                                                                                                                            | length(32)               | I          | Length of the data read request                                                                                                                                                        |
|                                                                                                                            | first_dw_be(4)           | I          | First data word byte enable                                                                                                                                                            |
|                                                                                                                            | last_dw_be(4)            | I          | Last data word byte enable                                                                                                                                                             |
|                                                                                                                            | traffic_class(32)        | I          | Traffic class of the request                                                                                                                                                           |
|                                                                                                                            | address_translation(2)   | I          | Address translation field. See PCIE base spec for more details.                                                                                                                        |
|                                                                                                                            | buffer_ptr(32)           | I          | Buffer that the read data should be written to when the transaction is completed.                                                                                                      |
|                                                                                                                            | buffer_len(32)           | I          | Buffer size in 32bit dwords                                                                                                                                                            |
|                                                                                                                            | error_injection_code(32) | I          | Error injection code.*                                                                                                                                                                 |
|                                                                                                                            | block(1)                 | I          | Indication on whether or not task will block until a completion is returned.                                                                                                           |
| Queue a memory write TLP request for transmission. Memory write transactions are posted and do not require a completion.   | command_num(32)          | O          | Unique command number assigned to this transaction.                                                                                                                                    |
|                                                                                                                            | completion_status(32)    | O          | Completion status of transaction. Valid only if blocking.**                                                                                                                            |
|                                                                                                                            | address(64)              | I          | Memory write destination address.                                                                                                                                                      |
|                                                                                                                            | length(32)               |            | Length field for the transaction.                                                                                                                                                      |
|                                                                                                                            | first_dw_be(4)           | I          | First data word byte enables.                                                                                                                                                          |
|                                                                                                                            | last_dw_be(4)            | I          | Last data word byte enables.                                                                                                                                                           |
|                                                                                                                            | traffic_class(32)        | I          | Traffic class of the request.                                                                                                                                                          |
|                                                                                                                            | address_translation(2)   | I          | Address translation field. See PCIE base spec for more details.                                                                                                                        |
|                                                                                                                            | ep(1)                    | I          | A '1' sets the error poison bit.                                                                                                                                                       |
|                                                                                                                            | buffer_ptr(32)           | I          | Pointer to the data to be written                                                                                                                                                      |
|                                                                                                                            | buffer_len(32)           | I          | Buffer size in 32 bit dwords                                                                                                                                                           |
|                                                                                                                            | error_injection_code(32) | I          | Error injection code.*                                                                                                                                                                 |
|                                                                                                                            | block(1)                 | I          | Indication on whether or not task will block until transaction is complete. For posted commands such as MemWrite the command is considered complete as soon as the driver has sent it. |
|                                                                                                                            | command_num(32)          | O          | Unique command number assigned to this transaction.                                                                                                                                    |
|                                                                                                                            | completion_status(32)    | O          | Completion status of the transaction. Valid only if blocking.**                                                                                                                        |

**Table 3-2 Driver user tasks (Continued)**

| <b>Task Name</b>                                                                                                                  | <b>Arguments</b>         | <b>I/O</b> | <b>Values</b>                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------|------------------------------------------------------------------------------|
| QueueIORRead<br><br>Queue an I/O read TLP request for transmission.<br>I/O transactions are non-posted and require a completion.  | io_address(32)           | I          | Destination address.                                                         |
|                                                                                                                                   | first_dw_be(4)           | I          | First data word byte enable                                                  |
|                                                                                                                                   | buffer_ptr(32)           | I          | Pointer to the data to be written.                                           |
|                                                                                                                                   | buffer_len(32)           | I          | Buffer size in 32 bit dwords                                                 |
|                                                                                                                                   | error_injection_code(32) | I          | Error injection code.*                                                       |
|                                                                                                                                   | block(1)                 | I          | Indication on whether or not task will block until a completion is returned. |
|                                                                                                                                   | command_num(32)          | O          | Unique command number assigned to this transaction.                          |
| QueueIOWrite<br><br>Queue an I/O write TLP request for transmission.<br>I/O transactions are non-posted and require a completion. | io_address(32)           | I          | Destination address.                                                         |
|                                                                                                                                   | data(32)                 | I          | Dword of data to be written                                                  |
|                                                                                                                                   | first_dw_be(4)           | I          | First data word byte enable                                                  |
|                                                                                                                                   | ep(1)                    | I          | Sets the EP bit in the TLP indicating that the data is poisoned.             |
|                                                                                                                                   | error_injection_code(32) | I          | Error injection code.*                                                       |
|                                                                                                                                   | block(1)                 | I          | Indication on whether or not task will block until a completion is returned. |
|                                                                                                                                   | command_num(32)          | O          | Unique command number assigned to this transaction.                          |
|                                                                                                                                   | completion_status(32)    | O          | Completion status of transaction. Only valid if blocking.**                  |

**Table 3-2 Driver user tasks (Continued)**

| Task Name                                                                                                                                                                                                                                                                                                                                                                                           | Arguments                | I/O | Values                                                                                                                                                                                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QueueCfgRead<br><br>Queue a type 0 or type 1 config read request, based on the config_type argument, for transmission. Configuration requests are non-posted and require a completion.<br><br>Data used with the QueueCfgRead task is byte swapped from the received TLP format. This is done for the ease of use by the customer since by definition PCIE Configuration Space is little endian.    | cfg_address(16)          | I   | Destination address to send the Config read to. Note that configuration requests route by ID. Also known as {Bus, Device, Function Number}.                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                     | register_number(10)      | I   | Configuration reg number to be read. The lower 6 bits are the register number and the upper 4 bits are the extended register number.                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                     | first_dw_be(4)           | I   | First data word byte enable                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                     | config_type(1)           | I   | 0 means type 0 read and 1 means type 1 read.                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                     | buffer_ptr(32)           | I   | Pointer to the data to be written. Note the data returned will be in little endian format like the configuration space (i.e. byte swapped from the TLP ordering)                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                     | buffer_len(32)           | I   | Buffer size in 32 bit dwords                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                     | error_injection_code(32) | I   | Error injection code.*                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                     | block(1)                 | I   | Indication on whether or not task will block until a completion is returned.                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                     | command_num(32)          | O   | Unique command number assigned to this transaction.                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                     | completion_status(32)    | O   | Completion status of transaction. Only valid if blocking.**                                                                                                                                          |
| QueueCfgWrite<br><br>Queue a type 0 or type 1 config write request, based on the config_type argument, for transmission. Configuration requests are non-posted and require a completion.<br><br>Data used with the QueueCfgWrite task is byte swapped from the received TLP format. This is done for the ease of use by the customer since by definition PCIE Configuration Space is little endian. | cfg_address(16)          | I   | Destination address to be written to. Note that configuration requests route by ID. This address will be captured as the Completer ID in the endpoint. Also known as {Bus, Device, Function Number}. |
|                                                                                                                                                                                                                                                                                                                                                                                                     | register_number(10)      | I   | Configuration register number to be read. The lower 6 bits are the register number and the upper 4 bits are the extended register number.                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                     | first_dw_be(4)           | I   | First data word byte enable                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                     | config_type(1)           | I   | 0 means type 0 config write. 1 means type 1 config write.                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                     | ep(1)                    | I   | Error poison bit. Indication that the data in the payload is corrupt.                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                     | write_data(32)           | I   | Dword of data to be written in little Endian format (same as configuration space, and byte swapped from TLP ordering)                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                     | error_injection_code(32) | I   | Error injection code for this transaction.*                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                                                                     | block(1)                 | I   | Indication on whether or not task will block until a completion is returned.                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                     | command_num(32)          | O   | Unique command number assigned to this transaction.                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                     | completion_status(32)    | O   | Completion status of transaction. Only valid if blocking.**                                                                                                                                          |

**Table 3-2 Driver user tasks (Continued)**

| <b>Task Name</b>                                                                                                                                                                                                            | <b>Arguments</b>         | <b>I/O</b> | <b>Values</b>                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QueueMsg<br><br>Queue a Msg TLP if no payload is present or a MsgD command if a payload is present. Message requests are posted and do not require a completion.<br>See example below.<br><br>See example after this table. | vendor_fields(64)        | I          | Bytes 8-12 of the TLP header are for a vendor defined message. This should be set to 0 if a message other than a vendor defined message is being sent.                            |
|                                                                                                                                                                                                                             | traffic_class(32)        | I          | Traffic class of message to be sent.                                                                                                                                              |
|                                                                                                                                                                                                                             | message_code(8)          | I          | Message code to be sent.                                                                                                                                                          |
|                                                                                                                                                                                                                             | routing_type(3)          | I          | Message routing type.                                                                                                                                                             |
|                                                                                                                                                                                                                             | ep(1)                    | I          | Indication that data payload is corrupt. Should always be 0 unless the message contains a payload.                                                                                |
|                                                                                                                                                                                                                             | buffer_ptr(32)           | I          | Pointer to message payload, if any. Otherwise this field is reserved and should be set to 0.                                                                                      |
|                                                                                                                                                                                                                             | buffer_length(32)        | I          | Length of the data payload in dwords. Payloads should be present only for vendor defined messages. Length must be set to 0 if no payload is present.                              |
|                                                                                                                                                                                                                             | error_injection_code(32) | I          | Error injection code for this TLP.*                                                                                                                                               |
|                                                                                                                                                                                                                             | block(1)                 | I          | Indication on whether or not task will block until transaction is complete. For posted requests such as this one, the transaction is complete once the driver has transmitted it. |
|                                                                                                                                                                                                                             | command_num(32)          | O          | Unique command number assigned to this transaction.                                                                                                                               |
|                                                                                                                                                                                                                             | completion_status(32)    | O          | Status of the command request.**                                                                                                                                                  |

**Table 3-2 Driver user tasks (Continued)**

| Task Name                                                                                                                      | Arguments                | I/O | Values                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----|------------------------------------------------------------------------------|
| Queue a FetchAdd Atomic Operation TLP request for transmission. FetchAdd transactions are non-posted and require a completion. | address(64)              | I   | Destination address.                                                         |
|                                                                                                                                | length(32)               | I   | Length of the data read request                                              |
|                                                                                                                                | first_dw_be(4)           | I   | First data word byte enable                                                  |
|                                                                                                                                | last_dw_be(4)            | I   | Last data word byte enable                                                   |
|                                                                                                                                | traffic_class(32)        | I   | Traffic class of the request                                                 |
|                                                                                                                                | address_translation(2)   | I   | Address translation field. See PCIE base spec for more details.              |
|                                                                                                                                | ep(1)                    | I   | Error poison bit. Indication that the data in the payload is corrupt.        |
|                                                                                                                                | data_in_buffer_ptr(32)   | I   | Buffer that stores the completion data coming in.                            |
|                                                                                                                                | data_in_buffer_len(32)   | I   | Buffer size in 32bit dwords                                                  |
|                                                                                                                                | data_out_buffer_ptr(32)  | I   | Buffer that stores the outgoing data payload                                 |
|                                                                                                                                | data_out_buffer_len(32)  |     | Buffer size in 32bit dwords                                                  |
|                                                                                                                                | error_injection_code(32) | I   | Error injection code*                                                        |
|                                                                                                                                | block(1)                 | I   | Indication on whether or not task will block until a completion is returned. |
|                                                                                                                                | command_num (32)         | O   | Unique command number for this transaction.                                  |
|                                                                                                                                | completion_status(32)    | O   | Completion status of transaction. Valid only if blocking.**                  |

**Table 3-2 Driver user tasks (Continued)**

| <b>Task Name</b>                                                                                                                        | <b>Arguments</b>         | <b>I/O</b> | <b>Values</b>                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------|------------------------------------------------------------------------------|
| QueueSwap<br><br>Queue a Swap Atomic Operation TLP request for transmission. Swap transactions are non-posted and require a completion. | address(64)              | I          | Destination address.                                                         |
|                                                                                                                                         | length(32)               | I          | Length of the data read request                                              |
|                                                                                                                                         | first_dw_be(4)           | I          | First data word byte enable                                                  |
|                                                                                                                                         | last_dw_be(4)            | I          | Last data word byte enable                                                   |
|                                                                                                                                         | traffic_class(32)        | I          | Traffic class of the request                                                 |
|                                                                                                                                         | address_translation(2)   | I          | Address translation field. See PCIE base spec for more details.              |
|                                                                                                                                         | ep(1)                    | I          | Error poison bit. Indication that the data in the payload is corrupt.        |
|                                                                                                                                         | data_in_buffer_ptr(32)   | I          | Buffer that stores the completion data coming in.                            |
|                                                                                                                                         | data_in_buffer_len(32)   | I          | Buffer size in 32bit dwords                                                  |
|                                                                                                                                         | data_out_buffer_ptr(32)  | I          | Buffer that stores the outgoing data payload                                 |
|                                                                                                                                         | data_out_buffer_len(32)  | I          | Buffer size in 32bit dwords                                                  |
|                                                                                                                                         | error_injection_code(32) | I          | Error injection code*                                                        |
|                                                                                                                                         | block(1)                 | I          | Indication on whether or not task will block until a completion is returned. |
|                                                                                                                                         | command_num (32)         | O          | Unique command number for this transaction.                                  |
|                                                                                                                                         | completion_status(32)    | O          | Completion status of transaction. Valid only if blocking.**                  |

**Table 3-2 Driver user tasks (Continued)**

| Task Name                                                                                                                                                                                                                                                                                                                                              | Arguments                   | I/O | Values                                                                                                                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----|-----------------------------------------------------------------------------------------------------------------------|
| QueueCAS<br><br>Queue a CAS (compare and swap) Atomic Operation TLP request for transmission. CAS transactions are non-posted and require a completion.                                                                                                                                                                                                | address(64)                 | I   | Destination address.                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                        | length(32)                  | I   | Length of the data read request                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                        | first_dw_be(4)              | I   | First data word byte enable                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                        | last_dw_be(4)               | I   | Last data word byte enable                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                        | traffic_class(32)           | I   | Traffic class of the request                                                                                          |
|                                                                                                                                                                                                                                                                                                                                                        | address_translation(2)      | I   | Address translation field. See PCIE base spec for more details.                                                       |
|                                                                                                                                                                                                                                                                                                                                                        | ep(1)                       | I   | Error poison bit. Indication that the data in the payload is corrupt.                                                 |
|                                                                                                                                                                                                                                                                                                                                                        | data_in_buffer_ptr(32)      | I   | Buffer that stores the completion data coming in.                                                                     |
|                                                                                                                                                                                                                                                                                                                                                        | data_in_buffer_len(32)      | I   | Buffer size in 32bit dwords                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                        | data_out_buffer_ptr(32)     | I   | Buffer that stores the outgoing data payload                                                                          |
|                                                                                                                                                                                                                                                                                                                                                        | data_out_buffer_len(32)     |     | Buffer size in 32bit dwords                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                        | error_injection_code(32)    | I   | Error injection code*                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                        | block(1)                    | I   | Indication on whether or not task will block until a completion is returned.                                          |
| IsTransactionComplete<br><br>Checks if the transaction specified by request_id is complete. When this task returns a positive status, the result of the command is purged from driver memory. Any repeat calls to this task with the same command number will return a status of unknown because the command result is no longer in the driver memory. | command_num(32)             | I   | Unique command number assigned to this transaction.                                                                   |
|                                                                                                                                                                                                                                                                                                                                                        | completion_status(32)       | O   | Status of the transaction. Valid only if the command is complete.**                                                   |
|                                                                                                                                                                                                                                                                                                                                                        | result(1)                   | O   | If 1 then the command is complete. If 0 then the command has not yet completed.                                       |
| AddTLPPrefix<br><br>Adds the prefix or prefixes contained in prefix_array to the next queued command.                                                                                                                                                                                                                                                  | logic [31:0] prefix_array[] | I   | A dynamic array containing the prefixes to be added. It is up to the user to build and set the contents of the array. |

**Table 3-2 Driver user tasks (Continued)**

| Task Name                                                                                                                                                                 | Arguments             | I/O | Values                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----|-------------------------------------------------------------------------|
| WaitForCompletion<br><br>Blocks until the transaction specified by request_id has completed. The completion status is purged from driver memory after this task finished. | command_num(32)       | I   | Unique command number assigned to this transaction.                     |
|                                                                                                                                                                           | completion_status(32) | O   | Final completion status.**                                              |
| WaitUntilDriverIdle<br><br>Blocking task that finishes when all outstanding requests have been completed and there are no queued requests waiting to go out.              | n/a                   | n/a |                                                                         |
| SetUseOrderedTags                                                                                                                                                         | enabled (1)           | I   | When enabled is set, the driver will issue tags in the numerical order. |

\* -These parameters for this field start with TX\_TLP\_EI\_\* and are defined in Verilog/Include/pciesvc\_parms.v. The error\_injection\_code field here is intended to be used for directed tests. For random error injection it is recommended to utilize the facilities defined in the Data Link Layer.

\*\*- The parameters for completion\_status start with TLP\_CPL\_STATUS\_\* and can be found in Verilog/Include/pciesvc\_tlp\_parms.v.

Delaying the transmission of Active State NAK is up to the testcase as this particular NAK is a TLP. The testcase will wait for the DL event, event\_send\_pm\_active\_state\_nak. The testcase can then wait as long as desired before sending NAK via:

```
<vip_path>.root0.driver0.QueueMsg( 0, // vendor_fields,
                                    0, // tc,
                                    TLP_MSG_CODE_PM_ACTIVE_STATE_NAK, // msg_code
                                    TLP_MSG_RT_TYPE_LOCAL_TERM_RCVR, // routing_type,
                                    0, //error_poison,
                                    msg_tx_buffer_ptr,
                                    msg_tx_buffer_len,
                                    0, // tx_ei_code,
                                    0,
                                    msg_command_num,
                                    msg_tx_driver_status);
```

This event is triggered if a PM\_AS\_Req\_L1 DLLP is received and ENABLE\_ASPM\_L1\_ENTRY\_VAR == 0.

### 3.1.3 Driver Memory Management Requirements

Most of the QueueXYZ driver tasks require the user to supply some sort of memory buffer. The driver will not deallocate these memory buffers since they were allocated externally. The type of command will determine when a user may deallocate or reuse a buffer that was passed to the driver.

Posted commands such as config writes and memory write do not require the memory buffer at all after the QueueXYZ command has been called. Thus if QueueMemWrite() was called 10 times consecutively, a user could simply use the same memory pointer and change the data for each call.

A memory pointer used for non-posted commands must not be deallocated until the command has completed or timed out. There are several ways to find out if a command is complete:

- ❖ Use the blocking argument when queuing the command
- ❖ Call WaitForCompletion() to wait until a specific command has completed
- ❖ Call IsTransactionComplete() to find out if a queued command has completed.
- ❖ Call WaitUntilDriverIdle to wait until all commands have completed.

Once the command is complete, the memory buffer may if desired be read for completion data and then should be deallocated.

Failure to deallocate unused memory may result in the simulation crashing due to a lack of VIP memory in test cases with a large number of transactions.

### 3.1.4 Driver Events

#### 3.1.4.1 event\_transaction\_completed

This event will trigger after a transaction has been completed by receiving successful completion status with the byte count for the transaction exhausted, a completion status of unsupported request, completer abort or completion retry status, or if a command times out .

## 3.2 Request Initiator Application

The Requester application generates PCIE Read/Write transactions to a target. Memory addresses are chosen at random (constrained by min/max parameters) and have varying lengths (again, constrained by min/max parameters.)

### 3.2.1 Requester Parameters

Requester parameters are listed in [Table 3-3](#).

**Table 3-3 Requester parameters**

| Parameter Name        | Settable VAR?* | Type    | Range         | Default | Description                                             |
|-----------------------|----------------|---------|---------------|---------|---------------------------------------------------------|
| NUM_MEM_WRITE         |                |         |               |         |                                                         |
|                       | Yes            | Integer | 0-large value | 20      | Number of memory write transactions to send.            |
| NUM_MEM_READ          |                |         |               |         |                                                         |
|                       | Yes            | Integer | 0-large value | 20      | Number of memory read transactions to send.             |
| MIN_DATA_LEN_IN_BYTES |                |         |               |         |                                                         |
|                       | Yes            | Integer | 1-4096        | 1 bytes | Minimum/maximum data length of write and read requests. |
| MAX_DATA_LEN_IN_BYTES |                |         |               |         |                                                         |

**Table 3-3 Requester parameters (Continued)**

| <b>Parameter Name</b>              | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>                                    | <b>Default</b>           | <b>Description</b>                                                                                                                                                       |
|------------------------------------|-----------------------|-------------|-------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                    | Yes                   | Integer     | 0-4096                                          | 128 bytes                |                                                                                                                                                                          |
| <b>BANDWIDTH_MODE</b>              |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | BANDWIDTH_MODE_RPS,<br>BANDWIDTH_MODE_REQ_DELAY | BANDWIDTH_MODE_REQ_DELAY | Set the mechanism used to meter out the transactions. The modes available are REQ_DELAY (with a specified time between packets) and RPS (specified requests-per-second.) |
| <b>MIN_TIME_BETWEEN_PACKETS_NS</b> |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-large value                                   | 1 ns                     | Minimum/maximum delay between each transmitted packet. After each packet transmission, this value is randomized.                                                         |
| <b>MAX_TIME_BETWEEN_PACKETS_NS</b> |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-large value                                   | 10_000 ns                |                                                                                                                                                                          |
| <b>MIN_TLP_TRAFFIC_CLASS</b>       |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-7                                             | 0                        | Minimum randomized TC value in transmitted TLPs.                                                                                                                         |
| <b>MAX_TLP_TRAFFIC_CLASS</b>       |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-7                                             | 0                        | Maximum randomized TC value in transmitted TLPs.                                                                                                                         |
| <b>DEFAULT_REQUESTER_ID</b>        |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-2^16                                          | INVALID_REQUESTER_ID     | Default requester-ID, if no configuration requests have been seen yet. User must explicitly set this.                                                                    |
| <b>PERCENTAGE_USE_TLP_DIGEST</b>   |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-100                                           | 50                       | Percentage probability of the TD bit being set in a completion, indicating that the packet has a TLP digest.                                                             |
| <b>MAX_NUM_TAGS</b>                |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | No                    | Integer     | 1-256                                           | 32                       | Maximum number of outstanding tags. Note that this must be smaller than the command management block table size (see CMB_TABLE_SIZE parameter below.)                    |
| <b>NUM_MEM_ADDR_SEGMENTS</b>       |                       |             |                                                 |                          |                                                                                                                                                                          |
|                                    | No                    | Integer     | 16-4096                                         | 10                       | Number of unique randomization segments – each of which is a min/max memory address range.                                                                               |

**Table 3-3 Requester parameters (Continued)**

| Parameter Name                       | Settable VAR?* | Type    | Range  | Default           | Description                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------|----------------|---------|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DISCARD_COMPLETIONS</b>           |                |         |        |                   |                                                                                                                                                                                                                                                                                                                                            |
|                                      | Yes            | Integer | 0-1    | 0                 | When set to a 1, the driver will automatically discard the status of completed commands. Users should only set this parameter to a 1 if they will not be checking completion results. This parameter does not automatically deallocate buffer memories that contain data payloads. It only affects how the driver saves completion status. |
| <b>CMB_TABLE_SIZE</b>                |                |         |        |                   |                                                                                                                                                                                                                                                                                                                                            |
|                                      | No             | Integer | 16-256 | 64 entries        | Size of the command management block table, which is used to track pending and outstanding transactions.                                                                                                                                                                                                                                   |
| <b>ENABLE_TX_TLP_REPORTING</b>       |                |         |        |                   |                                                                                                                                                                                                                                                                                                                                            |
|                                      | Yes            | Integer | 0-1    | 0                 | If enabled, transmitted TLPs will be reported to the global shadow memory. This should only be turned on if the corresponding LinkLayer parameter is not turned on (or the VIP LinkLayer doesn't exist, as when using the requester to drive a DUT.)<br>Make sure this is not enabled if the shadow memory is not instantiated.            |
| <b>ENABLE_SHADOW_MEMORY_CHECKING</b> |                |         |        |                   |                                                                                                                                                                                                                                                                                                                                            |
|                                      | Yes            | Integer | 0-1    | 1                 | When set to 1, the returned read transactions are checked against their expected value in the Global Shadow Memory. If the Global Shadow is not being used, this should be set to 0.                                                                                                                                                       |
| <b>DISPLAY_NAME</b>                  |                |         |        |                   |                                                                                                                                                                                                                                                                                                                                            |
|                                      | No             | String  |        | pciesvc_requester | Default prefix in \$msglog calls.                                                                                                                                                                                                                                                                                                          |
| <b>BANDWIDTH_REQUESTS_PER_SECOND</b> |                |         |        |                   |                                                                                                                                                                                                                                                                                                                                            |

**Table 3-3 Requester parameters (Continued)**

| Parameter Name                       | Settable VAR?* | Type    | Range | Default   | Description                                                                                                                                                                            |
|--------------------------------------|----------------|---------|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      | Yes            | Integer |       | 100,000   | The variable is applicable when bandwidth_mode is set to BANDWIDTH_MODE_REQUESTS_PER_SEC. The value of this variable specifies number of requests to be generated per second.          |
| <b>DISPLAY_CURRENT_STATUS_PERIOD</b> |                |         |       |           |                                                                                                                                                                                        |
|                                      | Yes            | Integer |       | 100,000   | The display_current_status_period variable represents the frequency in terms of time units after which the Requester application will display its current status periodically.         |
| <b>DISPLAY_TLP_BEGINNING_DWORDs</b>  |                |         |       |           |                                                                                                                                                                                        |
|                                      | Yes            | Integer |       | 8         | Enables to display TLP beginning DWORDs. )                                                                                                                                             |
| <b>DISPLAY_TLP_ENDING_DWORDs</b>     |                |         |       |           |                                                                                                                                                                                        |
|                                      | Yes            | Integer |       | 4         | Enables to display TLP ending DWORDs                                                                                                                                                   |
| <b>MAX_MRD_TIMEOUT_RETRY_COUNT</b>   |                |         |       |           |                                                                                                                                                                                        |
|                                      | Yes            | Integer |       | 1         | The max_mrd_timeout_retry_count variable represents the maximum number of times a Memory Read request is retried before a request is determined as a failure by Requester application. |
| <b>COMPLETION_TIMEOUT_NS</b>         |                |         |       |           |                                                                                                                                                                                        |
|                                      | Yes            | Integer |       | 1_000_000 | Completion timeout in NS .                                                                                                                                                             |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “\_VAR”. This is useful if using higher-level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

### 3.2.2 Requester User Tasks

The tasks listed in [Table 3-4](#) may be called to generate transactions and check for completion status. Certain bits that are less frequently user or changed must be set using the variables mentioned in the previous section.

**Table 3-4 Requester user tasks**

| <b>Task Name</b>                                                                                                                                                                                                    | <b>Arguments (length)</b> | <b>I/O</b> | <b>Values</b>                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------|
| SetRequesterId                                                                                                                                                                                                      | req_id (16)               | I          | Requester ID that the requester shall use. This ID is a concatenation of the bus number, device number and function number. |
| AddMemRange<br><br>Adds a min/max memory address range to specify the requester-generated addresses. This task can be called additional times to add multiple ranges.                                               | min_addr (64)             | I          | Minimum address to generate.                                                                                                |
|                                                                                                                                                                                                                     | max_addr (64)             | I          | Maximum address to generate.                                                                                                |
|                                                                                                                                                                                                                     | status (32)               | O          | Non-zero if AddMemRange failed.                                                                                             |
| RemoveMemRange<br><br>Removes a min/max memory address range created with above AddMemRange() task. This task must be called with identical min/max memory addresses as the corresponding range you want to delete. | min_addr (64)             | I          | Minimum address of range to delete.                                                                                         |
|                                                                                                                                                                                                                     | max_addr (64)             | I          | Maximum address of range to delete.                                                                                         |
|                                                                                                                                                                                                                     | status (32)               | O          | Non-zero if RemoveMemRange failed.                                                                                          |
| DisplayMemRangeList                                                                                                                                                                                                 | n/a                       | n/a        |                                                                                                                             |
| Displays a list of all the memory address ranges added with AddMemRange() task, above.                                                                                                                              |                           |            |                                                                                                                             |
| StartApp                                                                                                                                                                                                            | n/a                       | n/a        |                                                                                                                             |
| Start the Requester application.                                                                                                                                                                                    |                           |            |                                                                                                                             |
| IsAppFinished                                                                                                                                                                                                       | is_finished (1)           | O          | Set when the requester has completed.                                                                                       |
| Call to determine if the Requester Application has completed yet.                                                                                                                                                   |                           |            |                                                                                                                             |
| WaitUntilFinished                                                                                                                                                                                                   | n/a                       | n/a        |                                                                                                                             |
| Blocking task to await completion of the Requester Application.                                                                                                                                                     |                           |            |                                                                                                                             |
| ClearStats                                                                                                                                                                                                          | n/a                       | n/a        |                                                                                                                             |
| Clears internal statistics registers                                                                                                                                                                                |                           |            |                                                                                                                             |
| DisplayStats                                                                                                                                                                                                        | n/a                       | n/a        |                                                                                                                             |
| Displays the internal statistics registers.                                                                                                                                                                         |                           |            |                                                                                                                             |

### 3.2.3 Requester Statistics

The statistics listed in [Table 3-5](#) are maintained by the Requester:

**Table 3-5 Requested statistics**

| Stat Name                      | Width | Description                                  |
|--------------------------------|-------|----------------------------------------------|
| stat_num_tlp_sent              | 32    | Number of TLPs sent by the requester         |
| stat_num_tlp_received          | 32    | Number of TLPs received by the requester     |
| stat_num_req_sent              | 32    | Number of requests sent                      |
| stat_num_bytes_sent            | 32    | Number of total bytes sent                   |
| stat_num_data_bytes_sent       | 32    | Number of data bytes sent                    |
| stat_num_mem_req_sent          | 32    | Number of memory requests sent               |
| stat_num_mem_write_req_sent    | 32    | Number of memory write requests sent         |
| stat_num_mem_read_req_sent     | 32    | Number of memory read requests sent          |
| stat_num_mem_read_xn_completed | 32    | Number of memory read transactions completed |
| stat_num_mem_cpl_received      | 32    | Number of memory completions received        |
| stat_num_bytes_received        | 32    | Number of total bytes received               |
| stat_num_data_bytes_received   | 32    | Number of data bytes received                |

## 3.3 Completion Target Application

The Completion Target is a module that provides the completer services of a PCI Express completer that will respond to various inbound requests. Read transactions are optionally broken up into multiple completions, potentially interleaved with other read completions.

### 3.3.1 Completion Target Parameters

Completion target parameters are listed in [Table 3-6](#).

**Table 3-6 Completion target parameters**

| Parameter Name                         | Settable VAR?* | Type    | Range                 | Default               | Description                                                                                                                                                                 |
|----------------------------------------|----------------|---------|-----------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PCIE_SPEC_VER</b>                   |                |         |                       |                       |                                                                                                                                                                             |
|                                        | Yes            | Real    | 1.1, 2.0,<br>2.1, 3.0 | PCIE_SPEC_V<br>ER_2_1 | See Include/pciesvc_parms.v:<br>PCIE_SPEC_VER_*<br>Note: Please set this in the model.                                                                                      |
| <b>DEFAULT_COMPLETER_ID</b>            |                |         |                       |                       |                                                                                                                                                                             |
|                                        | Yes            | Integer | 0-2 <sup>16</sup>     | 16'h0100              | Default completer-ID, if no configuration requests have been seen yet. Note that this may be overridden both by received CfgWr requests as well as the SetCompleterID task. |
| <b>MIN_READ_CPL_DATA_SIZE_IN_BYTES</b> |                |         |                       |                       |                                                                                                                                                                             |

**Table 3-6 Completion target parameters (Continued)**

| <b>Parameter Name</b>                  | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>      | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------|-----------------------|-------------|-------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                        | Yes                   | Integer     | 0-4096            | 1 byte         | Randomized [min-max] at every completion. Any read request larger than this (taking into account the Read Completion Boundary) will be broken up into multiple read completions. values need to be greater than 1 RCB and will be rounded down to the nearest RCB. Note that regardless of the setting of MIN/MAX_READ_CPL_DATA_SIZE, it will follow PCIe completion rules and round to a read completion boundary.” |
| <b>MAX_READ_CPL_DATA_SIZE_IN_BYTES</b> |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                        | Yes                   | Integer     | 0-4096            | 128 bytes      | Randomized [min-max] at every completion. Any read request larger than this (taking into account the Read Completion Boundary) will be broken up into multiple read completions. values need to be greater than 1 RCB and will be rounded down to the nearest RCB. Note that regardless of the setting of MIN/MAX_READ_CPL_DATA_SIZE, it will follow PCIe completion rules and round to a read completion boundary.” |
| <b>READ_CPL_BOUNDARY</b>               |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                        | Yes                   | Integer     | 64, 128           | 64 bytes       | Memory completions (except potentially first and/or last completion) will align to this boundary.                                                                                                                                                                                                                                                                                                                    |
| <b>MAX_PAYLOAD_SIZE_IN_BYTES</b>       |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                        | Yes                   | Integer     | $2^x$<br>$x=7-12$ | 128 bytes      | The TLP payload cannot exceed this value.                                                                                                                                                                                                                                                                                                                                                                            |
| <b>MIN_MEM_CPL_LATENCY_NS</b>          |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                        | Yes                   | Integer     | 0-large value     | 0 ns           | Min/Max latency for memory transaction completions (in nanoseconds.) Note that each of multiple completions will have their own independent delays.                                                                                                                                                                                                                                                                  |
| <b>MAX_MEM_CPL_LATENCY_NS</b>          |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                        | Yes                   | Integer     | 0-large value     | 0 ns           |                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>MIN_CFG_CPL_LATENCY_NS</b>          |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                        | Yes                   | Integer     | 0-large value     | 0 ns           | Min/Max latency for configuration transaction completions (in nanoseconds.)                                                                                                                                                                                                                                                                                                                                          |
| <b>MAX_CFG_CPL_LATENCY_NS</b>          |                       |             |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                      |

**Table 3-6 Completion target parameters (Continued)**

| <b>Parameter Name</b>         | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>  | <b>Default</b> | <b>Description</b>                                                    |
|-------------------------------|-----------------------|-------------|---------------|----------------|-----------------------------------------------------------------------|
|                               | Yes                   | Integer     | 0-large value | 0 ns           |                                                                       |
| <b>MIN_IO_CPL_LATENCY_NS</b>  |                       |             |               |                |                                                                       |
|                               | Yes                   | Integer     | 0-large value | 0 ns           | Min/Max latency for I/O transaction completions (in nanoseconds.)     |
| <b>MAX_IO_CPL_LATENCY_NS</b>  |                       |             |               |                |                                                                       |
|                               | Yes                   | Integer     | 0-large value | 0 ns           |                                                                       |
| <b>MIN_MSG_CPL_LATENCY_NS</b> |                       |             |               |                |                                                                       |
|                               | Yes                   | Integer     | 0-large value | 0 ns           | Min/Max latency for message transaction completions (in nanoseconds.) |
| <b>MAX_MSG_CPL_LATENCY_NS</b> |                       |             |               |                |                                                                       |
|                               | Yes                   | Integer     | 0-large value | 0 ns           |                                                                       |

**Table 3-6 Completion target parameters (Continued)**

| Parameter Name                          | Settable VAR?* | Type    | Range | Default | Description                                                                                                                                                                                                                                       |
|-----------------------------------------|----------------|---------|-------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PERCENTAGE_USE_TLP_DIGEST</b>        |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer | 0-100 | 50      | Percentage probability of the TD bit being set in a completion, indicating that the packet has a TLP digest.                                                                                                                                      |
| <b>PERCENTAGE_CORRUPT_TLP_DIGEST</b>    |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer |       | 0       | Percentage of outbound transactions with a TLP digest (ECRC), that have a corrupt TLP digest (ECRC).<br><br>Expected Response: DUT should drop the TLP and verification of the generation and transmission of the ERR_MSG is left up to the user. |
| <b>ALLOW_VENDOR_PREFIX_L0</b>           |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer |       | 0       | When set to zero the app will flag any local vendor prefix 0 that is received and treat the underlying TLP as malformed. When set to a nonzero value the target app will not flag the prefix and process the underlying TLP normally.             |
| <b>ALLOW_VENDOR_PREFIX_L1</b>           |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer |       | 0       | When set to zero the app will flag any local vendor prefix 1 that is received and treat the underlying TLP as malformed. When set to a nonzero value the target app will not flag the prefix and process the underlying TLP normally.             |
| <b>ALLOW_VENDOR_PREFIX_E0</b>           |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer |       | 0       | When set to zero the app will flag any end-end vendor prefix 0 that is received treat the underlying TLP as malformed. When set to a nonzero value the target app will not flag the prefix and process the underlying TLP normally.               |
| <b>ALLOW_VENDOR_PREFIX_E1</b>           |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer |       | 0       | When set to zero the app will flag any end-end vendor prefix 1 that is received and treat the underlying TLP as malformed. When set to a nonzero value the target app will not flag the prefix and process the underlying TLP normally.           |
| <b>MAX_NUM_END_END_PREFIX_SUPPORTED</b> |                |         |       |         |                                                                                                                                                                                                                                                   |
|                                         | Yes            | Integer |       | 4       | If the target app receives a TLP with more than this number of end-end TLP prefixes, the TLP will be treated as an unsupported.request.                                                                                                           |

**Table 3-6 Completion target parameters (Continued)**

| Parameter Name                          | Settable VAR?*  | Type          | Range           | Default          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |         |           |   |           |              |             |             |         |                 |         |                 |
|-----------------------------------------|-----------------|---------------|-----------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-----------|---|-----------|--------------|-------------|-------------|---------|-----------------|---------|-----------------|
| <b>MEM_WRITE_NOTIFICATION_MODE</b>      |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | Yes             | Integer       | 0-1             | 0                | When set, any received memory writes are saved in an internal queue for later examination.                                                                                                                                                                                                                                                                                                                                                                                                                     |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>UNINITIALIZED_MEM_READ_MODE</b>      |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | Yes             | Integer       | See Description | MODE_BAAD        | <p>Controls the returned data from a read of uninitialized memory. There are four different modes (all prefixed by UNINITIALIZED_MEM_READ_MODE_):</p> <table> <thead> <tr> <th>Mode</th> <th>Returns</th> </tr> </thead> <tbody> <tr> <td>MODE_ZERO</td> <td>0</td> </tr> <tr> <td>MODE_BAAD</td> <td>32'hbaadbaad</td> </tr> <tr> <td>MODE_RANDOM</td> <td>Random data</td> </tr> <tr> <td>MODE_CA</td> <td>Completer Abort</td> </tr> <tr> <td>MODE_UR</td> <td>Unsupported Req</td> </tr> </tbody> </table> | Mode | Returns | MODE_ZERO | 0 | MODE_BAAD | 32'hbaadbaad | MODE_RANDOM | Random data | MODE_CA | Completer Abort | MODE_UR | Unsupported Req |
| Mode                                    | Returns         |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
| MODE_ZERO                               | 0               |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
| MODE_BAAD                               | 32'hbaadbaad    |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
| MODE_RANDOM                             | Random data     |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
| MODE_CA                                 | Completer Abort |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
| MODE_UR                                 | Unsupported Req |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>FLAG_UNINITIALIZED_MEM_READ</b>      |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | Yes             | Integer       | 0-1             | 1                | When set, all reads to uninitialized memory will be flagged with a message. When clear, no message will come out. This does not affect the return status of the read; however, it is controlled by the above UNINITIALIZED_MEM_READ_MODE parameter.                                                                                                                                                                                                                                                            |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>MEM_WRITE_NOTIFICATION_FIFO_SIZE</b> |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | No              | Integer       | 16-4096         | 64 entries       | Number of queued memory-write notifications that can be queued up.                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>CMB_TABLE_SIZE</b>                   |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | No              | Integer       | 16-256          | 64 entries       | Size of the command management block table, which is used to track pending and outstanding transactions.                                                                                                                                                                                                                                                                                                                                                                                                       |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>DISPLAY_NAME</b>                     |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | No              | String        |                 | "pciesvc_target" | Default prefix in \$msglog calls.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>APPL_ID</b>                          |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |
|                                         | Yes             | 32-Bit vector |                 | None             | Application ID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |         |           |   |           |              |             |             |         |                 |         |                 |
| <b>CFG_WRITE_NOTIFICATION_MODE</b>      |                 |               |                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |           |   |           |              |             |             |         |                 |         |                 |

**Table 3-6 Completion target parameters (Continued)**

| Parameter Name                | Settable VAR?* | Type    | Range | Default | Description                                                                                                                                                                                                                                                                               |
|-------------------------------|----------------|---------|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | Yes            | Bit     |       | 1'b0    | When set to 1'b1, inbound configuration write requests are saved in an internal queue for later examination. When set to 1'b0, inbound configuration write requests are not saved in an internal queue.                                                                                   |
| DISPLAY_CURRENT_STATUS_PERIOD |                |         |       |         |                                                                                                                                                                                                                                                                                           |
|                               | Yes            | Bit     |       | 1'b0    | When set to 1'b1, inbound configuration write requests are saved in an internal queue for later examination. When set to 1'b0, inbound configuration write requests are not saved in an internal queue.                                                                                   |
| ENABLE_64_BIT_ADDR            |                |         |       |         |                                                                                                                                                                                                                                                                                           |
|                               | Yes            | Bit     |       | 1'b1    | When set to 1'b1, enables Target application to respond to 64 bit addressing of memory requests. When set to 1'b0, Target applications respond to 64 bit addressing of memory requests with CA status.                                                                                    |
| PERCENTAGE_POISONED_CPLD      |                |         |       |         |                                                                                                                                                                                                                                                                                           |
|                               | Yes            | Integer | 0-100 | 0       | The default value of this variable is set to 0. For values greater than 0, it will trigger model's completer to send percentage-wise poisoned completion TLPS with EP bit set to 1. For example, if it is set to 40, then as many percentage completions from the model will be poisoned. |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with "\_VAR". This is useful if using higher-level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

### 3.3.1.1 Completion Target User Tasks

The tasks in [Table 3-7](#) may be called to generate transactions and check for completion status. Certain bits that are less frequently user or changed must be set using the completion target parameters listed in [Table 3-6](#).

**Table 3-7 Completion target user tasks**

| Task Name                                                                                                                                                                                                                                                                                                                   | Arguments (length)    | I/O | Values                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetCompleterId                                                                                                                                                                                                                                                                                                              | completer_id (16)     | I   | Sets the default Completer ID of the Target Application. This ID consists of the {Bus, Device, Function Number}.                                                                                                                                              |
| The default Completer ID is generally set inline via Configuration Write Requests received from the root. If the Target is to initiate any Requests before a Configuration Request is received, this task can be called to set the Completer ID. Any received Configuration Write Request will overwrite the current value. |                       |     |                                                                                                                                                                                                                                                               |
| AddCompleterId                                                                                                                                                                                                                                                                                                              | completer_id (16)     | I   | Adds an additional Completer ID to the Target Application. This ID consists of the {Bus, Device, Function Number}. Note that the Bus# should match the default Completer ID's bus# (above) – as a given endpoint should have the same bus# for all functions. |
| In addition to the above “default” completer ID, this task allows configuration of additional completer IDs that this target is expected to see. It will create Cfg blocks that can be sent separate Cfg transactions.                                                                                                      |                       |     |                                                                                                                                                                                                                                                               |
| SetCPTPointer                                                                                                                                                                                                                                                                                                               | cpt_ptr               | I   | Sets the internal configuration page table pointer. Typically called once in the Instantiation Model.                                                                                                                                                         |
| Sets the internal configuration pointer.                                                                                                                                                                                                                                                                                    |                       |     |                                                                                                                                                                                                                                                               |
| PopMemWriteNotification                                                                                                                                                                                                                                                                                                     | address (64)          | O   | Destination address.                                                                                                                                                                                                                                          |
| Pop the next memory write event in the queue (see MEM_WRITE_NOTIFICATION_MODE parameter to enable.)                                                                                                                                                                                                                         | first_data_dword (32) | O   | First data dword of the write.                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                             | data_dword_len (16)   | O   | Data length of the write transaction.                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                             | first_dw_be (4)       | O   | First data word byte enable                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                             | last_dw_be (4)        | O   | Last data word byte enable                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                             | flags (32)            | O   | Indicate details of this memory write. Currently defined flags are listed in the file <i>pciesvc_application_parms.v</i>                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                             | valid (1)             | O   | Set if this event has valid data in it.                                                                                                                                                                                                                       |

### 3.3.1.2 Completion Target Events

Completion target events are listed in [Table 3-8](#).

**Table 3-8 Completion target events**

| Event Name      | Description                                                                                                                                    |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| event_mem_write | This event will trigger after a memory write occurs in the completer. See related MEM_WRITE_NOTIFICATION_MODE parameter to control this event. |

### 3.3.1.3 Completion Target I/O Space

The Completion Target also can access an I/O memory space allowing reads and write to I/O addresses. Like the memory, the VIP I/O memory is a *sparse* model, allowing a number of disparate addresses to be accessed with a small amount of actual memory. Tasks that provide I/O memory are listed in [Table 3-9](#).

**Table 3-9** Completion target I/O memory space access tasks

| Task Name                                                                                       | Arguments (length) | I/O | Values                                                                                                        |
|-------------------------------------------------------------------------------------------------|--------------------|-----|---------------------------------------------------------------------------------------------------------------|
| Write<br><br>Write the provided data to the target PCIE I/O address, applying the byte enables. | address (32)       | I   | Target PCIE address. Must be dword aligned (bits [1:0] == 0).                                                 |
|                                                                                                 | byte_enables (4)   | I   | Data word byte enables. The bits are in TLP bit order (bit0 corresponds to byte 3 of the data).               |
|                                                                                                 | data (32)          | I   | Data for the write transaction. The data is in TLP byte-order (byte0 on the “left” and byte3 on the “right”). |
|                                                                                                 | status (32)        | O   | Returned status for the write.                                                                                |
| Read<br><br>Read the from the target PCIE I/O address into data, applying the byte enables.     | address (32)       | I   | Target PCIE address. Must be dword aligned (bits [1:0] == 0).                                                 |
|                                                                                                 | byte_enables (4)   | I   | Data word byte enables. The bits are in TLP bit order (bit0 corresponds to byte 3 of the data).               |
|                                                                                                 | data (32)          | O   | Data for the read transaction. The data is in TLP byte-order (byte0 on the “left” and byte3 on the “right”).  |
|                                                                                                 | status (32)        | O   | Returned status for the read.                                                                                 |

### 3.3.1.4 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 will allocate a *Configuration Pointer Table* which contains pointers to all of the Configuration Blocks allocated (one for each function in the device).

Tasks that provide access to the completion target configuration space access are listed in [Table 3-10](#).

**Table 3-10** Completion target configuration space access tasks

| Task Name                                                                                                                        | Arguments (length) | I/O | Values                                                |
|----------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------------------------------------------------------|
| BuildCfgPtrTable<br><br>Create a Configuration Pointer Table used to keep track of all the functions' configuration information. | max_func_num (32)  | I   | Maximum number of functions supported by this device. |
|                                                                                                                                  | cfg_type (1)       | I   | Type0 or Type1 configuration block.*                  |
|                                                                                                                                  | cpt_ptr (32)       | O   | Returned pointer to the Configuration Ptr Table       |

**Table 3-10 Completion target configuration space access tasks (Continued)**

| Task Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Arguments (length) | I/O | Values                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|------------------------------------------------------------------------------|
| AllocCfgBlock<br><br>Allocate and create a Configuration register and capabilities block for a given function.                                                                                                                                                                                                                                                                                                                                                                                       | cpt_ptr (32)       | I   | The CPT pointer (returned from above call to <i>BuildCfgPtrTable</i> ).      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | func_num (32)      | I   | The function number for the created configuration block.                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | cfg_type (1)       | I   | The configuration type (Type0 or Type1) that this created CfgBlock will be.* |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | func_type (4)      | I   | The particular type of function this will be (PF, BF, VF, etc.)              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | sr iov_pf (8)      | I   | The PF that is the ‘parent’ Physical function of this VF.                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | mr iov_bf (8)      | I   | The BF that is the ‘parent’ Base Function of this function.                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | status (32)        | O   | Returned status for the allocate.*                                           |
| FillCfgBlock<br><br>Mark the Cfg block as ‘valid’ and fill values in for a Capabilities Ptr as well as default values on the following Cfg registers:<br><br>Command Reg<br>Status Reg<br>PCIe Capabilities Reg<br>Device Capabilities Reg<br>Device Control Capabilites Reg<br><br>Note that this should typically only be called once (after calling AllocCfgBlock). Further configuration override can be done either via the below WriteCfgReg, or a PCIe CfgWr transaction to the bus/function. | cpt_ptr (32)       | I   | The CPT pointer for the device you want to fill.                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | func_num (8)       | I   | The function number of the Configuration Block you want to fill.             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | cfg_reg (32)       | I   | The configuration-register number you are attempting to write to.*           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | data (32)          | I   | Data for the configuration write transaction.                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | status (32)        | O   | Returned status for the write.*                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | cpt_ptr (32)       | I   | The CPT pointer for the device you want to access.                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | func_num (8)       | I   | The function number of the Configuration Block you want to access.           |

**Table 3-10 Completion target configuration space access tasks (Continued)**

| Task Name                                                                                                                                                   | Arguments (length) | I/O | Values                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|---------------------------------------------------------------------------|
| ReadCfgReg<br><br>Read from the target PCIE Configuration Space register number into data.                                                                  | cpt_ptr (32)       | I   | The CPT pointer for the device you want to access.                        |
|                                                                                                                                                             | func_num (8)       | I   | The function number of the Configuration Block you want to access.        |
|                                                                                                                                                             | cfg_reg (32)       | I   | The configuration register number you are attempting to read from.*       |
|                                                                                                                                                             | data (32)          | I   | Data for the read transaction.                                            |
|                                                                                                                                                             | status (32)        | O   | Returned status for the read.*                                            |
| WriteCfgCapReg<br><br>Write the data to the target PCIE Configuration Space register of the requested capability ID on the device specified by the cpt_ptr. | cpt_ptr (32)       | I   | The CPT pointer for the device you want to access.                        |
|                                                                                                                                                             | func_num (8)       | I   | The function number of the Configuration Block you want to access.        |
|                                                                                                                                                             | cap_id (8)         | I   | The requested configuration-capability ID.*                               |
|                                                                                                                                                             | cfg_reg (32)       | I   | The configuration-register of the above capability that you are writing.* |
|                                                                                                                                                             | data (32)          | I   | Data for the configuration write transaction.                             |
|                                                                                                                                                             | status (32)        | O   | Returned status for the write.*                                           |
| ReadCfgCapReg<br><br>Read the data from the target PCIE Configuration Space register of the requested capability ID on the device specified by the cpt_ptr. | cpt_ptr (32)       | I   | The CPT pointer for the device you want to access.                        |
|                                                                                                                                                             | func_num (8)       | I   | The function number of the Configuration Block you want to access.        |
|                                                                                                                                                             | cap_id (8)         | I   | The requested configuration-capability ID.*                               |
|                                                                                                                                                             | cfg_reg (32)       | I   | The configuration-register of the above capability that you are writing.* |
|                                                                                                                                                             | data (32)          | O   | Data for the configuration read transaction.                              |
|                                                                                                                                                             | status (32)        | O   | Returned status for the write.*                                           |

\* - This field uses a parameter defined in Verilog/Application\_PCIE/pciesvc\_cfg\_parms.v

### 3.3.1.5 Random Corruption of the Return Status of a Command.

A facility has been added to allow random corruption of the return status of a command. There are two main controls of this facility: a percentage to control if and when (randomly) a completion's status will be corrupted; and a set of weights (one per corruption type) each of which controls what type of corruption will be applied once the random selection percentage is satisfied.

There is one weight for each defined corruption type (UR, CRS, and CA) and a 'user' weight which will inject a user-supplied value onto the completion status. Use the following parameters.

| Parameter                     | Description                                                                                        |
|-------------------------------|----------------------------------------------------------------------------------------------------|
| PERCENTAGE MODIFY CPL STATUS  | Percentage of received Requests that get their completion status modified (based on below weights) |
| MODIFY CPL STATUS UR WEIGHT   | If hit - then rewrite Cpl status with UR                                                           |
| MODIFY CPL STATUS CRS WEIGHT  | If hit, then rewrite Cpl status with CRS                                                           |
| MODIFY CPL STATUS CA WEIGHT   | If hit, then rewrite Cpl status with CA                                                            |
| MODIFY CPL STATUS USER WEIGHT | If hit, then rewrite Cpl status with the below user-supplied value.                                |
| MODIFY CPL STATUS USER VALUE  | If above 'USER_WEIGHT' hits, then rewrite Cpl status with this value (used for reserved values)    |

### 3.3.2 Controlling Completion Timing and Size Using Callbacks in Verilog VIP

#### 3.3.2.1 Controlling Completion Size

Following are the two methods available in `tlp_transaction` class for controlling the completion size via callback.

```
function bit[31:0] get_next_completion_size_in_rcb();
function void      set_next_completion_size_in_rcb(int next_size);
```

The call to function `get_next_completion_size_in_rcb()` returns the completion size in RCB units set via the callback method.

Use the `set_next_completion_size_in_rcb()` method to specify the size in RCB units of the completion that follows this `tlp`.

These functions are used only with following callbacks:

```
target_app_tlp_callback::rx_req_callback
target_app_tlp_callback::tx_cpl_callback
```

The functions can be used in the following 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 is 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, then the VIP will transmit only enough data to reach the first RCB. In that case, the length of the first completion can be as small as 1 dword.

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.

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).

Scenario:

- ❖ 256 dword read from endpoint
- ❖ Access aligned to RCB
- ❖ RCB set to 128 bytes (32 dwords), so 8 RCB in total
- ❖ Configured completion sizes will be in the following order:
  - ◆ cpl 1: 1 rcb (32 dwords)
  - ◆ cpl 2: 2 rcb (64 dwords)
  - ◆ cpl 3: 4 rcb (128 dwords)
  - ◆ cpl 4: 1 rcb (32 dwords)

### Example 3-1

```
function void test_target_app_tlp_callback::rx_req_callback( input pciesvc_ta_cb_info
ta_cb_info,
                                         input tlp_transaction
tp, ref bit drop);

    bit [31:0] header_dword;
    bit [7:0] tlp_type;

    header_dword = tlp.get_tlp_data(0);
    tlp_type = header_dword[31:24];

    if ((tlp_type == TLP_TYPE_MEM_RD_REQ_32) || (tlp_type == TLP_TYPE_MEM_RD_REQ_64))
begin
    tlp.set_next_completion_size_in_rcb(1); // Determine size of first completion
end

    return;
endfunction

function void test_target_app_tlp_callback::tx_cpl_callback( input pciesvc_ta_cb_info
ta_cb_info,
                                         input tlp_transaction
tp,
                                         ref bit
drop);

    bit [31:0] header_dword;
    bit [7:0] tlp_type;
    bit [31:0] data;

    header_dword = tlp.get_tlp_data(0);
    tlp_type = header_dword[31:24];

    if (tlp_type == TLP_TYPE_CPLD) begin
        cpld_count++;
    end
endfunction
```

```

// Configure completion sizes as follows:
// cpl 1: 1 rcb (size configured above in rx_req_callback)
// cpl 2: 2 rcb
// cpl 3: 4 rcb
// cpl 4: 1 rcb
    case (cpld_count)
        // These three are the 1st, 2nd, and 3rd completions from the request, and respectively <also deleted a word>
        // set the sizes for the 2nd, 3rd, and 4th completions
        1: tlp.set_next_completion_size_in_rcb(2);
        2: tlp.set_next_completion_size_in_rcb(4);
        3: tlp.set_next_completion_size_in_rcb(1);
        // no handing for 4 since there is no next completion
    endcase
end

return;
endfunction

```

### 3.3.2.2 Controlling Completion Latency

The completion timing can be controlled by one of the following methods:

- ❖ [Controlling Delay for the Current Completion](#)
- ❖ [Controlling Delay for the Next Completion](#)

This can be done using the following callbacks:

- ❖ `target_app_tlp_callback::rx_req_callback`
- ❖ `target_app_tlp_callback::tx_cpl_callback`

#### 3.3.2.2.1 Controlling Delay for the Current Completion

To specify a delay for the current completion, use the `set_completion_delay_in_ns()` method in `tlp_transaction` class:

```
function void set_completion_delay_in_ns(bit[31:0] delay);
```

The input argument to the function specifies the delay in ns for a completion.

This value is ignored if

- ❖ the TLP is not a completion transmitted by the VIP.
- ❖ the value is negative.

This is used only with the following callback method:

```
target_app_tlp_callback::tx_cpl_callback
```

The `tlp_transaction` class also implements this function to get the completion delay that is set via the callback:

```
function bit[31:0] get_completion_delay_in_ns();
```

When called in the callback, this function returns a 32-bit value representing ns.

When used at the specified callback, the `set_completion_delay_in_ns` method 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. The delay specified in the callback is in addition to any delay in generating the completion due to randomization between user-selected latency parameter values (`MIN/`  
`MAX_CPL_LATENCY_NS`).

The attribute controls the delay between the callback and the time the completion is sent to the TL. This implies that if another completion comes before the delay expires, the second completions will go first. If not, the delay will not affect the order in which completions are transmitted.

As a result, the delays required to cause order changes depends on

- ❖ when the requests are received.
- ❖ when the completions are generated.

Completions depends on whether

- ◆ the user is controlling completion timing.
- ◆ the user is controlling completion size.
- ◆ model randomization of completion size and timing if the user does not directly control it.

Note that changing a delay does not necessarily imply changing completion order; timing may be shifted without affecting completion order.

### Example 3-2 Example Scenario

- ❖ Perform 2 aligned 128 dword reads from endpoint with RCB set to 128 bytes (32 dword) – that is, 4 completions per request.
- ❖ Configure completion delays so the completions come back in the following order:
  - ◆ req 1 cpl 1
  - ◆ req 2 cpl 1
  - ◆ req 2 cpl 2
  - ◆ req 1 cpl 2
  - ◆ req 1 cpl 3
  - ◆ req 2 cpl 3
  - ◆ req 2 cpl 4
  - ◆ req 1 cpl 4

This example scenario uses the data in each completion to identify the associated request and consequently determine the delay.

```
class test_target_app_tlp_callback extends target_app_tlp_callback;
    integer cpuld_count;

    function new(string my_name = "test_target_app_tlp_callback");
        super.new(my_name);
        cpuld_count = 0;
    endfunction: new

    function void tx_cpl_callback( input pciesvc_ta_cb_info ta_cb_info,
```

```

        input tlp_transaction      tlp,
ref      bit                drop);

bit [31:0] header_dword;
bit [7:0]  tlp_type;
bit [31:0] data;

header_dword = tlp.get_tlp_data(0);
tlp_type = header_dword[31:24];

if (tlp_type == TLP_TYPE_CPLD) begin
    cpld_count++;

    // Get the 1st word of the payload, check the data (which associates it with a
    specific request), and
    // assign the delay based on that.
    data = tlp.get_tlp_data(3);
    case (data[15:0])
        // These are the four completions from the first request:
        16'h0000: tlp.set_completion_delay_in_ns(0);
        16'h0080: tlp.set_completion_delay_in_ns(1000);
        16'h0100: tlp.set_completion_delay_in_ns(50);
        16'h0180: tlp.set_completion_delay_in_ns(1000);
        // These are the four completions from the second request:
        16'h0200: tlp.set_completion_delay_in_ns(200);
        16'h0280: tlp.set_completion_delay_in_ns(200);
        16'h0300: tlp.set_completion_delay_in_ns(1000);
        16'h0380: tlp.set_completion_delay_in_ns(50);
    endcase
end

return;
endfunction

endclass: test_target_app_tlp_callback
test_target_app_tlp_callback test_ta_tlp_callback;

Setup the target app TLP callback class in the env or initial block and add to SVC target
instance
    test_ta_tlp_callback = new("test_ta_tlp_callback");
success = top.root0.target_appl0.svc_ta_cb.add_tlp_callback(test_ta_tlp_callback);

```

### 3.3.2.2.2 Controlling Delay for the Next Completion

To specify a delay for the next completion, use the `set_completion_delay_in_ns()` method in `tlp_transaction` class:

```
function void set_next_completion_delay_in_ns(bit[31:0] next_delay);
```

The input argument to the function specifies the delay in ns to the creation of a completion that follows the current TLP.

This is used in conjunction with the following callback methods:

- ❖ `target_app_tlp_callback::rx_req_callback()`
- ❖ `target_app_tlp_callback::tx_cpl_callback()`

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 can be used in two cases:

- ❖ A non-posted request received by the VIP: The value specifies the delay to the first completion transmitted by the VIP in response.
- ❖ A memory read completion transmitted by the VIP, if there is at least one subsequent completion for the same request: The value specifies the delay to the next completion transmitted by the VIP.

This value is ignored if

- ❖ the TLP is neither a non-posted request received by the VIP nor a memory read completion transmitted by the VIP.
- ❖ the TLP is the last completion of a memory read request.
- ❖ the value is negative.

### Example 3-3 Example Scenario

- ❖ Perform 3 memory reads of 4 dword to different addresses from the endpoint.
- ❖ Configure completion delays so that the completions come back in reverse order:
  - ◆ req 1
  - ◆ req 2
  - ◆ req 3
  - ◆ req 3 cpl
  - ◆ req 2 cpl
  - ◆ req 1 cpl

```
function void test_target_app_tlp_callback::rx_req_callback( input pciesvc_ta_cb_info
ta_cb_info,
                                         input tlp_transaction
tlp,
                                         ref    bit
drop);
    bit [31:0] header_dword;
    bit [7:0]   tlp_type;

    header_dword = tlp.get_tlp_data(0);
    tlp_type = header_dword[31:24];

    if (tlp_type == TLP_TYPE_MEM_RD_REQ_64) begin
        req_count++;
        case (req_count)
            1: tlp.set_next_completion_delay_in_ns(2100);
            2: tlp.set_next_completion_delay_in_ns(1100);
            3: tlp.set_next_completion_delay_in_ns(100);
        endcase
    end

    return;
endfunction
```



**Note** With `completion_delay_in_ns`, the delay specified in the callback is in addition to any delay already incurred in getting the completion to the callback.

If the model is configured with the non-zero completion latency values (`MIN/MAX_MEM_CPL_LATENCY_NS`), then the model will still use those to determine when the callback occurs. The `completion_delay_in_ns` value will be in addition to that value. To specify the delay entirely via the callback, all the `CPL_LATENCY` values should be set to 0.

If `next_completion_delay_in_ns` is specified, that value will be used instead of the `CPL_LATENCY` values randomized by the model. As a result, if `next_completion_delay_in_ns` is specified on the callback for completion A to affect completion B, and then `completion_delay_in_ns` is specified subsequently for completion B, the final delay for completion B would be the sum of `next_completetion_delay_in_ns` and `completion_delay_in_ns` values.

## 3.4 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.

There are three page-sizes available for allocating pages such that the memory buffers are neither so large that memory is wasted nor are they inefficiently small.

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

The three page sizes are simply: Large, Small and Dword (although the latter, being only 4-bytes long, hardly qualifies as a 'page'!) Since all accesses to the memory target are Dword at a time, it's difficult to predict the transaction's total data length; therefore a "hint" style reservation mechanism is used to allocate pages. When a PCIE memory write is intended, the client can call the task `PreWriteHint()` to request reservation of adequately sized pages. When the following `Write()` is called, the reserved pages are then used to efficiently store the data.

Note that it is up to the particular application using the target memory to choose optimal small and large page sizes based on their use-model. These applications are generally tuned to cooperate optimally with the DUT; similarly the memory target should be tuned to work with these applications. The task `DisplayStats()` can be useful in showing the allocated memory sizes during a simulation to help out in choosing optimal page sizes.

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

### 3.4.1 Memory Target Parameters

Memory target parameters are listed in [Table 3-11](#).

**Table 3-11 Memory target parameters**

| Parameter Name                                                                                                                                                                                                                                                                                                              | Settable VAR?* | Type    | Range    | Default           | Description                                                                                                                                                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|----------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PAGE_SIZE_IN_DWORD</b>                                                                                                                                                                                                                                                                                                   |                |         |          |                   |                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                             | No             | Integer | 8-4096   | 64                | Large page size, in units of dwords. Any transfer of this size (or larger) will allocate pages of this size.                                                                                                                                             |
| <b>SMALL_PAGE_SIZE_IN_DWORD</b>                                                                                                                                                                                                                                                                                             |                |         |          |                   |                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                             | No             | Integer | 8-256    | 8                 | Small page size, in units of dwords. Any transfer of this size (or larger, but less than the above PAGE_SIZE_IN_DWORD) will allocate pages of this size.<br>Any requests smaller than this will use individual Dwords.                                   |
| <b>NUM_64_BIT_PAGES</b>                                                                                                                                                                                                                                                                                                     |                |         |          |                   |                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                             | No             | Integer | 1024-16k | 4096              | Number of 64-bit pages initialized at startup. If the application attempts to allocate more pages than initialized, the allocation will fail, and the user should up the number of pages.<br>Each large or small page or fword uses a single page entry. |
| <b>NUM_32_BIT_PAGES</b>                                                                                                                                                                                                                                                                                                     |                |         |          |                   |                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                             | No             | Integer | 1024-16k | 4096              | Number of 32-bit pages initialized at startup. If the application attempts to allocate more pages than initialized, the allocation will fail, and the user should up the number of pages.<br>Each large or small page or dword uses a single page entry. |
| <b>NUM_ATTR_TBL_ENTRIES</b>                                                                                                                                                                                                                                                                                                 |                |         |          |                   |                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                             | No             | Integer | 1-1024   | 64                | The number of attribute table entries. This defines how many memory ranges are available (see the Add/RemoveMemRange task calls below).                                                                                                                  |
| <b>DISPLAY_NAME</b>                                                                                                                                                                                                                                                                                                         |                |         |          |                   |                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                             | No             | String  |          | “memory_target0.” | Default prefix in \$msglog calls.                                                                                                                                                                                                                        |
| *Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module. |                |         |          |                   |                                                                                                                                                                                                                                                          |

### 3.4.1.1 Memory Target User Tasks

Memory target user tasks are listed in [Table 3-12](#).

**Table 3-12 Memory target user tasks**

| Task Name                                                                                                                                                      | Arguments (length) | I/O | Values                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write<br><br>Write the provided data to the target PCIE memory address, applying the byte enables.                                                             | address(64)        | I   | Target PCIE address. Must be dword aligned (bits [1:0] == 0).<br><br>If address[63:32] == 0, then it is considered a 32-bit address.                                                                                                                                             |
|                                                                                                                                                                | byte_enables (4)   | I   | Data word byte enables. The bits are in TLP bit order (bit0 corresponds to byte 3 of the data).                                                                                                                                                                                  |
|                                                                                                                                                                | data (32)          | I   | Data for the write transaction. The data is in TLP byte-order (byte0 on the “left” and byte3 on the “right”).                                                                                                                                                                    |
|                                                                                                                                                                | status(32)         | O   | Returned status for the write.                                                                                                                                                                                                                                                   |
| Read<br><br>Read the from the target PCIE memory address into data, applying the byte enables.                                                                 | address(64)        | I   | Target PCIE address. Must be dword aligned (bits [1:0] == 0).<br><br>If address[63:32] == 0, then it is considered a 32-bit address.                                                                                                                                             |
|                                                                                                                                                                | byte_enables (4)   | I   | Data word byte enables. The bits are in TLP bit order (bit0 corresponds to byte 3 of the data).                                                                                                                                                                                  |
|                                                                                                                                                                | data (32)          | O   | Data for the read transaction. The data is in TLP byte-order (byte0 on the “left” and byte3 on the “right”).                                                                                                                                                                     |
|                                                                                                                                                                | status(32)         | O   | Returned status for the read. See Application_PCIE/_pciesvc_application_parms.v                                                                                                                                                                                                  |
| PreWriteHint<br><br>Provide a hint to the memory target as to the length of the next write transaction.                                                        | address(64)        | I   | Base PCIE address for the upcoming write requests. Must be dword aligned (bits [1:0] == 0). This address should be the same as the first Write call that will be made following the call to PreWriteHint.<br><br>If address[63:32] == 0, then it is considered a 32-bit address. |
|                                                                                                                                                                | dword_length (32)  | I   | Total length (in dwords) of the upcoming data transferred in this memory write transaction.                                                                                                                                                                                      |
| AddMemRange<br><br>Define a special region of memory.<br>Note that is only required if non-default attributes (e.g. IGNORED) are required on the memory range. | min_range (64)     | I   | Minimum memory address for the region.                                                                                                                                                                                                                                           |
|                                                                                                                                                                | max_range (64)     | I   | Maximum memory address for the region.                                                                                                                                                                                                                                           |
|                                                                                                                                                                | attributes (32)    | I   | The attribute(s) for the specified region.                                                                                                                                                                                                                                       |
|                                                                                                                                                                | error (1)          | O   | Returned status for the AddMemRange. 0 indicates success.                                                                                                                                                                                                                        |

**Table 3-12 Memory target user tasks (Continued)**

| Task Name                                                                                                                                                                         | Arguments (length) | I/O | Values                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|----------------------------------------------------------|
| RemoveMemRange<br><br>Remove a special region of memory that was added previously. Note that the min/max_range must <u>exactly</u> match that which was specified in AddMemRange. | min_range(64)      | I   | Minimum memory address for the region.                   |
|                                                                                                                                                                                   | max_range (64)     | I   | Maximum memory address for the region.                   |
|                                                                                                                                                                                   | attributes (32)    | I   | The attribute(s) for the specified region to be removed. |
|                                                                                                                                                                                   | error (1)          | O   | Returned error status for the RemoveMemRange call.       |
| DisplayStats<br><br>Displays all stats in the Memory Target.                                                                                                                      | none               |     | Displays all stats in the memory target.                 |
| ClearStats<br><br>Clears stats counters in the Memory Target.                                                                                                                     | none               |     | Clears all stats in the memory target.                   |

### 3.4.2 Ignoring Memory Ranges

The memory target (`mem_target0`) has a means to ignore memory ranges. The following two tasks are available for ignoring memory ranges:

- † “Adding a Range of Memory”
- † “Removing a Range of Created Memory”

#### 3.4.2.1 Adding a Range of Memory

Add a range of (potentially ignored) memory:

```
AddMemRange(input bit [63:0]           // Start address
            min_range,
            input bit [63:0] max_range,        // End address
            input bit [31:0] attributes,      // Attribute list (the parameter
            output bit      error)          // This bit indicates if an error
                                              MEM_CHECK_ATTR_IGNORE_BIT is the
                                              ignored flag).
```

#### 3.4.2.2 Removing a Range of Created Memory

Remove a range of created memory:

```
RemoveMemRange (input bit [63:0]         // Start address - min, max and attributes
                min_range,
                input bit [63:0] max_range,       // End address
                                              must match to a previous AddMemRange()
                                              call.)
```

```

    input bit [31:0] attributes,           // Attribute list (the parameter
                                         // MEM_CHECK_ATTR_IGNORE_BIT is the
                                         // ignored flag).
    output bit      error)             // This bit indicates if an error

```

To control what is returned when an ignored (or otherwise uninitialized) region memory is read, you must set the UNINITIALIZED\_MEM\_READ\_MODE [\_VAR] parameter in the target application (target\_app10) to various values:

|                                    |                                                 |
|------------------------------------|-------------------------------------------------|
| UNINITIALIZED_MEM_READ_MODE_ZERO   | - Return zero                                   |
| UNINITIALIZED_MEM_READ_MODE_BAAD   | - Return the value 32'hbaad_baad;               |
| UNINITIALIZED_MEM_READ_MODE_RANDOM | - Return random data                            |
| UNINITIALIZED_MEM_READ_MODE_CA     | - Return a Completer Abort (CA) completion      |
| UNINITIALIZED_MEM_READ_MODE_UR     | - Return an Unsupported Request (UR) completion |

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.

### 3.5 Mid-Sim Reset

The VC VIP provides functionality to support mid-simulation reset. The idea 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 make sure the DUT recovers and that the link retrains. During this time we want to mimic a reset also happening on the VIP which means all activity should cease, all buffers should be cleared, and we should go back into our initial state waiting for training sets.

So, how is this done in with the VIP? First, recall 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 reset. The PL provides a mechanism to 'unplug' and then 'plug', RequestHotplugMode(). All applications provide a mechanism which resets the apps meaning they are re-initialized, ResetApp().

Steps:

1. Initialize DUT and VIP, run to a point in the test where a mid-sim reset is to be performed
2. Unplug VIP from bus (HOTPLUG\_UNPLUG)
3. Assert Reset on the DUT
4. Reset apps (all, some, or none – user choice)
5. Re-enable the VIP on the bus (HOTPLUG\_DETECT)
6. De-assert Reset on the DUT
7. Continue with the test

Suggest monitoring for a change in LTSSM state; PL : WaitForLtssmStateChange()

# 4 Transaction Layer

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. In order to initialize VC1-7, SetInitTxCredits must be called followed by SetVcEnable.

## 4.1 Transaction Layer Module IOs

Transaction Layer module I/O signals are listed in [Table 4-1](#).

**Table 4-1 Transaction Layer module I/Os**

| 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 (32) | Bits (use predefined parms 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 |

## 4.2 Transaction Layer Configuration Tasks

Transaction Layer configuration tasks are listed in [Table 4-2](#).

**Table 4-2 Transaction Layer configuration tasks**

| <b>Task Name</b>   | <b>Arguments</b> | <b>I/O</b> | <b>Values</b>                                                                                                                     |
|--------------------|------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------|
| SetVcEnable        | vh (32)          | I          | Virtual Hierarchy number                                                                                                          |
|                    | vc (32)          | I          | Virtual Channel number                                                                                                            |
|                    | enable           | I          | Enable or disable vc                                                                                                              |
| SetTrafficClassMap | tc(32)           | I          | Traffic class to be mapped to a virtual channel                                                                                   |
|                    | vc(32)           | I          | Virtual channel that traffic class is to be mapped to                                                                             |
|                    | enable(1)        | I          | Enable bit for mapping.                                                                                                           |
| SetInitTxCredits   | vh(32)           | I          | Virtual Hierarchy                                                                                                                 |
|                    | vc(32)           | I          | Virtual channel associated with these credits                                                                                     |
|                    | credit_type(32)  | I          | Definitions (user pre-defined parms for access)<br>2'b00 = Posted<br>2'b01 = Non-Posted<br>2'b10 = Completion<br>2'b11 = Reserved |
|                    | hdr_credits(32)  | I          | Number of header credits for this credit_type                                                                                     |
|                    | data_credits(32) | I          | Number of data credits for this credit_type                                                                                       |

## 4.3 Transaction Layer User Tasks

Transaction Layer user tasks are listed in [Table 4-3](#).

**Table 4-3 Transaction Layer user tasks**

| <b>Task Name</b>                                    | <b>Arguments</b>  | <b>I/O</b> | <b>Values</b>                                        |
|-----------------------------------------------------|-------------------|------------|------------------------------------------------------|
| IsTransactionLayerIdle                              | result (1)        | O          | Is idle is all queues are empty                      |
| This task should be called at the end of each test. |                   |            |                                                      |
| AddMemAddrApplIdMapEntry                            | memory_addr(64)   | I          | Base Address of memory range                         |
| Used to map memory addresses to an application.     | memory_window(64) | I          | Window of addresses which will cause match of entry. |
|                                                     | appl_id(32)       | I          | Application ID to map TLP to.                        |
|                                                     | error(1)          | O          | Indication that addition of new entry failed.        |
| AddIOAddrApplIdMapEntry                             | memory_addr(64)   | I          | Base Address of memory range                         |
| Used to map I/O addresses to an application.        | memory_window(64) | I          | Window of addresses which will cause match of entry. |
|                                                     | appl_id(32)       | I          | Application ID to map TLP to.                        |
|                                                     | error(1)          | O          | Indication that addition of new entry failed.        |

**Table 4-3 Transaction Layer user tasks (Continued)**

| <b>Task Name</b>                                                                                                                             | <b>Arguments</b>                                                                                                                                                                                                         | <b>I/O</b>                          | <b>Values</b>                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AddCfgBDFApplIdMapEntry                                                                                                                      | config_type(1)<br><br>Used to map Config Request {Bus, Device, Function} to applications.<br>Used when VIP is Upstream port of a link. This mapping is enabled via the ENABLE_ROUTE_CFG_TYPE[0I1]_TO_FUNCTION parameter. | I<br><br>bdf(16)<br><br>appl_id(32) | If true, Configuration is a Type 1 request. If false, Configuration is a Type 0 request.<br><br>{bus, device, function} of request.<br><br>Application ID to map TLP to. |
|                                                                                                                                              | error(1)                                                                                                                                                                                                                 | O                                   | Indication that addition of new entry failed.                                                                                                                            |
| AddATAddrApplIdMapEntry                                                                                                                      | memory_addr(64)<br><br>Used to map memory addresses which need address translation to an application.                                                                                                                    | I<br><br>memory_window(64)          | Base Address of memory range<br><br>Window of addresses which will cause match of entry.                                                                                 |
|                                                                                                                                              | appl_id(32)                                                                                                                                                                                                              | I                                   | Application ID to map TLP to.                                                                                                                                            |
|                                                                                                                                              | error(1)                                                                                                                                                                                                                 | O                                   | Indication that addition of new entry failed.                                                                                                                            |
| AddRIdMsgCodeApplIdMapEntry                                                                                                                  | requester_id(16)<br><br>Used to map {Requester Ids, msgcode} of MSG TLPs to applications.                                                                                                                                | I<br><br>msgcode(8)                 | Requester Id to map<br><br>Msgcode of TLP. Same value as msgcode field in TLP header. See Include/pciesvc_parms.v file for defines.                                      |
|                                                                                                                                              | appl_id(32)                                                                                                                                                                                                              | I                                   | Application ID to map TLP to.                                                                                                                                            |
|                                                                                                                                              | error(1)                                                                                                                                                                                                                 | O                                   | Indication that addition of new entry failed.                                                                                                                            |
| AddRequestIdApplIdMapEntry                                                                                                                   | requester_id(16)<br><br>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.                                    | I<br><br>appl_id(32)                | Requester Id to map<br><br>Application ID to map TLP to.                                                                                                                 |
|                                                                                                                                              | error(1)                                                                                                                                                                                                                 | O                                   | Indication that addition of new entry failed.                                                                                                                            |
| DisplayMemAddrApplidMap                                                                                                                      | none                                                                                                                                                                                                                     |                                     | Displays all entries in Memory Address mapping table.                                                                                                                    |
| Displays all memory address to application id map entries.                                                                                   |                                                                                                                                                                                                                          |                                     |                                                                                                                                                                          |
| DisplayIOAddrApplidMap                                                                                                                       | none                                                                                                                                                                                                                     |                                     | Displays all entries in I/O Address mapping table.                                                                                                                       |
| Displays all I/O address to application id map entries.                                                                                      |                                                                                                                                                                                                                          |                                     |                                                                                                                                                                          |
| DisplayCfgBDFApplidMap                                                                                                                       | none                                                                                                                                                                                                                     |                                     | Displays all entries in CfgBDF mapping table.                                                                                                                            |
| Displays all Configuration Type 0 and Type 1 {Bus, Device, Function} to application id map entries. Use when VIP is Upstream port of a link. |                                                                                                                                                                                                                          |                                     |                                                                                                                                                                          |

**Table 4-3 Transaction Layer user tasks (Continued)**

| <b>Task Name</b>                                                                                                               | <b>Arguments</b>      | <b>I/O</b> | <b>Values</b>                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------|
| DisplayATAddrApplidMap<br><br>Displays all memory address to application id map entries which require address translation.     | none                  |            | Displays all entries in AT Address mapping table.                                                                                 |
| DisplayRidMsgCodeApplidMap<br><br>Displays all {Requester Id, MsgCode} to application id map entries.                          | none                  |            | Displays all entries in RidMsgCode mapping table.                                                                                 |
| DisplayRidApplidMap<br><br>Displays all Requester Id to application id map entries. Use when VIP is Upstream port of a link.   | none                  |            | Displays all entries in Requestor id mapping table.                                                                               |
| DisplayStats<br><br>Displays all stats in Transaction Layer.                                                                   | none                  |            | Displays all stats in Transaction Layer.                                                                                          |
| ClearStats<br><br>Clears all stats in Transaction Layer.                                                                       | none                  |            | Clear all stats in Transaction Layer.                                                                                             |
| IsVcInitFinished<br><br>Used to determine if Data Link Layer has finished the Init Flow Control handshake for a particular VC. | vh(32)                | I          | Virtual Hierarchy.                                                                                                                |
|                                                                                                                                | vc(32)                | I          | Virtual channel to check.                                                                                                         |
| QueryRxCreditsAvailable<br><br>Returns credits this VIP has received and are available for sending TLPs.                       | vh(32)                | I          | Virtual Hierarchy                                                                                                                 |
|                                                                                                                                | vc(32)                | I          | Virtual channel to check.                                                                                                         |
|                                                                                                                                | fc_type               | I          | Definitions (user pre-defined parms for access)<br>2'b00 = Posted<br>2'b01 = Non-Posted<br>2'b10 = Completion<br>2'b11 = Reserved |
|                                                                                                                                | avail_hdr_credits     | O          | Actual number header credits available for transmitting TLPs. Limit – consumed header credit values.                              |
|                                                                                                                                | infinite_hdr_credits  | O          | If set, TLPs are not gated due to header credits.                                                                                 |
|                                                                                                                                | avail_data_credits    | O          | Actual number data credits available for transmitting TLPs. Limit – consumed data credit values.                                  |
|                                                                                                                                | infinite_data_credits | O          | If set, TLPs are not gated due to data credits.                                                                                   |

**Table 4-3 Transaction Layer user tasks (Continued)**

| Task Name                                                                                                  | Arguments             | I/O | Values                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------|-----------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| QueryTxCreditsAvailable<br><br>Returns number of credits transmitted to the link partner for sending TLPs. | vh(32)                | I   | Virtual Hierarchy                                                                                                                                     |
|                                                                                                            | vc(32)                | I   | Virtual channel to check.                                                                                                                             |
|                                                                                                            | fc_type               | I   | Definitions (user pre-defined parms for access)<br>2'b00 = Posted<br>2'b01 = Non-Posted<br>2'b10 = Completion<br>2'b11 = Reserved                     |
|                                                                                                            | avail_hdr_credits     | O   | Actual number header credits transmitted to link partner. Link partner can use these credits to send TLPs. Allocated – Received header credit values. |
|                                                                                                            | infinite_hdr_credits  | O   | If set, initial header credits sent to link partner were infinite.                                                                                    |
|                                                                                                            | avail_data_credits    | O   | Actual number data credits transmitted to link partner. Link partner can use these credits to send TLPs. Allocated – Received data credit values.     |
|                                                                                                            | infinite_data_credits | O   | If set, initial data credits sent to link partner were infinite.                                                                                      |

**Table 4-3 Transaction Layer user tasks (Continued)**

| Task Name                                                                                                                                                                                                  | Arguments    | I/O | Values                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| QueryCreditCounts                                                                                                                                                                                          | vh(32)       | I   | Virtual Hierarchy                                                                                                                                     |
| Returns actual counter values as selected by credit_sel. These are the values in the counters themselves and not the actual number of credits available.                                                   | vc(32)       | I   | Virtual channel to check.                                                                                                                             |
|                                                                                                                                                                                                            | credit_sel   | I   | Definitions (user pre-defined parms for access)<br>0 = init allocated<br>1 = allocated<br>2 = limit<br>3 = received<br>4 = consumed<br>5 = init limit |
|                                                                                                                                                                                                            | credit_type  | I   | Definitions (user pre-defined parms for access)<br>2'b00 = Posted<br>2'b01 = Non-Posted<br>2'b10 = Completion<br>2'b11 = Reserved                     |
|                                                                                                                                                                                                            | hdr_credits  | O   | Value stored in header counter indicated by credit_sel. Not actual number of credits.                                                                 |
|                                                                                                                                                                                                            | data_credits | O   | Value stored in data counter indicated by credit_sel. Not actual number of credits.                                                                   |
| CheckFinalCredits                                                                                                                                                                                          | n/a          | n/a | This task should be called at the end of every test. Any lost credits will be flagged.                                                                |
| Compares initial allocated credits to final allocated – received credit values.<br>Compares initial Limit credits to final limit – consumed credit values.<br>Warnings are issued if any credits are lost. |              |     |                                                                                                                                                       |

## 4.4 Transaction Layer Parameters

Transaction Layer parameters are listed in [Table 4-4](#).

**Table 4-4 Transaction Layer parameters**

| Parameter Name               | Settable VAR?* | Type    | Range                 | Default Value         | Description                                                                                                                      |
|------------------------------|----------------|---------|-----------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------|
| PCIE_SPEC_VER                |                |         |                       |                       |                                                                                                                                  |
|                              | Yes            | Real    | 1.1, 2.0,<br>2.1, 3.0 | PCIE_SPEC_V<br>ER_2_1 | See Include/pciesvc_parms.v:<br>PCIE_SPEC_VER_*<br>Note: Please set this in the model.                                           |
| ENABLE_ROUTE_MEM_TO_FUNCTION |                |         |                       |                       |                                                                                                                                  |
|                              | Yes            | Integer | 0-1                   | 0                     | Enable routing memory requests to function via memory request mapping table. Use task AddMemAddrApplIdMapEntry to program table. |

**Table 4-4 Transaction Layer parameters (Continued)**

| <b>Parameter Name</b>                     | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>    | <b>Default Value</b> | <b>Description</b>                                                                                                                                                             |
|-------------------------------------------|-----------------------|-------------|-----------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DEFAULT_ROUTE_MEM_APPL_ID</b>          |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0-2^16          | 0                    | Default Application ID to use if above enable is not asserted or mapping fails.                                                                                                |
| <b>ENABLE_ROUTE_IO_TO_FUNCTION</b>        |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0-1             | 0                    | Enable routing I/O requests to function via I/O request mapping table. Use task AddIOAddrApplIdMapEntry to program table.                                                      |
| <b>DEFAULT_ROUTE_IO_APPL_ID</b>           |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0 - large value | 0                    | Default Application ID to use if above enable is not asserted or mapping fails.                                                                                                |
| <b>ENABLE_ROUTE_CFG_TYPE0_TO_FUNCTION</b> |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0-1             | 0                    | Enable routing Type 0 Configuration requests to function via configuration request mapping table. Task AddCfgBDFApplIdMapEntry used to program table.                          |
| <b>DEFAULT_ROUTE_CFG_TYPE0_APPL_ID</b>    |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0 - large value | 0                    | Default Application ID to use if corresponding Type 0 enable listed above is not asserted or mapping fails.                                                                    |
| <b>ENABLE_ROUTE_CFG_TYPE1_TO_FUNCTION</b> |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0-1             | 0                    | Enable routing Type 1 Configuration requests to function via configuration request mapping table. Task AddCfgBDFApplIdMapEntry used to program table.                          |
| <b>DEFAULT_ROUTE_CFG_TYPE1_APPL_ID</b>    |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0 - large value | 0                    | Default Application ID to use if corresponding Type 1 enable listed above is not asserted or mapping fails.                                                                    |
| <b>ENABLE_ROUTE_MSG_TO_FUNCTION</b>       |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0-1             | 0                    | Enable routing message requests to function via message request mapping table. If not enabled, the default Appl Id used for routing is as defined by DEFAULT_ROUTE_MSG_APPL_ID |
| <b>DEFAULT_ROUTE_MSG_APPL_ID</b>          |                       |             |                 |                      |                                                                                                                                                                                |
|                                           | Yes                   | Integer     | 0 - large value | 0                    | Default Application ID to use if above enable is not asserted or mapping fails.                                                                                                |

**Table 4-4 Transaction Layer parameters (Continued)**

| Parameter Name                       | Settable VAR?* | Type    | Range           | Default Value | Description                                                                                                         |
|--------------------------------------|----------------|---------|-----------------|---------------|---------------------------------------------------------------------------------------------------------------------|
| <b>ENABLE_ROUTE_AT_TO_FUNCTION</b>   |                |         |                 |               |                                                                                                                     |
|                                      | Yes            | Integer | 0-1             | 0             | Enable routing AT requests to function via AT request mapping table. Use task AddATApplIdMapEntry to program table. |
| <b>DEFAULT_ROUTE_AT_APPL_ID</b>      |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 0 - large value | 0             | Default Application ID to route Address Translation requests to.                                                    |
| <b>NUM_APPL_ID</b>                   |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 8-128           | 8             | Max number of unique Application IDs. IDs assigned to applications must be less than this value.                    |
| <b>RID_APPLID_TABLE_SIZE</b>         |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 4-4096          | 64            | Number of unique RID to Appl_id map entries.                                                                        |
| <b>RID_MSGCODE_APPLID_TABLE_SIZE</b> |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 4-4096          | 64            | Number of unique {RID,msgcode} to Appl_id map entries.                                                              |
| <b>MEM_ADDR_ADDPLID_TABLE_SIZE</b>   |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 4-4096          | 64            | Number of unique Mem Address to Appl_id map entries.                                                                |
| <b>IO_ADDR_ADDPLID_TABLE_SIZE</b>    |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 4-4096          | 64            | Number of unique I/O Address to Appl_id map entries.                                                                |
| <b>AT_ADDR_ADDPLID_TABLE_SIZE</b>    |                |         |                 |               |                                                                                                                     |
|                                      | No             | Integer | 4-4096          | 64            | Number of unique AT Address to Appl_id map entries.                                                                 |
| <b>AUTO_ENABLE_VC0_AT_STARTUP</b>    |                |         |                 |               |                                                                                                                     |
|                                      | Yes            | Integer | 0-1             | 1             | Enable of VC0 at startup. VC0 automatically initializes unless this parm/_VAR is set to 0.                          |

**Table 4-4 Transaction Layer parameters (Continued)**

| Parameter Name                                | Settable VAR?* | Type    | Range                        | Default Value                                                                                | Description                                                                                                                                                              |
|-----------------------------------------------|----------------|---------|------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>NUM_VC_[P/NPCPL]_NIT_[HDRDATA]_CREDITS</b> |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer | Hdr = 0-255<br>Date = 0-4096 | P_HDR =102<br>P_DATA =1024<br>NP_HDR =101<br>NP_DATA =1025<br>CPL_HDR =100<br>CPL_DATA =1026 | Initial credits sent to link partner if SetAllocatedCredits is not called. For VC0 only.                                                                                 |
| <b>MIN_VC[0-7]_[P/NP/CPL]_UPDATEFC_DELAY</b>  |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer |                              | 1 ns                                                                                         | Min delay from rx of TLP to tx of corresponding credit. This can be used to model delay associated with freeing rx TLP buffer space.                                     |
| <b>MAX_VC[0-7]_[P/NP/CPL]_UPDATEFC_DELAY</b>  |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer |                              | 100 ns                                                                                       | Max delay from rx of TLP to tx of corresponding credit. This can be used to model delay associated with freeing rx TLP buffer space.                                     |
| <b>CREDIT_STARVATION_TIMEOUT_NS</b>           |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer |                              | 10,000 ns                                                                                    | If a VC is credit starved, i.e. TLP transmission is gated, for too long, a warning is issued. Credits should be returned in a timely fashion. Set to 0 to disable check. |
| <b>MAX_NUM_END_TO_END_PREFIXES</b>            |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer |                              | 4                                                                                            | Max number of prefixes allowed. Version 3 only.                                                                                                                          |
| <b>REMOTE_MAX_PAYLOAD_SIZE</b>                |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer |                              | 128 bytes                                                                                    | Remote Max Payload Size. Used to check incoming TLP size.                                                                                                                |
| <b>REMOTE_EXTENDED_TAG_FIELD_ENABLED</b>      |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer | 0-1                          | 0                                                                                            | Remote extended Tag enabled support as per Config 7.8.4. Used to check incoming TLPs.                                                                                    |
| <b>REMOTE_MAX_READ_REQUEST_SIZE</b>           |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer |                              | 512 bytes                                                                                    | Remote Max Read Request size. Used to check incoming Read Request TLP size.                                                                                              |
| <b>ENABLE_ARI</b>                             |                |         |                              |                                                                                              |                                                                                                                                                                          |
|                                               | Yes            | Integer | 0-1                          | 0                                                                                            | Enable ARI in Transaction Layer. Version 3 only.                                                                                                                         |

**Table 4-4 Transaction Layer parameters (Continued)**

| Parameter Name                     | Settable VAR?* | Type    | Range                | Default Value | Description                                                                                                                                                                                                                                    |
|------------------------------------|----------------|---------|----------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>IS_TX_DOWNSTREAM</b>            |                |         |                      |               |                                                                                                                                                                                                                                                |
|                                    | No             | Integer | 0-1                  | 0             | Stack direction. Used for TLP header checking/routing.                                                                                                                                                                                         |
| <b>IS_SWITCH</b>                   |                |         |                      |               |                                                                                                                                                                                                                                                |
|                                    | No             | Integer | 0-1                  | 0             | Is this stack part of a switch? Used for TLP header checking/routing.                                                                                                                                                                          |
| <b>DISPLAY_VC_QUEUES_PERIOD_NS</b> |                |         |                      |               |                                                                                                                                                                                                                                                |
|                                    | Yes            | Integer | 10_000 - large value | 50000         | Display contents of enabled VC queues. Setting to 0 disables the display.                                                                                                                                                                      |
| <b>ENABLE_SHADOW_CFG_LOOKUP</b>    |                |         |                      |               |                                                                                                                                                                                                                                                |
|                                    | Yes            | Integer |                      | 1             | When this is 1, the Transaction Layer will examine the shadow configuration database of the source of received TLPs to allow TLP checks against that configuration.<br>Make sure this is not enabled if the shadow memory is not instantiated. |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “\_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

## 4.5 Transaction Layer Events

Transaction Layer events are listed in [Table 4-5](#).

**Table 4-5 Transaction Layer events**

| Event Name            | Description            |
|-----------------------|------------------------|
| event_sent_credit     | Credits were sent.     |
| event_received_credit | Credits were received. |
| event_sent_tlp        | TLP was sent.          |
| event_received_tlp    | TLP was received.      |

## 4.6 Transaction Layer ASCII Signals

Transaction Layer ASCII signals are listed in [Table 4-6](#).

**Table 4-6 Transaction Layer ASCII Signals**

| <b>Event Name</b>    | <b>Description</b>                                                    |
|----------------------|-----------------------------------------------------------------------|
| ascii_tx_tlp_type    | Type of TLP to be sent as defined by {fmt, type} fields.              |
| ascii_tx_tlp_fc_type | Flow control credits associated with this TLP. Values are P, NP, CPL. |
| ascii_tx_tlp_vc      | VC TLP sent on.                                                       |
| ascii_tx_tlp_xid     | Sent TLP transaction Id                                               |
| ascii_rx_tlp_type    | Type of received TLP as defined by {fmt, type} fields.                |
| ascii_rx_tlp_fc_type | Flow control credits associated with this TLP. Values are P, NP, CPL. |
| ascii_rx_tlp_vc      | VC TLP received on.                                                   |
| ascii_rx_tlp_xid     | Received TLP transaction Id                                           |

## 4.7 Transaction Layer Statistics

Transaction Layer statistics are listed in [Table 4-7](#).

**Table 4-7 Transaction Layer statistics**

| <b>Stat Name</b>                | <b>Width</b> | <b>Description</b>                    |
|---------------------------------|--------------|---------------------------------------|
| stat_num_tlp[0-7]_sent          | 32           | Number of TLPs sent by the link       |
| stat_num_tlp[0-7]_received      | 32           | Number of TLPs received by the link   |
| stat_num_good_tlp[0-7]_sent     | 32           | Number of TLPs sent without error     |
| stat_num_good_tlp[0-7]_received | 32           | Number of TLPs received without error |
| stat_num_bad_tlp[0-7]_sent      | 32           | Number of TLPs sent with error        |
| stat_num_bad_tlp[0-7]_received  | 32           | Number of TLPs received with error    |
| stat_num_tc[0-7]_tlps_sent      | 32           | Number of tc[0-7] TLPs sent           |
| stat_num_tc[0-7]_tlps_received  | 32           | Number of tc[0-7] TLPs received       |
| stat_num_vc[0-7]_tlps_sent      | 32           | Number of vc[0-7] TLPs sent           |
| stat_num_vc[0-7]_tlps_received  | 32           | Number of vc[0-7] TLPs received       |
| stat_num_tlp_cfg_rd0_received   | 32           | Number of Cfg rd0 TLPs received       |
| stat_num_tlp_cfg_wr0_received   | 32           | Number of Cfg wr0 TLPs received       |
| stat_num_tlp_cfg_rd1_received   | 32           | Number of Cfg rd1 TLPs received       |
| stat_num_tlp_cfg_wr1_received   | 32           | Number of Cfg wr1 TLPs received       |
| stat_num_tlp_io_rd_received     | 32           | Number of I/O rd TLPs received        |
| stat_num_tlp_io_wr_received     | 32           | Number of I/O wr TLPs received        |
| stat_num_tlp_tcfg_rd_received   | 32           | Number of Tcfg rd0 TLPs received      |
| stat_num_tlp_tcfg_wr_received   | 32           | Number of Tcfg wr0 TLPs received      |
| stat_num_tlp_msg_received       | 32           | Number of msg TLPs received           |
| stat_num_tlp_msqd_received      | 32           | Number of Msqd TLPs received          |

**Table 4-7 Transaction Layer statistics (Continued)**

| <b>Stat Name</b>                              | <b>Width</b> | <b>Description</b>                            |
|-----------------------------------------------|--------------|-----------------------------------------------|
| stat_num_tlp_msg_assert_int[a-d]_received     | 32           | Number of msg assert Int[a-d] TLPs received   |
| stat_num_tlp_msg_deassert_int[a-d]_received   | 32           | Number of msg deassert Int[a-d] TLPs received |
| stat_num_tlp_msg_pm_active_state_nak_received | 32           | Number of msg pm active state NAK received    |
| stat_num_tlp_msg_pm_pme_received              | 32           | Number of msg pme received                    |
| stat_num_tlp_msg_pm_turn_off_received         | 32           | Number of msg pm turn off received            |
| stat_num_tlp_msg_pm_to_ack_received           | 32           | Number of msg pm to ACK received              |
| stat_num_tlp_msg_err_cor_received             | 32           | Number of msg correctable error received      |
| stat_num_tlp_msg_err_nonfatal_received        | 32           | Number of msg nonfatal error received         |
| stat_num_tlp_msg_err_fatal_received           | 32           | Number of msg fatal error received            |
| stat_num_tlp_msg_unlock_received              | 32           | Number of msg unlock received                 |
| stat_num_tlp_msg_set_pwr_limit_received       | 32           | Number of msg set pwr limit received          |
| stat_num_tlp_msg_vendor_type0_received        | 32           | Number of msg vendor type0 received           |
| stat_num_tlp_msg_vendor_type1_received        | 32           | Number of msg vendor type1 received           |
| stat_num_tlp_msg_ltr_received                 | 32           | Number of msg ltr received                    |
| stat_num_tlp_msg_obff_received --             | 32           | Number of msg obff received                   |
| stat_num_tlp_mem_wr32_received                | 32           | Number of TLP Mem wr 32 received              |
| stat_num_tlp_mem_wr64_received                | 32           | Number of TLP Mem wr 64 received              |
| stat_num_tlp_mem_rd32_received                | 32           | Number of TLP Mem rd 32 received              |
| stat_num_tlp_mem_rd64_received                | 32           | Number of TLP Mem rd 64 received              |
| stat_num_tlp_mem_rd_lock32_received           | 32           | Number of TLP Mem rd lock 32 received         |
| stat_num_tlp_mem_rd_lock64_received           | 32           | Number of TLP Mem rd lock 64 received         |
| stat_num_tlp_fetch_add32_received             | 32           | Number of TLP fetch add32 received            |
| stat_num_tlp_fetch_add64_received             | 32           | Number of TLP fetch add64 received            |
| stat_num_tlp_swap32_received                  | 32           | Number of TLP swap32 received                 |
| stat_num_tlp_swap64_received                  | 32           | Number of TLP swap64 received                 |
| stat_num_tlp_cas32_received                   | 32           | Number of TLP cas32 received                  |
| stat_num_tlp_cas64_received                   | 32           | Number of TLP cas64 received                  |
| stat_num_tlp_cpl_received                     | 32           | Number of TLP cpl received                    |
| stat_num_tlp_cpld_received                    | 32           | Number of TLP cpld received                   |
| stat_num_tlp_cpl_lock_received                | 32           | Number of TLP cpl lock received               |
| stat_num_tlp_cpld_lock_received               | 32           | Number of TLP cpld lock received              |
| stat_num_tlp_cfg_rd0_sent                     | 32           | Number of cfg rd0 TLPs sent                   |
| stat_num_tlp_cfg_wr0_sent                     | 32           | Number of cfg wr0 TLPs sent                   |

**Table 4-7 Transaction Layer statistics (Continued)**

| <b>Stat Name</b>                          | <b>Width</b> | <b>Description</b>                        |
|-------------------------------------------|--------------|-------------------------------------------|
| stat_num_tlp_cfg_rd1_sent                 | 32           | Number of cfg rd1 TLPs sent               |
| stat_num_tlp_cfg_wr1_sent                 | 32           | Number of cfg wr1 TLPs sent               |
| stat_num_tlp_io_rd_sent                   | 32           | Number of I/O rd TLPs sent                |
| stat_num_tlp_io_wr_sent                   | 32           | Number of I/O wr TLPs sent                |
| stat_num_tlp_tcfg_rd_sent                 | 32           | Number of TCfg rd0 TLPs sent              |
| stat_num_tlp_tcfg_wr_sent                 | 32           | Number of TCfg wr0 TLPs sent              |
| stat_num_tlp_msg_sent                     | 32           | Number of msg TLPs sent                   |
| stat_num_tlp_msqd_sent                    | 32           | Number of MsgD TLPs sent                  |
| stat_num_tlp_msg_assert_int[a-d]_sent     | 32           | Number of msg assert int[a-d] TLPs sent   |
| stat_num_tlp_msg_deassert_int[a-d]_sent   | 32           | Number of msg deassert int[a-d] TLPs sent |
| stat_num_tlp_msg_pm_active_state_nak_sent | 32           | Number of msg pm active state NAK sent    |
| stat_num_tlp_msg_pm_pme_sent              | 32           | Number of msg pme sent                    |
| stat_num_tlp_msg_pm_turn_off_sent         | 32           | Number of msg pm turn off sent            |
| stat_num_tlp_msg_pm_to_ack_sent           | 32           | Number of msg pm to ACK sent              |
| stat_num_tlp_err_cor_sent                 | 32           | Number of msg correctable error sent      |
| stat_num_tlp_msg_err_nonfatal_sent        | 32           | Number of msg nonfatal error sent         |
| stat_num_tlp_err_fatal_sent               | 32           | Number of msg fatal error sent            |
| stat_num_tlp_msg_unlock_sent              | 32           | Number of msg unlock sent                 |
| stat_num_tlp_set_pwr_limit_sent           | 32           | Number of msg set pwr limit sent          |
| stat_num_tlp_msg_vendor_type0_sent        | 32           | Number of msg vendor type0 sent           |
| stat_num_tlp_msg_vendor_type1_sent        | 32           | Number of msg vendor type1 sent           |
| stat_num_tlp_ltr_sent                     | 32           | Number of msg ltr sent                    |
| stat_num_tlp_obff_sent                    | 32           | Number of msg obff sent                   |
| stat_num_tlp_mem_wr32_sent                | 32           | Number of TLP Mem wr 32 sent              |
| stat_num_tlp_mem_wr64_sent                | 32           | Number of TLP Mem wr 64 sent              |
| stat_num_tlp_mem_rd32_sent                | 32           | Number of TLP Mem rd 32 sent              |
| stat_num_tlp_mem_rd64_sent                | 32           | Number of TLP Mem rd 64 sent              |
| stat_num_tlp_mem_rd_lock32_sent           | 32           | Number of TLP Mem rd lock 32 sent         |
| stat_num_tlp_mem_rd_lock64_sent           | 32           | Number of TLP Mem rd lock 64 sent         |
| stat_num_tlp_fetch_add32_sent             | 32           | Number of TLP fetch add32 sent            |
| stat_num_tlp_fetch_add64_sent             | 32           | Number of TLP fetch add64 sent            |
| stat_num_tlp_swap32_sent                  | 32           | Number of TLP swap32 sent                 |
| stat_num_tlp_swap64_sent                  | 32           | Number of TLP swap64 sent                 |
| stat_num_tlp_cas32_sent                   | 32           | Number of TLP cas32 sent                  |

**Table 4-7 Transaction Layer statistics (Continued)**

| <b>Stat Name</b>               | <b>Width</b> | <b>Description</b>              |
|--------------------------------|--------------|---------------------------------|
| stat_num_tlp_cas64_sent        | 32           | Number of TLP cas64 sent        |
| stat_num_tlp_cpl_sent          | 32           | Number of TLP cpl sent          |
| stat_num_tlp_cpld_sent         | 32           | Number of TLP cpld sent         |
| stat_num_tlp_cpl_lock_sent     | 32           | Number of TLP cpl lock sent     |
| stat_num_tlp_cpld_lock_sent    | 32           | Number of TLP cpld lock sent    |
| stat_num_dl_status_down_events | 32           | Number of dl status down events |

## 4.8 Transaction Layer Internal Interface Tasks

The Transaction Layer interfaces with the application layer above and with the Data Link Layer below. Application layer to Transaction Layer interface tasks are listed in [Table 4-8](#). Transaction Layer to Data Link Layer tasks are listed in [Table 4-10](#).

**Table 4-8 Application layer – Transaction Layer interface tasks**

| <b>Task Name</b>                                                                             | <b>Arguments</b> | <b>I/O</b> | <b>Values</b>                                                                                                                    |
|----------------------------------------------------------------------------------------------|------------------|------------|----------------------------------------------------------------------------------------------------------------------------------|
| SendPacket<br><br>Task pair called with task of same name in application. Used to send TLPs. | appli_id(32)     | I          | Application ID TLP was sent from.                                                                                                |
|                                                                                              | tlp_vh(32)       | I          | Virtual hierarchy to send TLP on.                                                                                                |
|                                                                                              | tlp_tc(32)       | I          | Traffic class of the outgoing packet                                                                                             |
|                                                                                              | tlp_ptr(32)      | I          | Pointer to the TLP header                                                                                                        |
|                                                                                              | tlp_len(32)      | I          | Length of the TLP in dwords                                                                                                      |
|                                                                                              | tlp_ei_code(32)  | I          | Error injection code. Error injection code can be found in Verilog/Include/pciesvc_parms.v and start with the prefix TX_TLP_EI_* |
|                                                                                              | req(1)           | I          | Request to send TLP                                                                                                              |
|                                                                                              | ack(1)           | O          | Acknowledgement that request was accepted.                                                                                       |

**Table 4-8 Application layer – Transaction Layer interface tasks (Continued)**

| Task Name                                                                              | Arguments       | I/O | Values                                                                                                                                                                                        |
|----------------------------------------------------------------------------------------|-----------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Task pair called with task of same name in application. Used to receive TLPs from VIP. | appl_id(32)     | I   | Application ID requesting TLP.                                                                                                                                                                |
|                                                                                        | tlp_vh(32)      | O   | Virtual hierarchy TLP was received on.                                                                                                                                                        |
|                                                                                        | tlp_tc(32)      | O   | Traffic class of the received TLP.                                                                                                                                                            |
|                                                                                        | tlp_ptr(32)     | O   | Pointer to data in the received TLP.<br>NOTE: This pointer must be freed by the user to avoid memory leakage. See the FreeMemory task description in <a href="#">"Memory Model Utility"</a> . |
|                                                                                        | tlp_len(32)     | O   | Length of the TLP in dwords.                                                                                                                                                                  |
|                                                                                        | tlp_ei_code(32) | O   | Error injection code. No rx error injection codes are currently defined.                                                                                                                      |
|                                                                                        | tlp_status(32)  | O   | Error status of TLP. Used by Application to generate the appropriate Completion TLP.                                                                                                          |
|                                                                                        | req(1)          | O   | Request to pass the received packet up.                                                                                                                                                       |
|                                                                                        | ack(1)          | I   | Acknowledgment that the received packet was accepted.                                                                                                                                         |

There are some error injection codes that are not inserted using automated error injection but can be injected using either the Synopsys user application or a user-created application. It is up to you to inject these errors when you create a TLP, but the appropriate error injection code must be used so that lower layers know the TLP has an error. The error injection codes are described in [Table 4-9](#).

**Table 4-9 Error injection codes**

| Error Inection Code            | Description                                                                              |
|--------------------------------|------------------------------------------------------------------------------------------|
| TX_TLP_EI_INVALID_FMT_TYPE     | The TLP has a reserved or undefined value on the fmt/type fields.                        |
| TX_TLP_EI_CORRUPT_LENGTH_FIELD | The length of the TLP does not match the length field.                                   |
| TX_TLP_EI_CORRUPT_ECRC         | The end-to-end cyclic redundancy check value is corrupted.                               |
| TX_TLP_EI_CORRUPT_FIRST_DW_BE  | The first DW BE is set to a reserved/illegal value.                                      |
| TX_TLP_EI_CORRUPT_LAST_DW_BE   | The last DW BE is set to a reserved/illegal value.                                       |
| TX_TLP_EI_INVALID_ATTR         | The attribute field is set to a value with is invalid/illegal for the TLP type.          |
| TX_TLP_EI_INVALID_AT           | The AT bit is set to a value which is invalid/illegal for the TLP type.                  |
| TX_TLP_EI_INVALID_TH           | The TH bit is set to a value which is invalid/illegal for the TLP type.                  |
| TX_TLP_EI_MALFORMED            | The TLP is malformed in some other way not specified by the above error injection codes. |
| TX_TLP_EI_IGNORE_CREDIT        | Credits are ignored.                                                                     |
| TX_TLP_EI_MISSING_START        | Missing START.                                                                           |

Transaction Layer <-> Data Link Layer interface tasks are described in [Table 4-10](#).

**Table 4-10 Transaction Layer – Data Link Layer interface tasks**

| <b>Task Name</b>                                                                                                                                                        | <b>Arguments</b> | <b>I/O</b> | <b>Values</b>                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| TransmitTLP<br><br>Task pair called with task of same name in Data Link Layer. Used to send TLPs.                                                                       | tlp_ptr(32)      | O          | Pointer of the TLP to be sent.                                                                                                                    |
|                                                                                                                                                                         | tlp_len(32)      | O          | Length of the data buffer containing the TLP in dwords.                                                                                           |
|                                                                                                                                                                         | tlp_ei_code(32)  | O          | Error injection code.                                                                                                                             |
|                                                                                                                                                                         | req              | O          | Request from application layer to Transaction Layer                                                                                               |
|                                                                                                                                                                         | ack              | I          | Acknowledgement that Transaction Layer has accepted the transmission request from the application.                                                |
| ReceiveTLP<br><br>Task pair called with task of same name in Data Link Layer. Used to receive TLPs.                                                                     | tlp_vh           | O          |                                                                                                                                                   |
|                                                                                                                                                                         | tlp_vc           | O          |                                                                                                                                                   |
|                                                                                                                                                                         | tlp_ptr(32)      | I          | Pointer to the sent TLP.                                                                                                                          |
|                                                                                                                                                                         | tlp_len(32)      | I          | Length of the sent TLP buffer in dwords.                                                                                                          |
|                                                                                                                                                                         | ei_code(32)      | I          | Error injection code. No EI codes defined for receive side.                                                                                       |
|                                                                                                                                                                         | Req              | I          | Request to from Transaction Layer to application layer to pass TLP contents.                                                                      |
|                                                                                                                                                                         | Ack              | O          | Acknowledgement that TLP contents have been accepted by the application layer.                                                                    |
| TransmitCredits<br><br>Task pair called with task of same name in Data Link Layer. Used to send Credits.<br><br>Instruct the link to send an UpdateFCP or InitFCP DLLP. | vh(32)           | O          | Virtual hierarchy to send DLLP to.                                                                                                                |
|                                                                                                                                                                         | vc(32)           | O          | Virtual channel to send DLLP to.                                                                                                                  |
|                                                                                                                                                                         | credit_type(32)  | O          | update_type[1:0] == 2'b00 means P update<br>update_type[1:0] == 2'b01 means Non-Posted update<br>update_type[1:0] == 2'b10 means Completion type. |
|                                                                                                                                                                         | hdr_credits(32)  | O          | Number of header credits sent                                                                                                                     |
|                                                                                                                                                                         | data_credits(32) | O          | Number of data credits sent                                                                                                                       |
|                                                                                                                                                                         | credit_is_init   | O          | This is the first credits sent. Will be use in FC Initialization process.                                                                         |
|                                                                                                                                                                         | req(1)           | O          | Request to link                                                                                                                                   |
|                                                                                                                                                                         | ack(1)           | I          | Acknowledgement from link that request was accepted.                                                                                              |

**Table 4-10 Transaction Layer – Data Link Layer interface tasks (Continued)**

| Task Name                                                                                                                       | Arguments        | I/O | Values                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| ReceiveCredits<br><br>Task pair called with task of same name in Data Link Layer. Used to receive credits from Data Link Layer. | vh(32)           | I   | Virtual hierarchy DLLP sent on.                                                                                                                   |
|                                                                                                                                 | vc(32)           | I   | Virtual channel DLLP sent on.                                                                                                                     |
|                                                                                                                                 | credit_type(32)  | I   | update_type[1:0] == 2'b00 means P update<br>update_type[1:0] == 2'b01 means Non-Posted update<br>update_type[1:0] == 2'b10 means Completion type. |
|                                                                                                                                 | hdr_credits(32)  | I   | Number of header credits sent                                                                                                                     |
|                                                                                                                                 | data_credits(32) | I   | Number of data credits sent                                                                                                                       |
|                                                                                                                                 | credit_is_init   | I   | This is the first credits sent. These are initialization credits.                                                                                 |
|                                                                                                                                 | req(1)           | I   | Request to link                                                                                                                                   |
|                                                                                                                                 | ack(1)           | O   | Acknowledgement from link that request was accepted.                                                                                              |



# 5 Data Link Layer

The Data Link Layer accepts TLPs from the Transaction Layer and schedules them for transmission., as well as conveying transmitted TLPs to the Transaction Layer. It is also responsible for sourcing and sinking DLLPs. TLPs can be copied to a scoreboard via SentTLP and SentTLP tasks.

## 5.1 Date Link Layer Module I/Os

I/Os of the Data Link Layer module are listed in [Table 5-1](#).

**Table 5-1 Data Link Layer module I/Os**

| Name         | I/O    | Description                                                                                                                                                                                                                                                                           |
|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| reset        | I (1)  | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.                                                                                                                                                                                              |
| link_width   | I (32) | Link width from Phy                                                                                                                                                                                                                                                                   |
| phy_status   | I (32) | Bit definitions (use predefined bit parms for access)<br>[0] = link_up.<br>[1] = phy in recovery                                                                                                                                                                                      |
| freq_select  | I (32) | Frequency select from Phy                                                                                                                                                                                                                                                             |
| dl_status    | O (32) | Bit definitions (use predefined bit parms 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 |
| retrain_link | O (1)  | Instruction from the Data Link Layer to the Physical Layer that it needs to retrain the phy.<br>Each bit corresponds to a link.                                                                                                                                                       |

## 5.2 Data Link Layer Configuration Tasks

Data Link Layer configuration tasks are listed in [Table 5-2](#).

**Table 5-2 Data Link Layer configuration tasks**

| Task Name                                                                                                                                    | Arguments | I/O | Values                      |
|----------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|-----------------------------|
| SetLinkEnable<br><br>This task enables the Data Link Layer. The Data Link Layer will automatically initiate VC0 InitFC process when enabled. | enable(1) | I   | Set to 1 to enable the link |

## 5.3 Data Link Layer User Tasks

Data Link Layer user tasks are listed in [Table 5-3](#).

**Table 5-3 User Specific – Link Interface**

| Task Name                                                                                                                               | Arguments (length) | I/O | Values                                                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IsDataLinkIdle<br><br>This task should be called at the end of each test. Returns 1 if all queues are empty and no EIs are in progress. | result5            | O   | Returns 1 if no TLP or DLLP requests pending.                                                                                                                            |
| DisplayStats<br><br>Displays all stats in Data Link Layer.                                                                              | none               |     | Displays all stats in Data Link Layer                                                                                                                                    |
| ClearStats<br><br>Clears all stats in Data Link Layer.                                                                                  | none               |     | Clear all stats in Data Link Layer                                                                                                                                       |
| TransmitUserDLLP<br><br>Allows user to send DLLPs.                                                                                      | user_data (32)     | I   | Unframed DLLP                                                                                                                                                            |
|                                                                                                                                         | user_ei_code (32)  | I   | Error injection code                                                                                                                                                     |
|                                                                                                                                         | valid              | I   | Request from Vendor logic to Data Link Layer.                                                                                                                            |
|                                                                                                                                         | block              | I   | 1 = Task will not return until DLLP has been transmitted.<br>0 = DLLP will be posted to a queue which will schedule DLLP for transmission. Task will return immediately. |
| ReceiveVendorDLLP<br><br>Allows user to pick up incoming vendor specific DLLPs.                                                         | vendor_data (24)   | O   |                                                                                                                                                                          |
|                                                                                                                                         | vendor_vc (32)     | O   | Virtual channel number.                                                                                                                                                  |
|                                                                                                                                         | vendor_status (32) | I   | Receive status                                                                                                                                                           |
|                                                                                                                                         | req                | O   | Request from Data Link Layer to Vendor logic.                                                                                                                            |
|                                                                                                                                         | ack                | I   | Acknowledgement that vendor logic has accepted the receive request from the Data Link.                                                                                   |

**Table 5-3 User Specific – Link Interface (Continued)**

| Task Name                                                                                                                                                                                                                                                                                           | Arguments (length)                                                                                            | I/O                                   | Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SentTLP<br><br>Scoreboard interface. If enabled via SENT_TLP_INTERFACE_MODE, all TLPs sent by Data Link Layer will be queued and accessed via this task.<br><br>event_sent_tlp can be used to wait for valid TLPs to be queued. See “ <a href="#">Data Link Layer Events</a> ”.                     | ptr (32)<br><br>len (32)<br><br>seq_num (32)<br><br>lcrc (32)<br><br>ei_cod (32)<br><br>transmit_status (32)  | O<br><br>O<br><br>O<br><br>O<br><br>O | Pointer to TLP stored in memory.<br>NOTE: This pointer must be freed by the user to avoid memory leakage. See the FreeMemory task description in “ <a href="#">Memory Model Utility</a> ”.<br>Length of TLP stored in memory in dwords.<br>Bits [11:0] – Sequence number of TLP<br>LCRC of sent TLP<br>Error Injection code of TLP sent. See “ <a href="#">Data Link Layer Transmit TLP Error Injection</a> ” for a list of the codes.<br>Status of the sent TLP.<br>SENT_TLP_STATUS_GOOD_BIT is asserted for each TLP DUT is expected to forward to the TL. Any other bit asserted Indicates VIP Data Link Layer injected error. The TLP with errors must be dropped by the DUT. Dropped TLPs may be retried by VIP.<br>See Include/pciesvc_parms.v for bit definitions SENT_TLP_STATUS_*_BIT.<br>Pointer is valid |
| ReceivedTLP<br><br>Scoreboard interface. If enabled via RECEIVED_TLP_INTERFACE_MODE, all TLPs received by the Data Link Layer will be queued and accessed via this task.<br><br>event_received_tlp can be used to wait for valid TLPs to be queued. See “ <a href="#">Data Link Layer Events</a> ”. | ptr (32)<br><br>len (32)<br><br>seq_num (32)<br><br>lcrc (32)<br><br>ei_code (32)<br><br>received_status (32) | O<br><br>O<br><br>O<br><br>O<br><br>O | Pointer to TLP stored in memory.<br>NOTE: This pointer must be freed by the user to avoid memory leakage. See the FreeMemory task description in “ <a href="#">Memory Model Utility</a> ”.<br>Length of TLP stored in memory in dwords.<br>Bits [11:0] – Sequence number of TLP<br>LCRC of received TLP<br>Error Injection code of TLP received. “ <a href="#">Data Link Layer Transmit TLP Error Injection</a> ” for a list of the codes.<br>Status of the received TLP.<br>RECEIVED_TLP_STATUS_GOOD_BIT is asserted for each TLP VIP forwards to the TL. Any other bit asserted Indicates TLP was received with error. TLPs with errors will be dropped, but possible retried by DUT.<br>See Include/pciesvc_parms.v for bit definitions RECEIVED_TLP_STATUS_*_BIT.<br>Pointer is valid.                          |

**Table 5-3 User Specific – Link Interface (Continued)**

| Task Name                                                                                                                                                                                                                                                                                                              | Arguments (length)   | I/O | Values                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SentDLLP<br><br>Scoreboard interface. If enabled via SENT_DLLP_INTERFACE_MODE, all DLLPs sent by the Data Link LayerData Link Layerwill be queued and accessed via this task.<br><br>event_sent_dllp can be used to wait for valid DLLPs to be queued. See “ <a href="#">Data Link Layer Events</a> ”.                 | ptr (32)             | O   | Pointer to DLLP stored in memory.<br>NOTE: This pointer must be freed by the user to avoid memory leakage. See the FreeMemory task description in “ <a href="#">Memory Model Utility</a> ”. |
|                                                                                                                                                                                                                                                                                                                        | len (32)             | O   | Length of DLLP stored in memory in dwords.                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                        | ei_code (32)         | O   | Error Injection code of DLLP sent. See “ <a href="#">Data Link Layer Transmit DLLP Error Injection</a> ” for a list of the codes.                                                           |
|                                                                                                                                                                                                                                                                                                                        | transmit_status (32) | O   | Status of the sent DLLP. See Include/pciesvc_parms.v for bit definitions SENT_DLLP_STATUS_*_BIT.                                                                                            |
|                                                                                                                                                                                                                                                                                                                        | valid (1)            | O   | Pointer is valid.                                                                                                                                                                           |
| ReceivedDLLP<br><br>Scoreboard interface. If enabled via RECEIVED_DLLP_INTERFACE_MODE, all DLLPs received by the Data Link LayerData Link Layerwill be queued and accessed via this task.<br><br>event_received_dllp can be used to wait for valid DLLPs to be queued. See “ <a href="#">Data Link Layer Events</a> ”. | ptr (32)             | O   | Pointer to DLLP stored in memory.<br>NOTE: This pointer must be freed by the user to avoid memory leakage. See the FreeMemory task description in “ <a href="#">Memory Model Utility</a> ”. |
|                                                                                                                                                                                                                                                                                                                        | len (32)             | O   | Length of DLLP stored in memory in dwords.                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                        | ei_code(32)          | O   | Error Injection code of DLLP sent. See “ <a href="#">Data Link Layer Transmit DLLP Error Injection</a> ” for a list of the codes.                                                           |
|                                                                                                                                                                                                                                                                                                                        | receive_status (32)  | O   | Status of the received DLLP. See Include/pciesvc_parms.v for bit definitions RECEIVED_DLLP_STATUS_*_BIT.                                                                                    |
|                                                                                                                                                                                                                                                                                                                        | valid (1)            | O   | Pointer is valid                                                                                                                                                                            |
| SetReplayTimeout<br><br>Replay timer limit will be automatically updated per spec Table “Unadjusted Replay Timer Limits” each time either link_width, freq_select, or MAX_PAYLOAD_SIZE_VAR changes unless this task is called.                                                                                         | value (32)           | I   | Length of the replay timer in symbols. If called, timeout value is sticky. Setting to value = 0 will enable automatic updates.                                                              |
| SetAttachedReplayTimeout<br><br>Attached Replay timer limit will be automatically updated per spec, Table “Unadjusted Replay Timer Limits”, each time either link_width, freq_select, or MAX_PAYLOAD_SIZE_VAR changes unless this task is called.                                                                      | value (32)           | I   | Length of the attached replay timer in symbols. Used to check the DUT’s replay timer. Setting value = 0 will enable automatic updates if MAX_PAYLOAD_SIZE_VAR, link_width, or speed change. |

**Table 5-3 User Specific – Link Interface (Continued)**

| <b>Task Name</b>                                                                                                                                                                                                                                   | <b>Arguments (length)</b> | <b>I/O</b> | <b>Values</b>                                                                                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetAttachedReplayTimeoutTolerance<br><br>Used to set tolerances for checking replay timer of DUT.                                                                                                                                                  | value (32)                | I          | Number of symbols in which retry may be received after a timeout. This should account for clock domain crossings, ACK processing variances, etc.                                                                                 |
|                                                                                                                                                                                                                                                    | link_width (32)           | I          | Link width value pertains to. Each link width can have a different value.                                                                                                                                                        |
| SetMaxAckNakLatency<br><br>AckNak Latency timer will be automatically updated per spec, Table “Ack Transmit Latency Limit”, each time either link_width, freq_select, or MAX_PAYLOAD_SIZE_VAR changes unless this task is called.                  | value (32)                | I          | Max length of the ACK/NAK latency timer in symbols. If called, value is sticky. Setting to value = 0 will enable automatic updates.                                                                                              |
| SetMinAckNakLatency                                                                                                                                                                                                                                | value (32)                | I          | Min Length of the ACK/NAK latency timer in symbols. This value is not automatically updated, and defaults to 0.                                                                                                                  |
| SetMaxAttachedAckNakLatency<br><br>Attached AckNak Latency timer will be automatically updated per spec, Table “Ack Transmit Latency Limit”, each time either link_width, freq_select, or MAX_PAYLOAD_SIZE_VAR changes unless this task is called. | value (32)                | I          | Max length of the attached ACK/NAK latency timer in symbols. Used to check DUT's AckNak latency timer. If called, value is sticky. Setting value = 0 will enable automatic updates if MAX_PAYLOAD_SIZE_VAR or link_width change. |
| SetMinAttachedAckNakLatency<br><br>Used to check DUT's AckNak latency timer.                                                                                                                                                                       | value (32)                | I          | Min length of the attached ACK/NAK latency timer in symbols. Default value = 0.                                                                                                                                                  |
| SetAttachedAckNakLatencyTolerance<br><br>Used to set tolerances for checking AckNak latency timer of DUT.                                                                                                                                          | value (32)                | I          | Variance in number of symbols in which ACK may be received. This should account for clock domain crossings, TLP processing variances, etc.                                                                                       |
|                                                                                                                                                                                                                                                    | link_width (32)           | I          | Link width value pertains to. Each link width can have a different value.                                                                                                                                                        |
| SetMaxAttachedNakLatency<br><br>NAK latency limit will be automatically updated per spec, internal delay, each time either link_width, freq_select, or MAX_PAYLOAD_SIZE_VAR changes unless this task is called.                                    | value (32)                | I          | Max NAK latency limit in symbols. Used to check DUT's NAK latency. If called, value is sticky. Setting to value = 0 will enable automatic updates.                                                                               |

**Table 5-3 User Specific – Link Interface (Continued)**

| <b>Task Name</b>                                                                                                                                    | <b>Arguments (length)</b> | <b>I/O</b> | <b>Values</b>                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------|-----------------------------------------------------------------------------------------------------------------|
| SetAckFactor<br><br>Used to update AckFactor table entries listed in spec. Values used to automatically set replay timer and AckNak latency values. | max_payload_size          | I          | Possible value, power of 2: 128, 256, 512, 1024, 2048, 4096.                                                    |
|                                                                                                                                                     | freq_select               | I          |                                                                                                                 |
|                                                                                                                                                     | link_width                | I          | Possible value: 1,2,4,8,12,16,32.                                                                               |
|                                                                                                                                                     | value                     | I          |                                                                                                                 |
| DisplayAttachedReplayTimeoutTolerance s<br><br>Displays replay timer checker tolerances for link widths of 1, 2,4,8,12,16, and 32.                  | n/a                       | n/a        | Displays replay timeout tolerances used to check attached replay timers. Tolerances are per link_width.         |
| DisplayAttachedAckNakLatencyTolerance s<br><br>Displays AckNak Latency checker tolerances for link widths of 1, 2,4,8,12,16, and 32.                | n/a                       | n/a        | Displays AckNak latency tolerances used to check attached AckNak latency timers. Tolerances are per link_width. |
| InitiateASPML0sEntry<br><br>Directs VIP to enter ASPM Tx L0s. Call InitiateASPMExit task to direct VIP back to L0.                                  | n/a                       | n/a        |                                                                                                                 |
| InitiateASPML1Entry<br><br>Directs VIP to enter ASPM L1. Call InitiateASPMExit task to direct VIP back to L0.                                       | n/a                       | n/a        | ENABLE_ASMP_L1_ENTRY must be enabled to enter L1.                                                               |
| InitiatePML1Entry<br><br>Directs VIP to enter PM L1. Call InitiatePMExit task to direct VIP back to L0.                                             | n/a                       | n/a        | ENABLE_ASMP_L1_ENTRY must be enabled to enter L1.                                                               |

**Table 5-3 User Specific – Link Interface (Continued)**

| Task Name                                                                                                   | Arguments (length) | I/O | Values                                                                                               |
|-------------------------------------------------------------------------------------------------------------|--------------------|-----|------------------------------------------------------------------------------------------------------|
| InitiatePML23Entry<br><br>Directs VIP to enter PM L2/L3. Call InitiatePMExit task to direct VIP back to L0. | n/a                | n/a |                                                                                                      |
| InitiatePMExit<br><br>Directs VIP to transition back to L0 from PM low power state.                         | block              | I   | If block is set, task returns after low power state is exited. If not set, task returns immediately. |
| InitiateASPMExit<br><br>Directs VIP to transition back to L0 from ASPM low power state.                     | block              | I   | If block is set, task returns after low power state is exited. If not set, task returns immediately. |

## 5.4 Data Link Layer Parameters

Data Link Layer parameters are listed in [Table 5-4](#).

**Table 5-4 Data Link Layer parameters**

| Parameter Name          | Settable VAR?* | Type    | Range                 | Default           | Description                                                                                                                                                                                                                                            |
|-------------------------|----------------|---------|-----------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PCIE_SPEC_VER</b>    |                |         |                       |                   |                                                                                                                                                                                                                                                        |
|                         | Yes            | Real    | 1.1, 2.0, 2.1,<br>3.0 | PCIE_SPEC_VER_2_1 | See Include/pciesvc_parms.v:<br>PCIE_SPEC_VER_*<br>Note: Please set this in the model.                                                                                                                                                                 |
| <b>MAX_PAYLOAD_SIZE</b> |                |         |                       |                   |                                                                                                                                                                                                                                                        |
|                         | Yes            | Integer | $2^x$<br>$x = 7-12$   | 128 bytes         | Set replay timer and AckNak Latency timers per spec Tables “Unadjusted Replay Timer Limits” and “Ack Transmit Latency Limit”. Also used to check the DUT’s replay and AckNak Latency timers. Must match the Max_Payload_Size in DUT’s config register. |
| <b>MAX_NUM_REPLAYS</b>  |                |         |                       |                   |                                                                                                                                                                                                                                                        |
|                         | Yes            | Integer | 3-5                   | 3                 | Maximum number of replays before the link gives up on transmitting a TLP                                                                                                                                                                               |
| <b>MIN_NAK_LATENCY</b>  |                |         |                       |                   |                                                                                                                                                                                                                                                        |
|                         | Yes            | Integer | 0 - large value       | 0 ns              | Minimum latency until a NAK is issued                                                                                                                                                                                                                  |
| <b>MAX_NAK_LATENCY</b>  |                |         |                       |                   |                                                                                                                                                                                                                                                        |
|                         | Yes            | Integer | 0 - large value       | 30 ns             | The maximum latency before a NAK is issued                                                                                                                                                                                                             |

**Table 5-4 Data Link Layer parameters (Continued)**

| Parameter Name                      | Settable VAR?* | Type    | Range             | Default | Description                                                                                                                                                                                   |
|-------------------------------------|----------------|---------|-------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MIN_INITFC_DELAY</b>             |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 0 - large value   | 0 ns    | Minimum interval between InitFC DLLPs. Used to model delays to due media access. Value should be relatively small.                                                                            |
| <b>MAX_INITFC_DELAY</b>             |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 0 - large value   | 10 ns   | Maximum interval between InitFC DLLPs. Used to model delays to due media access. Value should be relatively small.                                                                            |
| <b>MIN_UPDATEFC_DELAY</b>           |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 0 - large value   | 1       | Minimum interval between UpdateFC DLLPs. Used to model delays to due media access. Value should be relatively small.                                                                          |
| <b>MAX_UPDATEFC_DELAY</b>           |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 0 - large value   | 100     | Maximum interval between UpdateFC DLLPs. Used to model delays to due media access. Value should be relatively small.                                                                          |
| <b>MIN_TX_IPG</b>                   |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 0 - large value   | 0       | Min gap between packets (TLPs and/or DLLPs) as measured in symbol times.<br>0 = packets can be packed in same symbol.<br>1 = packets will always start on lane 0 in symbol following END/EDB. |
| <b>MAX_TX_IPG</b>                   |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 0 - large value   | 1       | Max gap between packets (TLPs and/or DLLPs) as measured in symbol times.                                                                                                                      |
| <b>INITFC_TIMEOUT_NS</b>            |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 1us - large value | 34us    | Maximum time between receiving all 3 types (P, NP, CPL) of InitFC DLLPs. VIP will issue NOTICE if timeout value is exceeded.                                                                  |
| <b>UPDATEFC_TIMEOUT_NS</b>          |                |         |                   |         |                                                                                                                                                                                               |
|                                     | Yes            | Integer | 1us -large value  | 30us    | Maximum time between receiving UpdateFC DLLPs. Timeout is tracked per VC/Type. VIP will issue NOTICE if timeout value is exceeded.                                                            |
| <b>MAX_NUM_RETRY_BUFFER_DWORDS</b>  |                |         |                   |         |                                                                                                                                                                                               |
|                                     | No             | Integer | 16-2^16           | 4096    | Maximum number of dwords the retry buffer can hold before it backpressures the Transaction Layer.                                                                                             |
| <b>VC[0-7]_UPDATEFC_INTERVAL_NS</b> |                |         |                   |         |                                                                                                                                                                                               |

**Table 5-4 Data Link Layer parameters (Continued)**

| <b>Parameter Name</b>                       | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>     | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                             |
|---------------------------------------------|-----------------------|-------------|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             | Yes                   | Integer     | 500 -large value | 30,000         | If credits for a VC have not been sent to the link partner for this interval, all 3 types of credits will be scheduled for transmission. Setting to 0 disables scheduling credits. This should be set to 0 for most testing as periodic updates could mask credits being lost. |
| <b>INITIAL_TRANSMIT_SEQUENCE_VALUE</b>      |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | 0-4095           | 0              | The first TLP will be transmitted with this value. Used to check rollover at 4096                                                                                                                                                                                              |
| <b>INITIAL_RECEIVE_SEQUENCE_VALUE</b>       |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | 0-4095           | 0              | The first TLP sent must have this sequence number                                                                                                                                                                                                                              |
| <b>SENT_TLP_INTERFACE_MODE</b>              |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | See Description  | 1              | Mode for queuing TLPs for SentTLP task. Bits are defined in Include/pciesvc_parms.v as SENT_TLP_INTERFACE_MODE_*_BIT                                                                                                                                                           |
| <b>RECEIVED_TLP_INTERFACE_MODE</b>          |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | See Description  | 0              | Mode for queuing TLPs for ReceivedTLP task. Bits are defined in Include/pciesvc_parms.v as RECEIVED_TLP_INTERFACE_MODE_*_BIT                                                                                                                                                   |
| <b>SENT_DLLP_INTERFACE_MODE</b>             |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | See Description  | 0              | Mode for queuing DLLPs for SentDLLP task. Bits are defined in Include/pciesvc_parms.v as SENT_DLLP_INTERFACE_MODE_*_BIT                                                                                                                                                        |
| <b>RECEIVED_DLLP_INTERFACE_MODE</b>         |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | See Description  | 0              | Mode for queuing DLLPs for ReceivedDLLP task. Bits are defined in Include/pciesvc_parms.v as RECEIVED_DLLP_INTERFACE_MODE_*_BIT                                                                                                                                                |
| <b>PERCENTAGE_TX_TLP_INSTEAD_OF_INITFC2</b> |                       |             |                  |                |                                                                                                                                                                                                                                                                                |
|                                             | Yes                   | Integer     | 0-100            | 0              | Enables sending a TLP to complete flow control initialization instead of sending an INITFC2 DLLP. A TLP must be queued in order for initialization to complete.                                                                                                                |
| <b>INTERNAL_DELAY_2_5G</b>                  |                       |             |                  |                |                                                                                                                                                                                                                                                                                |

**Table 5-4 Data Link Layer parameters (Continued)**

| <b>Parameter Name</b>               | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                   |
|-------------------------------------|-----------------------|-------------|--------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     | Yes                   | Integer     | 1-128        | 10             | Internal delay used in “Ack Transmit Latency Limit” equation for replay timer and AckNak latency timer at 2.5G. Value is expressed in terms of symbol time.                                                                                                                          |
| <b>INTERNAL_DELAY_5G</b>            |                       |             |              |                |                                                                                                                                                                                                                                                                                      |
|                                     | Yes                   | Integer     | 1-128        | 10             | Internal delay used in “Ack Transmit Latency Limit” equation for replay timer and AckNak latency timer at 5G. Value is expressed in terms of symbol time.                                                                                                                            |
| <b>ATTACHED_INTERNAL_DELAY_2_5G</b> |                       |             |              |                |                                                                                                                                                                                                                                                                                      |
|                                     | Yes                   | Integer     | 1-128        | 10             | Internal delay used in “Ack Transmit Latency Limit” equation to check attached replay timer and AckNak latency timer at 2.5G. Accounts for packet processing delay and transmission latency. Value is expressed in terms of symbol time. Value is expressed in terms of symbol time. |
| <b>ATTACHED_INTERNAL_DELAY_5G</b>   |                       |             |              |                |                                                                                                                                                                                                                                                                                      |
|                                     | Yes                   | Integer     | 1-128        | 10             | Internal delay used in “Ack Transmit Latency Limit” equation to check attached replay timer and AckNak latency timer at 5G. Accounts for packet processing delay and transmission latency. Value is expressed in terms of symbol time.                                               |
| <b>MIN_TX_NULLIFIED_TLP_LEN</b>     |                       |             |              |                |                                                                                                                                                                                                                                                                                      |
|                                     | Yes                   | Integer     | 4-1024       | 4              | Minimum nullified TLP length in dwords.                                                                                                                                                                                                                                              |
| <b>MAX_TX_NULLIFIED_TLP_LEN</b>     |                       |             |              |                |                                                                                                                                                                                                                                                                                      |
|                                     | Yes                   | Integer     | 4-1024       | 300            | Maximum nullified TLP length in dwords.                                                                                                                                                                                                                                              |
| <b>TX_NULLIFIED_TLP_HDR0_VALUE</b>  |                       |             |              |                |                                                                                                                                                                                                                                                                                      |
|                                     | Yes                   | Integer     | 0 - 2^32     | 32'H7000_03FF  | The default automatically generated nullified TLP is a MsgD, fatal error message. If the DUT forwards this TLP, it should be flagged by upper layers.                                                                                                                                |
| <b>TX_NULLIFIED_TLP_HDR1_VALUE</b>  |                       |             |              |                |                                                                                                                                                                                                                                                                                      |

**Table 5-4 Data Link Layer parameters (Continued)**

| <b>Parameter Name</b>              | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>       | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                       |
|------------------------------------|-----------------------|-------------|--------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                    | Yes                   | Integer     | 0 - 2^32           | 32'HFFFF_FF33  |                                                                                                                                                                                                                          |
| <b>TX_NULLIFIED_TLP_HDR2_VALUE</b> |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0 - 2^32           | 32'HBAAD_BAAD  |                                                                                                                                                                                                                          |
| <b>TX_NULLIFIED_TLP_HDR3_VALUE</b> |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0 - 2^32           | 32'HDEAD_BEEF  |                                                                                                                                                                                                                          |
| <b>ASPM_TIMEOUT_CNT_LIMIT</b>      |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 1000 - large value | 20000          | If DUT fails to respond to ASPM request handshake for this # symbols, NOTICE will be issued and ASPM entry will be aborted.                                                                                              |
| <b>PM_TIMEOUT_CNT_LIMIT</b>        |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 1000 - large value | 20000          | If DUT fails to respond to PM request handshake for this # symbols, NOTICE will be issued and ASPM entry will be aborted.                                                                                                |
| <b>L0S_IDLE_TIMER_LIMIT_NS</b>     |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 10 - large value   | 0              | 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. |
| <b>ENABLE_ASPM_L1_ENTRY</b>        |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-1                | 0              | This VAR must be set to 1 to enable ASPM L1 entry as requested by the VIP or the DUT.                                                                                                                                    |
| <b>ENABLE_ASPM_L1_1_ENTRY</b>      |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-1                | 0              | This VAR must be set to 1 to enable ASPM L1_1 entry as requested by the VIP or the DUT.                                                                                                                                  |
| <b>ENABLE_ASPM_L1_2_ENTRY</b>      |                       |             |                    |                |                                                                                                                                                                                                                          |
|                                    | Yes                   | Integer     | 0-1                | 0              | This VAR must be set to 1 to enable ASPM L1_2 entry as requested by the VIP or the DUT.                                                                                                                                  |
| <b>ENABLE_PM_L1_1_ENTRY</b>        |                       |             |                    |                |                                                                                                                                                                                                                          |

**Table 5-4 Data Link Layer parameters (Continued)**

| Parameter Name                                                                                                                                                                                                                                                                                                              | Settable VAR?* | Type    | Range    | Default | Description                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0-1      | 0       | This VAR must be set to 1 to enable PM L1_1 entry as requested by the VIP or the DUT.                                                                                                                      |
| <b>ENABLE_PM_L1_2_ENTRY</b>                                                                                                                                                                                                                                                                                                 |                |         |          |         |                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0-1      | 0       | This VAR must be set to 1 to enable PM L1_2 entry as requested by the VIP or the DUT.                                                                                                                      |
| <b>LTR_L1_2_THRESHOLD_VALUE</b>                                                                                                                                                                                                                                                                                             |                |         |          |         |                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0 - 2^16 | 0       | Per spec L1_2 threshold value. ASPM L1_2 will be entered when snoop value*scale /no_snoop value*scale in received LTR msg are greater than this value*scale threshold. Applicable to Downstream port only. |
| <b>LTR_L1_2_THRESHOLD_SCALE</b>                                                                                                                                                                                                                                                                                             |                |         |          |         |                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0 - 2^16 | 0       | Per spec L1_2 threshold scale. ASPM L1_2 will be entered when snoop value*scale /no_snoop value*scale in received LTR msg are greater than this value*scale threshold. Applicable to Downstream port only. |
| <b>ENABLE_EI_TX_TLP_ON_RETRY</b>                                                                                                                                                                                                                                                                                            |                |         |          |         |                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0-1      | 1       | If enabled, EI will be inserted on retries in addition to the first transmit attempt. If not enabled, EI will be inserted only on the first transmit attempt.                                              |
| <b>ENABLE_TRANSACTION_LOG</b>                                                                                                                                                                                                                                                                                               |                |         |          |         |                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0-1      | 1       | If enabled (and the transaction logger has been enabled via <i>msglog_control</i> , see below) transactions will be written to the transaction log.                                                        |
| <b>ENABLE_TX_TLP_REPORTING</b>                                                                                                                                                                                                                                                                                              |                |         |          |         |                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes            | Integer | 0-1      | 1       | If enabled, transmitted TLPs will be reported to the global shadow memory.<br>Make sure this is not enabled if the shadow memory is not instantiated.                                                      |
| *Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with "_VAR". This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module. |                |         |          |         |                                                                                                                                                                                                            |

## 5.5 Data Link Layer Events

Types of Data Link Layer events are listed in [Table 5-5](#).

**Table 5-5 Data Link Layer events**

| <b>Event Name</b>              | <b>Description</b>                                                                                                                                                                                                                                                                                       |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| event_sent_dllp                | DLLP was sent.                                                                                                                                                                                                                                                                                           |
| event_sent_user_dllp           | DLLP was sent via the user interface                                                                                                                                                                                                                                                                     |
| event_received_dllp            | DLLP was received. Can be used in conjunction with ReceivedDLLP task to indicate a DLLP is available.                                                                                                                                                                                                    |
| event_sent_tlp                 | TLP was sent. Can be used in conjunction with SentTLP task to indicate a TLP is available.                                                                                                                                                                                                               |
| event_received_tlp             | TLP was received. Can be used in conjunction with ReceivedTLP task to indicate a TLP is available.                                                                                                                                                                                                       |
| event_send_tlp                 | Event triggered when any TLP is sent.                                                                                                                                                                                                                                                                    |
| event_send_dllp                | Event triggered when any DLLP is sent.                                                                                                                                                                                                                                                                   |
| event_receive_tlp              | Event triggered when any TLP is received.                                                                                                                                                                                                                                                                |
| event_receive_dllp             | Event triggered when any DLLP is received                                                                                                                                                                                                                                                                |
| event_send_pm_active_state_nak | Event triggered when an PM_ACTIVE_STATE_NAK TLP needs to be sent to the link partner.<br>The PM_ACTIVE_STATE_NAK TLP transmission will need to be initiated by the test case via the driver application or the TL user interface                                                                         |
| event_rx_active_state_nak      | Event triggered when an PM_ACTIVE_STATE_NAK TLP is received. If the enable_auto_aspm_l1_req_termination configuration variable is set, the DL will automatically terminate the PM handshake. If not set, the test case will need to terminate the PM handshake via InitiatePMExit() or by sending a TLP. |

## 5.6 Data Link Layer ASCII Signals

ASCII signals on the Data Link Layer are listed in Table 5-6.

**Table 5-6 Data Link Layer ASCII signals**

| <b>Signal Name</b>              | <b>Description</b>                                |
|---------------------------------|---------------------------------------------------|
| 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.                    |
| ascii_rx_tlp_type               | Received TLP type, defined by {fmt, type} fields. |

**Table 5-6 Data Link Layer ASCII signals (Continued)**

| Signal Name                     | Description                                 |
|---------------------------------|---------------------------------------------|
| 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]_fcsdm_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                     |

## 5.7 Data Link Layer Statistics

Types of Data Link Layer statistics are listed in [Table 5-7](#).

**Table 5-7 Data Link Layer statistics**

| Stat Name                       | Width | Description                                     |
|---------------------------------|-------|-------------------------------------------------|
| stat_num_tlp_sent               | 32    | Number of TLPs sent by the link                 |
| stat_num_tlp_received           | 32    | Number of TLPs received by the link             |
| stat_num_good_tlp_sent          | 32    | Number of TLPs sent without error               |
| stat_num_good_tlp_received      | 32    | Number of TLPs received without error           |
| stat_num_bad_tlp_sent           | 32    | Number of TLPs sent with error                  |
| stat_num_bad_tlp_received       | 32    | Number of TLPs received with error              |
| stat_num_good_retries_sent      | 32    | Number of retry TLPs sent without error         |
| stat_num_bad_retries_sent       | 32    | Number of retry TLPs sent with error            |
| stat_num_nullified_tlp_received | 32    | Number of nullified TLPs received without error |
| stat_num_dllp_sent              | 32    | Number of DLLPs sent by the link                |
| stat_num_dllp_received          | 32    | Number of DLLPs received by the link            |
| stat_num_good_dllp_sent         | 32    | Number of DLLPs sent without error              |
| stat_num_good_dllp_received     | 32    | Number of DLLPs received without error          |
| stat_num_bad_dllp_sent          | 32    | Number of DLLPs sent with error                 |

**Table 5-7 Data Link Layer statistics (Continued)**

| <b>Stat Name</b>                       | <b>Width</b> | <b>Description</b>                                                                    |
|----------------------------------------|--------------|---------------------------------------------------------------------------------------|
| stat_num_bad_dllp_received             | 32           | Number of DLLPs received with error                                                   |
| stat_num_retries_sent                  | 32           | Number of packets that had to be retransmitted                                        |
| stat_num_phy_retrain                   | 32           | Number of times the link was retrained due to the replay attempt counter rolling over |
| stat_num_ack_sent                      | 32           | Number of ACK DLLPs sent                                                              |
| stat_num_ack_received                  | 32           | Number of ACK DLLPs received                                                          |
| stat_num_nak_sent                      | 32           | Number of NAK DLLPs sent                                                              |
| stat_num_nak_received                  | 32           | Number of NAK DLLPs received                                                          |
| stat_num_retries_due_to_replay_timeout | 32           | Number of retried packets due to replay timeout                                       |
| stat_num_retries_due_to_nak            | 32           | Number of retried packets due to a NAK                                                |
| stat_num_duplicate_tlp_received        | 32           | Number of received TLPs with the same sequence number                                 |
| stat_num_out_of_order_tlp_received     | 32           | Number of TLPs received with out of order sequence numbers                            |
| stat_num_vc#_updatefc_received         | 32           | Number of UpdateFC DLLPs received on VC#                                              |
| stat_num_vc#_p_updatefc_received       | 32           | Number of UpdateFC P DLLPs received on VC#                                            |
| stat_num_vc#_np_updatefc_received      | 32           | Number of UpdateFC NP DLLPs received on VC#                                           |
| stat_num_vc#_cpl_updatefc_received     | 32           | Number of UpdateFC CPL DLLPs received on VC#                                          |
| stat_num_vc#_updatefc_sent             | 32           | Number of UpdateFC DLLPs sent on VC#                                                  |
| stat_num_vc#_p_updatefc_sent           | 32           | Number of UpdateFC P DLLPs sent on VC#                                                |
| stat_num_vc#_np_updatefc_sent          | 32           | Number of UpdateFC NP DLLPs sent on VC#                                               |
| stat_num_vc#_cpl_updatefc_sent         | 32           | Number of UpdateFC CPL DLLPs sent on VC#                                              |
| stat_num_vc#_initfc1_received          | 32           | Number of InitFC1 DLLPs received on VC#                                               |
| stat_num_vc#_initfc1_p_received        | 32           | Number of InitFC1 P DLLPs received on VC#                                             |
| stat_num_vc#_initfc1_np_received       | 32           | Number of InitFC1 NP DLLPs received on VC#                                            |
| stat_num_vc#_initfc1_cpl_received      | 32           | Number of InitFC1 CPL DLLPs received on VC#                                           |
| stat_num_vc#_initfc1_sent              | 32           | Number of InitFC1 DLLPs sent on VC#                                                   |
| stat_num_vc#_initfc1_p_sent            | 32           | Number of InitFC1 P DLLPs sent on VC#                                                 |
| stat_num_vc#_initfc1_np_sent           | 32           | Number of InitFC1 NP DLLPs sent on VC#                                                |
| stat_num_vc#_initfc1_cpl_sent          | 32           | Number of InitFC1 CPL DLLPs sent on VC#                                               |
| stat_num_vc#_initfc2_received          | 32           | Number of InitFC2 DLLPs received on VC#                                               |
| stat_num_vc#_initfc2_p_received        | 32           | Number of InitFC2 P DLLPs received on VC#                                             |
| stat_num_vc#_initfc2_np_received       | 32           | Number of InitFC2 NP DLLPs received on VC#                                            |
| stat_num_vc#_initfc2_cpl_received      | 32           | Number of InitFC2 CPL DLLPs received on VC#                                           |
| stat_num_vc#_initfc2_sent              | 32           | Number of InitFC2 DLLPs sent on VC#                                                   |

**Table 5-7 Data Link Layer statistics (Continued)**

| <b>Stat Name</b>                            | <b>Width</b> | <b>Description</b>                                                                                                                                |
|---------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_num_vc#_initfc2_p_sent                 | 32           | Number of InitFC2 P DLLPs sent on VC#                                                                                                             |
| stat_num_vc#_initfc2_np_sent                | 32           | Number of InitFC2 NP DLLPs sent on VC#                                                                                                            |
| stat_num_vc#_initfc2_cpl_sent               | 32           | Number of InitFC2 CPL DLLPs sent on VC#                                                                                                           |
| stat_num_vendor_dllp_received               | 32           | Number of vendor specific DLLPs received                                                                                                          |
| stat_num_vendor_dllp_sent                   | 32           | Number of vendor specific DLLPs sent                                                                                                              |
| stat_num_phy_link_down_events               | 32           | Number of times the LTSSM reported link down dropping                                                                                             |
| stat_num_ei_tx_tlp_corrupt_lcrc             | 32           | Number of times the corrupt LCRC EI was injected                                                                                                  |
| stat_num_ei_tx_tlp_illegal_seq_number       | 32           | Number of times the illegal sequence number EI was injected. Illegal sequence number is: (seq_num + 1) % 4096 thru (seq_num + 2047) % 4096        |
| stat_num_ei_tx_tlp_duplicate_seq_number     | 32           | Number of times the duplicate sequence number EI was injected. Duplicate sequence number is: (seq_num + 2048) % 4096 thru (seq_num + 4095) % 4096 |
| stat_num_ei_tx_tlp_nullified                | 32           | Number of times the nullify TLP EI was injected                                                                                                   |
| stat_num_ei_tx_tlp_nullified_good_lcrc      | 32           | Number of times the nullify good TLP EI was injected                                                                                              |
| stat_num_ei_tx_tlp_nullified_corrupt_lcrc   | 32           | Number of times the nullify corrupt lcrc TLP EI was injected                                                                                      |
| stat_num_ei_tx_tlp_corrupt_disparity        | 32           | Number of times the corrupt disparity EI was injected during a TLP                                                                                |
| stat_num_ei_tx_tlp_missing_start            | 32           | Number of times the missing start delimiter EI was injected during a TLP                                                                          |
| stat_num_ei_tx_tlp_missing_end              | 32           | Number of times the missing end delimiter EI was injected during a TLP                                                                            |
| stat_num_ei_tx_tlp_bit_flip                 | 32           | Number of times the bit flip EI was injected during a TLP                                                                                         |
| stat_num_ei_tx_tlp_codeViolation            | 32           | Number of times the code violation EI was injected during a TLP                                                                                   |
| stat_num_ei_tx_tlp_scrambler_error          | 32           | Number of times the scrambler error EI was injected during a TLP                                                                                  |
| stat_num_ei_tx_tlp_8g_corrupt_header_crc    | 32           | Number of times the corrupt STP token header FCRC EI was injected during a TLP in 8G mode.                                                        |
| stat_num_ei_tx_tlp_8g_corrupt_header_parity | 32           | Number of times the corrupt STP token header parity EI was injected during a TLP in 8G mode.                                                      |
| stat_num_ei_tx_dllp_corrupt_crc             | 32           | Number of times the transmit DLLP corrupt CRC EI was injected                                                                                     |
| stat_num_ei_tx_dllp_unknown_type            | 32           | Number of times the unknown DLLP type was injected                                                                                                |
| stat_num_ei_tx_dllp_rsvd_non_zero           | 32           | Number of times the EI where reserved fields are nonzero was injected                                                                             |
| stat_num_ei_tx_dllp_duplicate_ack           | 32           | Number of times the EI duplicate ACKs was injected                                                                                                |

**Table 5-7 Data Link Layer statistics (Continued)**

| Stat Name                                 | Width | Description                                                                            |
|-------------------------------------------|-------|----------------------------------------------------------------------------------------|
| stat_num_ei_tx_dllp_corrupt_disparity     | 32    | Number of times the corrupt disparity EI was injected during a DLLP                    |
| stat_num_ei_tx_dllp_bit_flip              | 32    | Number of times the bit flip EI was injected during a DLLP                             |
| stat_num_ei_tx_dllp_missing_start         | 32    | Number of times the missing start delimiter EI was injected during a DLLP              |
| stat_num_ei_tx_dllp_missing_end           | 32    | Number of times the missing end delimiter EI was injected during a DLLP                |
| stat_num_ei_tx_dllp_codeViolation         | 32    | Number of times the code violation EI was injected during a DLLP                       |
| stat_num_ei_tx_dllp_scrambler_error       | 32    | Number of times the scrambler error EI was injected during a DLLP                      |
| stat_num_ei_tx_dllp_8g_corrupt_header     | 32    | Number of times the corrupt SDP token header EI was injected during a DLLP in 8G mode. |
| stat_num_ei_rx_tlp_withhold_ack_nak       | 32    | Number of times ACK/NAK was withheld from transmission following reception of a TLP    |
| stat_num_ei_rx_tlp_nak_good_tlp           | 32    | Number of times the NAK good TLPs EI was injected                                      |
| stat_num_ei_tx_replay_count_failure       | 32    | Number of times the replay count failure EI was injected                               |
| stat_num_ei_rx_ignore_dllp_ack            | 32    | Number of times the sent ACK NAK suppress EI was injected                              |
| stat_num_ei_tx_alignment_stp_wrong_lane   | 32    | Number of times the alignment 2 STP wrong lane EI was injected                         |
| stat_num_ei_tx_alignment_sdp_wrong_lane   | 32    | Number of times the alignment 2 SDP wrong lane EI was injected                         |
| stat_num_ei_tx_alignment_2_stp_per_symbol | 32    | Number of times the alignment 2 STP per symbol time EI was injected                    |
| stat_num_ei_tx_alignment_2_sdp_per_symbol | 32    | Number of times the alignment 2 SDP per symbol time EI was injected                    |
| stat_num_ei_tx_alignment_stp_packet_gap   | 32    | Number of times the alignment STP packet gap EI was injected                           |
| stat_num_ei_tx_alignment_sdp_packet_gap   | 32    | Number of times the alignment SDP packet gap EI was injected                           |

## 5.8 Data Link Layer Transmit TLP Error Injection

Data Link Layer transmit TLP error injection codes are listed in [Table 5-8](#).

**Table 5-8 Data Link Layer transmit TLP error injection codes**

| Name                                        | Type    | Range            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DUT Action                                                                                                                                                              |
|---------------------------------------------|---------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EI_TX_TLP_PERCENTAGE</b>                 |         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                         |
|                                             | Integer | 0-100            | Percentage probability of a TLP type EI occurring.                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                         |
| <b>EI_TX_TLP_CORRUPT_LCRC_WEIGHT</b>        |         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                         |
|                                             | Integer | Typically 0-1000 | Corrupts LCRC of TLP transmitted to the Phy. The LCRC is corrupted by adding 1 to the correct value.                                                                                                                                                                                                                                                                                                                                                                             | DUT will NAK, then svc will retry                                                                                                                                       |
| <b>EI_TX_TLP_ILLEGAL_SEQ_NUM_WEIGHT</b>     |         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                         |
|                                             | Integer | Typically 0-1000 | Send packet sequence number ( <code>seq_num + 1</code> ) % 4096 thru ( <code>seq_num + 2047</code> ) % 4096. The same TLP is sent twice: 1 <sup>st</sup> with the illegal sequence number, 2 <sup>nd</sup> with correct sequence number. The 2 <sup>nd</sup> good TLP is not sent until the DUT responds with the correct NAK.                                                                                                                                                   | The TLP should be discarded. The sequence number is NOT one of the 2048 previous sequence numbers (mod 4096), so the TLP is out of sequence. The DUT should send a NAK. |
| <b>EI_TX_TLP_DUPLICATE_SEQ_NUM_WEIGHT</b>   |         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                         |
|                                             | Integer | Typically 0-1000 | Send packet with sequence number ( <code>seq_num + 2048</code> ) % 4096 thru ( <code>seq_num + 4095</code> ) % 4096. The same TLP is sent twice: 1 <sup>st</sup> with the duplicate sequence number, 2 <sup>nd</sup> with correct sequence number. The DUT should respond with the correct ACK. If not additional packets are sent, a duplicate ACK will be received. Otherwise, the duplicate ACK could get aggregated with ACK from subsequent packet.                         | The TLP should be discarded. The DUT should send ACK since the TLP is a duplicate, i.e. the sequence number is one of the 2048 previous sequence numbers (mod 4096).    |
| <b>EI_TX_TLP_NULLIFIED_WEIGHT</b>           |         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                         |
|                                             | Integer | Typically 0-1000 | Data Link will send TLP to PHY with nullify indication. This EI will only generate nullified TLPs if TLPs are available for Tx. The nullified TLP header is programmed via <code>TX_NULLIFIED_TLP_HDR0-3_VALUE</code> parameter. The length of the nullified TLP is controlled via <code>MIN/MAX_TX_NULLIFIED_TLP_LEN</code> . The default nullified TLP is an Error Msg with Fatal Msg code. The same sequence number is used by the nullified TLP and the subsequent good TLP. | DUT will ignore nullified TLP, and should not ACK/NAK. Since the sequence number will not be advanced, the DUT should use and ACK the next TLP with the same seq id.    |
| <b>EI_TX_TLP_NULLIFIED_GOOD_LCRC_WEIGHT</b> |         |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                         |

**Table 5-8 Data Link Layer transmit TLP error injection codes (Continued)**

| Name                                           | Type    | Range            | Description                                                                                                                                                                                                                                                       | DUT Action                                                                                                                                                                                  |
|------------------------------------------------|---------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                | Integer | Typically 0-1000 | Data Link will send TLP to PHY with nullify indication and good LCRC (not inverted as a correct nullify TLP). This EI will only generate nullified TLPs if TLPs are available for Tx. The nullified TLP is generated same as above, but the LCRC is not inverted. | DUT will not ignore nullified TLP since LCRC was not inverted as expected, and should send NAK. Since the sequence number will not be advanced, the DUT should ACK the last valid TLP sent. |
| <b>EI_TX_TLP_NULLIFIED_CORRUPT_LCRC_WEIGHT</b> |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | Data Link will send TLP to PHY with nullified indication and corrupt the LCRC. This EI will only generate nullified TLPs if TLPs are available for Tx. The nullified TLP is generated same as above, but the LCRC is corrupted via adding 1 to correct value.     | DUT will not ignore nullified TLP since LCRC did not pass, and should send NAK. Since the sequence number will not be advanced, the DUT should ACK the last valid TLP sent.                 |
| <b>EI_TX_TLP_BIT_FLIP_WEIGHT</b>               |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will flip a bit in TLP at Byte indicated by Data Link.                                                                                                                                                                   | DUT will NAK, then svc will retry.<br>NOTE: The VIP cannot predict if the error will be detected inside the DLLP.                                                                           |
| <b>EI_TX_TLP_MISSING_START_WEIGHT</b>          |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | The Start delimiter, STP, will be replaced with idle or corrupted via disparity error, bit flip, or codeword violation.                                                                                                                                           | The DUT should ignore the packet as it could not determine that a TLP was being received.                                                                                                   |
| <b>EI_TX_TLP_MISSING_END_WEIGHT</b>            |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | The End delimiter, END, will be replaced with idle or corrupted via disparity error, bit flip, or codeword violation.                                                                                                                                             | The DUT should NAK the packet as a TLP was being received. VIP will retry.                                                                                                                  |
| <b>EI_TX_TLP_5G_CORRUPT_DISPARITY_WEIGHT</b>   |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will insert disparity error in TLP at Byte indicated by Data Link. Valid only for 2.5G and 5G modes.                                                                                                                     | DUT will NAK, then svc will retry.<br>NOTE: The VIP can't predict if the error will be detected inside the DLLP.                                                                            |
| <b>EI_TX_TLP_5G_CODE_VIOLATION_WEIGHT</b>      |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will insert code violation in TLP at Byte indicated by Data Link. Valid only for 2.5G and 5G modes.                                                                                                                      | DUT will NAK, then svc will retry                                                                                                                                                           |
| <b>EI_TX_TLP_SCRAMBLER_ERROR_WEIGHT</b>        |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
| **** Deprecated: Do not use ****               |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |
|                                                | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will insert a scrambler error in TLP at Byte indicated by Data Link.                                                                                                                                                     | DUT will NAK, then svc will retry                                                                                                                                                           |
| <b>EI_TX_TLP_8G_CORRUPT_HEADER_CRC_WEIGHT</b>  |         |                  |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                             |

**Table 5-8 Data Link Layer transmit TLP error injection codes (Continued)**

| Name                                             | Type    | Range            | Description                                                                                       | DUT Action                                 |
|--------------------------------------------------|---------|------------------|---------------------------------------------------------------------------------------------------|--------------------------------------------|
|                                                  | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will corrupt token header FCRC. Only valid in 8G mode.   | DUT is expected to transition to Recovery. |
| <b>EI_TX_TLP_8G_CORRUPT_HEADER_PARITY_WEIGHT</b> |         |                  |                                                                                                   |                                            |
|                                                  | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will corrupt token header parity. Only valid in 8G mode. | DUT is expected to transition to Recovery. |

## 5.9 Data Link Layer Transmit DLLP Error Injection

Data Link Layer transmit DLLP error injection codes are listed in [Table 5-9](#).

**Table 5-9 Data Link Layer transmit DLLP error injection codes**

| Name                                   | Type    | Range            | Description                                                                                                                        | DUT Action                                                                                                               |
|----------------------------------------|---------|------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| <b>EI_TX_DLLP_PERCENTAGE</b>           |         |                  |                                                                                                                                    |                                                                                                                          |
|                                        | Integer | 0-100            | Percentage probability of a transmit DLLP type EI occurring.                                                                       |                                                                                                                          |
| <b>EI_TX_DLLP_UNKNOWN_TYPE_WEIGHT</b>  |         |                  |                                                                                                                                    |                                                                                                                          |
|                                        | Integer | Typically 0-1000 | Set DLLP “type” field to an unknown value.                                                                                         | When DUT receives a DLLP with an unknown type field, the packet is discarded with no further action. DUT should not NAK. |
| <b>EI_TX_DLLP_CORRUPT_CRC_WEIGHT</b>   |         |                  |                                                                                                                                    |                                                                                                                          |
|                                        | Integer | Typically 0-1000 | Corrupt CRC of packet sent to the Phy.                                                                                             | DLLP is discarded.<br>NOTE: Need to figure out if DUT used the corrupt DLLP or not (use TransmitUserDLLP interface task) |
| <b>EI_TX_DLLP_DUPLICATE_ACK_WEIGHT</b> |         |                  |                                                                                                                                    |                                                                                                                          |
|                                        | Integer | Typically 0-1000 | Generate an ACK for a packet that has already been ACK'd. The sequence number in the DLLP must not be 2047 less than Next_rcv_seq. | Re-ACK a recently ACKed sequence id. DUT should ignore as long as the seq id is within the last 2048 ids.                |
| <b>EI_TX_DLLP_RSVD_NON_ZERO_WEIGHT</b> |         |                  |                                                                                                                                    |                                                                                                                          |
|                                        | Integer | Typically 0-1000 | Set reserved fields in DLLPs to non-zero value.                                                                                    | Reserved fields should be ignored, normal processing.                                                                    |
| <b>EI_TX_DLLP_BIT_FLIP_WEIGHT</b>      |         |                  |                                                                                                                                    |                                                                                                                          |

**Table 5-9 Data Link Layer transmit DLLP error injection codes (Continued)**

| Name                                          | Type    | Range            | Description                                                                                                                                    | DUT Action                                                                                                                                                                                                                                              |
|-----------------------------------------------|---------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                               | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will flip a bit in DLLP at Byte indicated by Data Link.                                               | If corrupting an ACK/NAK, DUT will retry the TLP if another ACK is not sent before retry begins. For all FC, PM, or Vendor DLLPs, DUT should sent the next TLP if available. NOTE: The VIP can't predict if the error will be detected inside the DLLP. |
| <b>EI_TX_DLLP_MISSING_START_WEIGHT</b>        |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
|                                               | Integer | Typically 0-1000 | The Start delimiter, SDP, will be replaced with idle or corrupted via disparity error, bit flip, or codeword violation.                        | The DUT should discard the DLLP.                                                                                                                                                                                                                        |
| <b>EI_TX_DLLP_MISSING_END_WEIGHT</b>          |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
|                                               | Integer | Typically 0-1000 | The End delimiter, END, will be replaced with idle or corrupted via disparity error, bit flip, or codeword violation.                          | The DUT should discard the DLLP.                                                                                                                                                                                                                        |
| <b>EI_TX_DLLP_5G_CORRUPT_DISPARITY_WEIGHT</b> |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
|                                               | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will insert disparity error in DLLP at Byte indicated by Data Link. Valid only for 2.5G and 5G modes. | If corrupting an ACK/NAK, DUT will retry the TLP if another ACK is not sent before retry begins. For all FC, PM, or Vendor DLLPs, DUT should sent the next TLP if available. NOTE: The VIP can't predict if the error will be detected inside the DLLP. |
| <b>EI_TX_DLLP_5G_CODE_VIOLATION_WEIGHT</b>    |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
|                                               | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will insert code violation in DLLP at Byte indicated by Data Link. Valid only for 2.5G and 5G modes.  | If corrupting an ACK/NAK, DUT will retry the TLP if another ACK is not sent before retry begins. For all FC, PM, or Vendor DLLPs, DUT should sent the next TLP if available.                                                                            |
| <b>EI_TX_DLLP_SCRAMBLER_ERROR_WEIGHT</b>      |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
| **** Deprecated: Do not use ****              |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
|                                               | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will insert a scrambler error in DLLP at Byte indicated by Data Link.                                 | If corrupting an ACK/NAK, DUT will retry the TLP if another ACK is not sent before retry begins. For all FC, PM, or Vendor DLLPs, DUT should sent the next TLP if available.                                                                            |
| <b>EI_TX_DLLP_8G_CORRUPT_HEADER_WEIGHT</b>    |         |                  |                                                                                                                                                |                                                                                                                                                                                                                                                         |
|                                               | Integer | Typically 0-1000 | Data Link will send EI code to Phy which will corrupt SDP Token header. Only valid in 8G mode.                                                 | If corrupting an ACK/NAK, DUT will retry the TLP if another ACK is not sent before retry begins. For all FC, PM, or Vendor DLLPs, DUT should sent the next TLP if available.                                                                            |

## 5.10 Data Link Layer Receive TLP Error Injection

Data Link Layer Receive TLP error injection codes are listed in [Table 5-10](#).

**Table 5-10 Data Link Layer Receive TLP error injection codes**

| Name                                     | Type    | Range            | Description                                                                              | DUT Action                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------|---------|------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EI_RX_TLP_PERCENTAGE</b>              |         |                  |                                                                                          |                                                                                                                                                                                                                                                                                                                                          |
|                                          | Integer | 0-100            | Percentage probability of a receive TLP type EI occurring.                               |                                                                                                                                                                                                                                                                                                                                          |
| <b>EI_RX_TLP_WITHHOLD_ACK_NAK_WEIGHT</b> |         |                  |                                                                                          |                                                                                                                                                                                                                                                                                                                                          |
|                                          | Integer | Typically 0-1000 | VIP will not send an ACK or NAK to the link partner for a sent TLP.                      | Dut will retry after timeout (measure). Note that the only TLPs that the DUT should then send us should be between the last ACK actually sent and the ACK number scheduled but not sent. In other words. The DU is not allowed to send any NEW TLPs until replay is completed. Also note the order must be increasing during the replay. |
| <b>EI_RX_TLP_NAK_GOOD_TLP_WEIGHT</b>     |         |                  |                                                                                          |                                                                                                                                                                                                                                                                                                                                          |
|                                          | Integer | Typically 0-1000 | For TLP sent, indicate NAK needs to be sent to link partner regardless of TLP integrity. | Dut will retry                                                                                                                                                                                                                                                                                                                           |

## 5.11 Data Link Layer Multiple Packet Error Injection

Data Link Layer multiple packet error injection codes are listed in [Table 5-11](#).

**Table 5-11 Data Link Layer multiple packet injection error codes**

| Name                                    | Type    | Range            | Description                                                                                                   | DUT Action                                                                                                                                                                                                              |
|-----------------------------------------|---------|------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EI_RX_MULTI_TLP_PERCENTAGE</b>       |         |                  |                                                                                                               |                                                                                                                                                                                                                         |
|                                         | Integer | 0-100            | Percentage probability of a receive TLP type EI occurring on multiple packets.                                |                                                                                                                                                                                                                         |
| <b>EI_RX_REPLY_COUNT_FAILURE_WEIGHT</b> |         |                  |                                                                                                               |                                                                                                                                                                                                                         |
|                                         | Integer | Typically 0-1000 | Cause DUT replay_num to roll over by ignoring 4 consecutive TLPs. This will force DUT to initiate retraining. | Cause a replay count failure by either NAKing the same TLP 4 times, or causing an ACKNAK timeout 4 times on the same TLP. DUT should cause the link to retrain. After retraining, DUT should attempt to send TLP again. |

## 5.12 Data Link Layer Packet Alignment Error Injection

Data Link Layer packet alignment error injection codes are listed in [Table 5-12](#).

**Table 5-12 Data Link Layer packet alignment error injection codes**

| Name                                              | Type    | Range            | Description                                                                           | DUT Action                                  |
|---------------------------------------------------|---------|------------------|---------------------------------------------------------------------------------------|---------------------------------------------|
| <b>EI_TX_ALIGNMENT_PERCENTAGE</b>                 |         |                  |                                                                                       |                                             |
|                                                   | Integer | 0-100            | Percentage probability of an alignment type EI occurring.                             |                                             |
| <b>EI_TX_ALIGNMENT_STP_WRONG_LANE_WEIGHT</b>      |         |                  |                                                                                       |                                             |
|                                                   | Integer | Typically 0-1000 | Data Link will start a TLP in lane other than 0 without a preceding END.              | DUT should ignore TLP. Maybe even send NAK. |
| <b>EI_TX_ALIGNMENT_SD_P_WRONG_LANE_WEIGHT</b>     |         |                  |                                                                                       |                                             |
|                                                   | Integer | Typically 0-1000 | Data Link will start a DLLP in lane other than 0 without a preceding END.             | DUT should ignore DLLP.                     |
| <b>EI_TX_ALIGNMENT_TWO_STP_PER_SYMBOL_WEIGHT</b>  |         |                  |                                                                                       |                                             |
|                                                   | Integer | Typically 0-1000 | Data Link will start 2 TLPs in symbol time. Only valid at link widths of 32.          | DUT should ignore the 2 <sup>nd</sup> TLP.  |
| <b>EI_TX_ALIGNMENT_TWO_SD_P_PER_SYMBOL_WEIGHT</b> |         |                  |                                                                                       |                                             |
|                                                   | Integer | Typically 0-1000 | Data Link will start 2 DLLPs in symbol time. Only valid at link widths of 12 or more. | DUT should ignore the 2 <sup>nd</sup> DLLP. |
| <b>EI_TX_ALIGNMENT_STP_PACKET_GAP_WEIGHT</b>      |         |                  |                                                                                       |                                             |

**Table 5-12 Data Link Layer packet alignment error injection codes (Continued)**

| Name                                         | Type    | Range            | Description                                                                         | DUT Action                              |
|----------------------------------------------|---------|------------------|-------------------------------------------------------------------------------------|-----------------------------------------|
|                                              | Integer | Typically 0-1000 | Data Link will place a gap between END and STP which occur in the same symbol time. | DUT should ignore 2 <sup>nd</sup> TLP.  |
| <b>EI_TX_ALIGNMENT_SDP_PACKET_GAP_WEIGHT</b> |         |                  |                                                                                     |                                         |
|                                              | Integer | Typically 0-1000 | Data Link will place a gap between END and SDP which occur in the same symbol time. | DUT should ignore 2 <sup>nd</sup> DLLP. |

## 5.13 Data Link Layer Internal Interface Tasks

Data Link Layer internal interface tasks are listed in [Table 5-13](#).

**Table 5-13 Transaction – Data Link Layer interface tasks**

| Task Name   | Arguments       | I/O | Values                                                                                                                                            |
|-------------|-----------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| TransmitTLP | tlp_ptr(32)     | I   | Pointer of the TLP packet to be sent.                                                                                                             |
|             | tlp_len(32)     | I   | Length of the data buffer containing the TLP in dwords.                                                                                           |
|             | tlp_ei_code(32) | I   | Error injection code                                                                                                                              |
|             | req             | I   | Request from application layer to Transaction Layer                                                                                               |
|             | ack             | O   | Acknowledgement that Transaction Layer has accepted the transmission request from the application.                                                |
| ReceiveTLP  | tlp_vh          | I   | VH the TLP was sent on. This MR FC_INIT state machine needs this info. Valid when Ack is asserted.                                                |
|             | tlp_vc          | I   | VC the TLP was sent on. This FC_INIT state machine needs this info. Valid when Ack is asserted. When MRIOV is enabled, this returns the VL value. |
|             | tlp_ptr(32)     | O   | Pointer to the sent TLP.                                                                                                                          |
|             | tlp_len(32)     | O   | Length of the sent TLP buffer in dwords.                                                                                                          |
|             | tlp_ei_code(32) | O   | Error Injection code                                                                                                                              |
|             | req             | O   | Request to from Transaction Layer to application layer to pass TLP contents.                                                                      |
|             | ack             | I   | Acknowledgement that TLP contents have been accepted by the application layer.                                                                    |

**Table 5-13 Transaction – Data Link Layer interface tasks (Continued)**

| Task Name                                                                                                                                                       | Arguments        | I/O                                                               | Values                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Instructs the link to send an UpdateFCP or InitFCP DLLP.<br><br>InitFC1 will cause Flow Control Init state machine to start for that particular VC.             | vh(32)           | I                                                                 | Virtual Hierarchy to send DLLP to.                                                                                               |
|                                                                                                                                                                 | vc(32)           | I                                                                 | Virtual channel to send DLLP to.                                                                                                 |
|                                                                                                                                                                 | credit_type(32)  | I                                                                 | credit_type[1:0] == 2'b00 means NP<br>credit_type[1:0] == 2'b01 means Posted<br>credit_type[1:0] == 2'b10 means Completion type. |
|                                                                                                                                                                 | hdr_credits(32)  | I                                                                 | Number of header credits sent                                                                                                    |
|                                                                                                                                                                 | data_credits(32) | I                                                                 | Number of data credits sent                                                                                                      |
|                                                                                                                                                                 | credit_is_init   | I                                                                 | This is the first credits sent. Will be use in FC Initialization process.                                                        |
|                                                                                                                                                                 | req(1)           | I                                                                 | Request to send credits                                                                                                          |
| Any UpdateFC and InitFC1 credits to forward to Transaction Layer. This task will be call on every clock cycle. Only 1 flow control DLLP will be sent per cycle. | ack(1)           | O                                                                 | Acknowledgement that request was accepted                                                                                        |
|                                                                                                                                                                 | vh(32)           | O                                                                 | Virtual Hierarchy Credits sent on.                                                                                               |
|                                                                                                                                                                 | vc(32)           | O                                                                 | Virtual channel Credits sent on.                                                                                                 |
|                                                                                                                                                                 | credit_type(32)  | O                                                                 | credit_type[1:0] == 2'b00 means NP<br>credit_type[1:0] == 2'b01 means Posted<br>credit_type[1:0] == 2'b10 means Completion type. |
|                                                                                                                                                                 | hdr_credits(32)  | O                                                                 | Number of header credits sent                                                                                                    |
|                                                                                                                                                                 | data_credits(32) | O                                                                 | Number of data credits sent                                                                                                      |
|                                                                                                                                                                 | credit_is_init   | O                                                                 | This is the first credits sent. These are initialization credits.                                                                |
| req(1)                                                                                                                                                          | O                | Request to Transaction Layer                                      |                                                                                                                                  |
|                                                                                                                                                                 | I                | Acknowledgement from Transaction Layer that request was accepted. |                                                                                                                                  |

## 5.14 Data Link Layer to Physical Layer Interface Tasks

Data Link Layer to Physical Layer interface tasks are listed in [Table 5-14](#).

**Table 5-14 Data Link Layer – Physical Layer interface tasks**

| Task Name   | Arguments           | I/O | Values                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|---------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TransmitPhy |                     |     |                                                                                                                                                                                                                                                                                                                                                                                                             |
|             | data_out(256)       | O   | Link data, on per lane basis<br>Lane 0 – data[7:0]<br>Lane 1 – data[15:8]<br>Lane 31 – data[248:255]                                                                                                                                                                                                                                                                                                        |
|             | control_bus(256)    | O   | Control_bus per lane:<br>Control_bus[7:0] – lane 0.<br>Control_bus[15:8] – lane 1.<br>Control_bus[248:255] – lane 31.<br><br>control_bus[lane_offset+0] - Indicates idle<br>control_bus[lane_offset+1] - Indicates STP<br>control_bus[lane_offset+2] - Indicated SDP<br>control_bus[lane_offset+3] - Indicates EOF<br>control_bus[lane_offset+4] - Indicates EDB<br>control_bus[lane_offset+7:5] - Reserved |
|             | ei_code(256)        | O   | ei_code per lane:<br>ei_code[7:0] – lane 0.<br>ei_code[15:8] – lane 1.<br>ei_code[248:255] – lane 31.                                                                                                                                                                                                                                                                                                       |
|             | phy_hold(1)         | I   | Indication from Physical Layer to hold transmission                                                                                                                                                                                                                                                                                                                                                         |
| ReceivePhy  | phy_align_packet(1) | I   | Indication from Phy that next packet must be aligned to lane 0. This will be used by the Phy create an opportunity between packets to insert skip set.                                                                                                                                                                                                                                                      |
|             | data_in(256)        | I   | One byte of outgoing data per lane.                                                                                                                                                                                                                                                                                                                                                                         |
|             | control_bus(256)    | I   | Indication of whether the outgoing byte is valid or not, or whether it is a start of TLP, end of TLP, etc. Each byte of the control bus corresponds to a byte of data.                                                                                                                                                                                                                                      |
|             | ei_code(256)        | I   | Error injection code. There is a 1 byte error injection code per byte of data.                                                                                                                                                                                                                                                                                                                              |

# 6 Physical Layer

The Physical Layer contains the LTSSM, performs data scrambling and descrambling, and is responsible for lane deskew and interfacing with the link for transmit/receive data. There is a separate PIPE interface to each PCS.

## 6.1 Physical Layer Module IOs

The module inputs/outputs for the Physical Layer are listed in [Table 6-1](#).

**Table 6-1 Physical Layer module I/Os**

| Name        | I/O   | Description                                                                                                                                                            |
|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| reset       | I(1)  | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.                                                                               |
| pl_control  | I(32) | Control signals into the phy for controlling things such as link retrain and entry/exit from low power states.                                                         |
| wake        | I(1)  | Internal wake signal, not user accessible. To wake/exit the model from L2 please see <code>InitiatePMExit</code> or <code>InitiateASPMExit</code> in the DL User Tasks |
| link_width  | O(32) | Width of the negotiated link                                                                                                                                           |
| freq_select | O(32) | Frequency select for the transmit clock generator.                                                                                                                     |
| pl_status   | O(32) | [0] = link_up.<br>[1] = phy in recovery                                                                                                                                |

## 6.2 Physical Layer Configuration Tasks

Tasks for configuring the Physical Layer are listed in [Table 6-2](#).

**Table 6-2 Tasks for configuring the Physical Layer**

| <b>Task Name</b>                                                                                                                                                                                                                                                                                                                       | <b>Arguments (length)</b> | <b>I/O</b> | <b>Values</b>                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetLinkWidth<br><br>Sets the maximum link width the LTSSM is allowed to negotiate. When link training is bypassed, the maximum link width will be used.<br><br>Calling this task also changes the supported link widths to all legal values below the max link width and sets the expected link width equal to the maximum link width. | link_width (32)           | I          | Set the link width that the LTSSM will try to negotiate.<br><br>Use the integral values with SetLinkWidth(). For example: 1 for x1, 2 for x2, 16 for x16 etc.,<br><br>Note. Do note use the link width parameter names used by SetSupportedLinkWidthVector (see below). |
| SetSupportedLinkWidthVector<br><br>Defined which link widths the LTSSM is allowed to negotiate to. An x1 link width must always be supported. No link widths above what was defined in SetLinkWidth are allowed.                                                                                                                       | link_width_vector_i (32)  | I          | Supported Link Widths<br><br>User should or together use the LINK_WIDTH_* parms defined in Include/pciesvc_parms.v to create a vector.                                                                                                                                  |
| SetExpectedLinkWidth<br><br>Sets the expected negotiated link width. The link width is checked on the LTSSM state transition from Configuration.Complete to L0.                                                                                                                                                                        | link_width_i (32)         | I          | Expected link width.                                                                                                                                                                                                                                                    |
| InitiateLinkWidthChange<br><br>Directs the LTSSM to attempt to upconfigure/downconfigure the link width to the highest allowed link width in the supported link width vector field. Can only be called in L0. Calls to this task outside of L0 will be ignored.                                                                        | n/a                       | n/a        | n/a                                                                                                                                                                                                                                                                     |
| SetLinkNumber<br><br>Sets the link number that the LTSSM will advertise in TS1/TS2 ordered sets during link training. Default link number is 0.                                                                                                                                                                                        | link_number (32)          | I          | Link number assigned to the LTSSM.                                                                                                                                                                                                                                      |

**Table 6-2 Tasks for configuring the Physical Layer (Continued)**

| Task Name                                                                                                                                                                                                                                                                                                                | Arguments (length)    | I/O | Values                                                                                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetSupportedSpeeds                                                                                                                                                                                                                                                                                                       | speeds (32)           | I   | Supported speeds. Parameters should be or'd together to create a vector. For example, (SPEED_2_5G   SPEED_5G   SPEED_8G) indicates support for 2.5G, 5G and 8G. The speed parms are located in Include/pciesvc_parms.v |
| Instructs the LTSSM which speeds are supported during link training. If link training is bypassed, the highest supported speed is always used.<br><br>If the VIP is a downstream port, calling this task will automatically set the target speed to the highest supported speed.                                         |                       |     |                                                                                                                                                                                                                        |
| SetTargetSpeed                                                                                                                                                                                                                                                                                                           | target_speed (32)     | I   | Target speed operation.<br>Users should or together the SPEED_* parms defined in Include/pciesvc_parms.v to set the supported speed.                                                                                   |
| Sets the desired speed of operation for a downstream port. Target speed is only defined for root complex, and calling this task for all other devices will be flagged as a warning.<br><br>The target speed field is automatically updated to the highest supported speed every time SetSupportedSpeedsVector is called. |                       |     |                                                                                                                                                                                                                        |
| SetExpectedSpeed                                                                                                                                                                                                                                                                                                         | expected_speed_i (32) | I   | Expected speed of operation.<br><br>Users should use the SPEED_* parms defined in Include/pciesvc_parms.v to set the expected speed. Only one speed can be expected.                                                   |
| The LTSSM is in the L0 state.<br><br>The downstream port has transmitted an SDP.                                                                                                                                                                                                                                         |                       |     |                                                                                                                                                                                                                        |
| InitiateRetrainLink                                                                                                                                                                                                                                                                                                      | n/a                   | n/a | n/a                                                                                                                                                                                                                    |
| Causes the LTSSM to enter recovery and attempt to retrain the link. This task has same functionality as setting retrain_link bit in PCIE Cfg's Link Control Register.                                                                                                                                                    |                       |     |                                                                                                                                                                                                                        |
| InitiateSpeedChange                                                                                                                                                                                                                                                                                                      | n/a                   | n/a | n/a                                                                                                                                                                                                                    |
| Sets the directed_speed_change variable in the LTSSM, causing the LTSSM to enter recovery and attempt a speed change.<br>Should only be called in L0. Calls to this task outside of L0 will be ignored.                                                                                                                  |                       |     |                                                                                                                                                                                                                        |

**Table 6-2 Tasks for configuring the Physical Layer (Continued)**

| Task Name                   | Arguments (length)                                                                                                                                                                                                                                                       | I/O                            | Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ConfigurePipeWidthTable     | rate(2)<br><br>Sets the width of per lane data bus for a given speed. This task is valid for SPIPE PIPE 3 models only. Default operation is 8 bits for all speeds.<br><br>Using this task on a PIPE 4 model will result in a NOTICE stating that the task is deprecated. | width(2)                       | Data rate that is to be configured. Users must use the parameters PIPE_RATE_* defined in Verilog/Include/pciesvc_parms.<br><br>The pipe data bus width that the SVC is supposed to operate at when at the above speed. Users must use the PIPE_DATA_BUS_WIDTH_* parameters defined in Verilog/Include/pciesvc_parms.v                                                                                                                                                                                                                                                                                                                                            |
| ConfigurePipeWidthPclkTable | rate (2)<br><br>Sets the width of per lane data bus and pope clock rate for a given link speed. This task is valid for MPIPE PIPE 4 models only. Default operation is eight bits for all speeds.                                                                         | width (2)<br><br>pclk_rate (2) | Data rate that is to be configured. Users must use the parameters PIPE_RATE_* defined in Verilog/Include/pciesvc_parms.<br><br>The pipe width that the VIP is supposed to operate at when at the above speed. Users must use the PIPE_WIDTH_* parameters defined in Verilog/Include/pciesvc_parms.v. Note that PIPE_WIDTH_* is not the same as PIPE_DATA_BUS_WIDTH. They are different PIPE signals with different values.<br><br>Frequency at which the pipe clock will operate. Takes in the params PIPE_PCLK_RATE_* defined in Verilog/Include/pciesvc_parms.v<br><br>See Table 3-2 in the PIPE spec for all legal combinations of rate, width and pclk_rate. |
| SetPhyEnable                | enable (1)                                                                                                                                                                                                                                                               | I                              | When set to a 1, the phy will allow the LTSSM to transition out of the disabled state. When set to 0, the LTSSM will be forced to transition to the disabled state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**Table 6-2 Tasks for configuring the Physical Layer (Continued)**

| Task Name        | Arguments (length) | I/O | Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|--------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetHotResetMode  | mode (32)          | I   | <p>Task takes a parameter defined in src/verilog/[tool]/pciesvc_phylayer_parms.v.</p> <p>This task allows the user to initiate a hot reset and/or force the LTSSM to stay in the hot reset state.</p> <p>HOT_RESET_MODE_INACTIVE – In this mode the LTSSM will not initiate a hot reset. If the LTSSM is in the hot_reset state then it will transition to a Detect state.</p> <p>HOT_RESET_MODE_FORCE – If not in the hot_reset state, the LTSSM will begin sending training sets with the hot reset bit set and transition to hot_reset. When in the hot_reset state, the LTSSM will remain in this state until the hot reset mode has been changed in inactive or the hot reset timer expires.</p> <p>HOT_RESET_MODE_WAIT – If not in the hot_reset state, the LTSSM will begin sending training sets with the hot reset bit set and transition to the hot reset state. If in the hot_reset state, the LTSSM will wait until it has sent 2 TS1 ordered sets with the hot reset bit set with lane and link number set to the appropriate values, then transition to Detect.</p> |
| InitiateLoopback | enable_i (1)       | I   | <p>Instructs the VIP to enter loopback as a loopback master.</p> <p>When set to 1, VIP will attempt to enter loopback mode as a loopback master. When cleared, the VIP will exit loopback mode if it was a loopback master.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 6-2 Tasks for configuring the Physical Layer (Continued)**

| Task Name                                                               | Arguments (length) | I/O | Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------|--------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetEnterCompliance                                                      | value (1)          | I   | Sets the enter compliance bit of the link control register. This is used to force the attached link into Polling.Compliance, and is also optionally used when entering loopback.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SetLaneReversalMode<br><br>Configures the VIP support of lane reversal. | mode (32)          | I   | The modes are:<br>UNSUPPORTED – The VIP will not attempt a lane reversal if during the configuration states it is unable to form a link.<br>SUPPORTED- The VIP will attempt a lane reversal if it is unable to form a link using normal lane ordering.<br>FORCED – The VIP will reverse its lanes from 0-(n-1) to (n-1)-0, where N is the link width as set using the SetLinkWidth task. This mode is intended for testing purposes only. It allows a user to test DUT lane reversal support without having to change the wiring.<br><br>When calling this task, users must use the LANE_REVERSAL* parms in Verilog/Include/pciesvc_parms.v. |

## 6.3 Physical Layer User Tasks

The following tasks can be used

Tasks that can be used to query the Physical Layer status are listed in [Table 6-3](#).

**Table 6-3 Physical Layer user tasks**

| <b>Task Name</b>                                                               | <b>Arguments (length)</b>      | <b>I/O</b> | <b>Values</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------------------------------------------------|--------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GetConfiguredLinkWidth<br><br>Returns the link width the VIP is configured at. | link_width (32)                | O          | Returns the maximum number of lanes the pl is configured to utilize.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| GetNegotiatedLinkWidth<br><br>Returns the current operating link width         | link_wdith (32)                | O          | Current operating link width. This task should only be called when the link is up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| GetNegotiatedSpeed<br><br>Returns current operating speed                      | speed (32)                     | O          | Returns the current operating speed.<br>Values are:<br>SPEED_2_5G<br>SPEED_5_0G<br>SPEED_8_0G<br>parms are defined in Include/pciesvc_parms.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| GetLtssmState<br><br>Returns the current LTSSM state.                          | ltssm_state (32)               | O          | The value returned is the current state of the LTSSM. LTSSM state parameters are defined in PhyLayer/pciesvc_phylayer_parms.v.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RequestHotPlugMode                                                             | input [31:0]<br>hot_reset_mode | I          | Causes the LTSSM to behave as if it has either been physically unplugged or plugged back in.<br><br>The hotplug mode parameters are defined in Verilog/Include/pciesvc_parms.v. Modes are as follows:<br><br>HOTPLUG_UNPLUG- The phy is unplugged and will not respond to the other side of the link until the hotplug mode is changed.<br><br>HOTPLUG_WAIT- The phy is enabled but will not exit detect.quiet until the other side of the link has done so.<br><br>HOTPLUG_MONITOR- The phy will check incoming training sets and make sure that the DUT is timing out correctly in detect/polling.active, but the phy will not exit detect in this state.<br><br>HOTPLUG_DETECT- This is the normal state. The phy will go through the detect states per the spec. |

Tasks that can be used to pass time until the LTSSM reaches a particular state are listed in [Table 6-4](#).

**Table 6-4 Tasks used to consume time waiting for a state**

| <b>Task Name</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>Arguments (length)</b>                            | <b>I/O</b> | <b>Values</b>                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------|
| WaitForLtssmState<br><br>Blocks until the LTSSM has reached the given state. If the LTSSM is already in the specified state then no action is taken.                                                                                                                                                                                                                                                                                                                                             | ltssm_state_i (32)                                   | I          | Waits until the LTSSM has reached a particular state. LTSSM state parameters are defined in PhyLayer/pciesvc_phylayer_parms.v |
| WaitUntilLinkUp<br><br>Blocks until link_up goes high. If the link is already up then there is no action.                                                                                                                                                                                                                                                                                                                                                                                        | N/A                                                  | N/A        | N/A                                                                                                                           |
| WaitUntilLtssmStateChange<br><br>Blocks until the LTSSM has exited the current state                                                                                                                                                                                                                                                                                                                                                                                                             | N/A                                                  | N/A        | N/A                                                                                                                           |
| ConfigureLane<br><br>This task associates an advertised link number with a physical link.<br><br>The default behavior is to associate physical lane 0 with advertised lane 0, physical lane 1 will advertise itself as lane 1 and so on.<br><br>Example- ConfigureLane(0,1,1) will instruct the LTSSM have physical lane 0 advertise itself as lane 1 in all TS1/TS2 ordered sets. This is intended to be used only for LTSSM testing, the LTSSM will not support arbitrary lane N to N mapping. | phy_id (32)<br><br>lane_num (32)<br><br>enabled (32) |            | Phy number that user wishes to configure<br><br>Lane number the phy should be associated with.<br><br>Enable the association. |
| DisplayStats<br><br>Displays all stats in Physical Layer.                                                                                                                                                                                                                                                                                                                                                                                                                                        | None                                                 |            | Displays all stats in PL                                                                                                      |
| ClearStats<br><br>Clears all stats in Physica Layer.                                                                                                                                                                                                                                                                                                                                                                                                                                             | None                                                 |            | Clear all stats in PL                                                                                                         |

## 6.4 LTSSM User Training Set Tasks

The Physical Layer has the capability for a user to define the entire contents of transmitted TS1/TS2 training sets on a per lane basis. Tasks used to define the contents of TS1/TS2 training sets are listed in [Table 6-5](#).

Note that these tasks should only be used for directed tests , and should not be used during normal operation.

In order to send user training sets, SetUserTxTs1/SetUserTxTs2 must be called to define the training sets on the lanes that a user training set is to be transmitted on. Once the user training sets are defined, the task SetUserTxTs1Pattern/SetUserTxTs2Pattern is called to define a pattern of user TS1 to normal TS1.

## Example

`SetUserTxTs1Pattern(1'b1, 1, 2, 1, 1)` will enable user TS1 patterns, and the LTSSM will transmit between 1 and 2 user TS1 followed by 1 normal TS1.

The parameters `USER_TX_TS1_LANE_MASK` and `USER_TX_TS2_LANE_MASK` can be used to apply the user training sets only to certain lanes.

**Table 6-5 LTSSM user training set tasks**

| Task Name                                                                                           | Arguments                                                                                                                                                                                                                                                                                                                                                      | I/O | Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetUserTxTs1<br><br>Defines a user training set and optionally an error injection for a given lane. | lane_num_i(32)<br><br>ei_byt enum(32)<br><br>ei_code(32)<br><br>symbol0(9)<br><br>symbol1(9)<br><br>symbol2(9)<br><br>symbol3(9)<br><br>symbol4(9)<br><br>symbol5(9)<br><br>symbol6(9)<br><br>symbol7(9)<br><br>symbol8(9)<br><br>symbol9(9)<br><br>symbol10(9)<br><br>symbol11(9)<br><br>symbol12(9)<br><br>symbol13(9)<br><br>symbol14(9)<br><br>symbol15(9) |     | Lane number that is to be configured.<br><br>Byte number that EI is to be injected on<br><br>EI code to be applied to the error'd symbol.<br>Symbol 0 of the user training set. MSB is the control bit for all symbols<br><br>Symbol 1 of the user training set<br><br>Symbol 2 of the user training set<br><br>Symbol 3 of the user training set<br><br>Symbol 4 of the user training set<br><br>Symbol 5 of the user training set<br><br>Symbol 6 of the user training set<br><br>Symbol 7 of the user training set<br><br>Symbol 8 of the user training set<br><br>Symbol 9 of the user training set<br><br>Symbol 10 of the user training set<br><br>Symbol 11 of the user training set<br><br>Symbol 12 of the user training set<br><br>Symbol 13 of the user training set<br><br>Symbol 14 of the user training set<br><br>Symbol 15 of the user training set<br><br>Symbol 16 of the user training set |

**Table 6-5 LTSSM user training set tasks (Continued)**

| Task Name                                                                                                                                                                                                                                                                                                  | Arguments                                                                                                                                    | I/O                   | Values                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetUserTxTs1Pattern<br><br>When enabled, the LTSSM will send a random burst of user training sets. The size of the burst is set by the min/max arguments. In between the burst of user training sets the LTSSM will send normal TS1. The number of normal TS1 is defined by the min/max spacing arguments. | enable_i(32)<br><br>min_user_tx_ts1_burst_i<br><br>max_user_tx_ts1_burst_i<br><br>min_user_tx_ts1_spacing_i<br><br>max_user_tx_ts1_spacing_i | I<br>I<br>I<br>I<br>I | '1' enables the training set pattern, '0' disables it<br><br>Minimum number of user TS1 sets in the user burst.<br><br>Maximum number of user TS1 sets in the user burst.<br><br>Minimum number of normal TS1 sets between the error burst.<br><br>Minimum number of normal TS1 sets between the error burst. |

**Table 6-5 LTSSM user training set tasks (Continued)**

| <b>Task Name</b>                                                                                    | <b>Arguments</b>                                                                                                                                                                                                                                                                                                                                              | <b>I/O</b>                                                                                                                             | <b>Values</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetUserTxTs2<br><br>Defines a user training set and optionally an error injection for a given lane. | lane_num_i(32)<br><br>ei_bytenum(32)<br><br>ei_code(32)<br><br>symbol0(9)<br><br>symbol1(9)<br><br>symbol2(9)<br><br>symbol3(9)<br><br>symbol4(9)<br><br>symbol5(9)<br><br>symbol6(9)<br><br>symbol7(9)<br><br>symbol8(9)<br><br>symbol9(9)<br><br>symbol10(9)<br><br>symbol11(9)<br><br>symbol12(9)<br><br>symbol13(9)<br><br>symbol14(9)<br><br>symbol15(9) | <br><br> | Lane number that is to be configured.<br><br>Byte number that EI is to be injected on<br><br>EI code to be applied to the error'd symbol.<br>Symbol 0 of the user training set. MSB is the control bit for all symbols.<br><br>Symbol 1 of the user training set<br><br>Symbol 2 of the user training set<br><br>Symbol 3 of the user training set<br><br>Symbol 4 of the user training set<br><br>Symbol 5 of the user training set<br><br>Symbol 6 of the user training set<br><br>Symbol 7 of the user training set<br><br>Symbol 8 of the user training set<br><br>Symbol 9 of the user training set<br><br>Symbol 10 of the user training set<br><br>Symbol 11 of the user training set<br><br>Symbol 12 of the user training set<br><br>Symbol 13 of the user training set<br><br>Symbol 14 of the user training set<br><br>Symbol 15 of the user training set |

**Table 6-5 LTSSM user training set tasks (Continued)**

| <b>Task Name</b>                                                                                                                                                                                                                                                                                           | <b>Arguments</b>                                                                                                                                                                                                                                                                                                     | <b>I/O</b>                                                                                                             | <b>Values</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetUserTxTs2Pattern<br><br>When enabled, the LTSSM will send a random burst of user training sets. The size of the burst is set by the min/max arguments. In between the burst of user training sets the LTSSM will send normal TS2. The number of normal TS2 is defined by the min/max spacing arguments. | enable(32)<br><br>min_user_tx_ts2_burst<br><br>max_user_tx_ts2_burst<br><br>min_user_tx_ts2_spacing<br><br>max_user_tx_ts2_spacing                                                                                                                                                                                   | I<br><br>I<br><br>I<br><br>I                                                                                           | '1' enables the training set pattern, '0' disables it<br><br>Minimum number of user TS2 sets in the user burst.<br><br>Maximum number of user TS2 sets in the user burst.<br><br>Minimum number of normal TS2 sets between the error burst.<br><br>Minimum number of normal TS2 sets between the error burst.                                                                                                                                                                                                                                                                                                                                                                                                               |
| GetTxTs<br><br>Returns the training set that is currently being transmitted on lane_num. This task is intended to help users build a training set where they wish to modify only a single field of an outgoing normal TS1/TS2                                                                              | lane_num_i(32)<br><br>symbol0(9)<br><br>symbol1(9)<br><br>symbol2(9)<br><br>symbol3(9)<br><br>symbol4(9)<br><br>symbol5(9)<br><br>symbol6(9)<br><br>symbol7(9)<br><br>symbol8(9)<br><br>symbol9(9)<br><br>symbol10(9)<br><br>symbol11(9)<br><br>symbol12(9)<br><br>symbol13(9)<br><br>symbol14(9)<br><br>symbol15(9) | I<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O<br><br>O | Lane number that is to be configured.<br><br>Symbol 0 of the user training set<br><br>Symbol 1 of the user training set<br><br>Symbol 2 of the user training set<br><br>Symbol 3 of the user training set<br><br>Symbol 4 of the user training set<br><br>Symbol 5 of the user training set<br><br>Symbol 6 of the user training set<br><br>Symbol 7 of the user training set<br><br>Symbol 8 of the user training set<br><br>Symbol 9 of the user training set<br><br>Symbol 10 of the user training set<br><br>Symbol 11 of the user training set<br><br>Symbol 12 of the user training set<br><br>Symbol 13 of the user training set<br><br>Symbol 14 of the user training set<br><br>Symbol 15 of the user training set |

## 6.5 Equalization Tasks

Equalization tasks are listed in [Table 6-6](#).

**Table 6-6 Equalization Tasks**

| Task Name                                                                                                                                                          | Arguments (length) | I/O | Values                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------------------------------------------------------------------------|
| SetAttachedFSLF<br><br>Sets what values the SPIPE will drive on the LocalFS/LocalLF PIPE bus. This task should not be called if not using an SPIPE model.          | lane_en(32)        | I   | Bit vector to enable FS/LF values.                                      |
|                                                                                                                                                                    | fs(32)             | I   | full swing value                                                        |
|                                                                                                                                                                    | lf(32)             | I   | low frequency value                                                     |
| SetTxTS1FSLF<br><br>Set FS and LF values advertised to the link partner during Phase 1. FS and LF values are used by SVC to check requested preset/coefficients.   | lane_en(32)        | I   | Bit vector to enable FS/LF values.                                      |
|                                                                                                                                                                    | fs(32)             | I   | full swing value                                                        |
|                                                                                                                                                                    | lf(32)             | I   | low frequency value                                                     |
| GetRxTS1FSLF<br><br>Get FS and LF values received in training sets by the SVC on each lane. These values are received from the link partner in TS1 during Phase 1. | lane (32)          | I   | Lane to query                                                           |
|                                                                                                                                                                    | fs(32)             | O   | full swing value                                                        |
|                                                                                                                                                                    | lf(32)             | O   | low frequency value                                                     |
|                                                                                                                                                                    | valid(1)           | O   | When asserted, FS and LF have been captured from the link partner.      |
| GetTxTS1FSLF<br><br>Get local FS and LF values advertised by the SVC. These values are sent to the link partner in TS1 during Equalization Phase 1.                | lane (32)          | I   | Lane to query                                                           |
|                                                                                                                                                                    | fs(32)             | O   | full swing value                                                        |
|                                                                                                                                                                    | lf(32)             | O   | low frequency value                                                     |
|                                                                                                                                                                    | valid(1)           | O   | When asserted, FS and LF have been captured from the link partner.      |
| SetEQEvaluationDelay<br><br>Set Min/Max time to evaluate attached transmitter setting changes.<br><br>Default value min/max values are 100/1000ns                  | lane_en(32)        | I   | Bit vector enable preset applies to.                                    |
|                                                                                                                                                                    | min(32)            | I   | Minimum delay time to evaluate equalization.                            |
|                                                                                                                                                                    | max(32)            | I   | Maximum delay time to evaluate equalization.                            |
| SetRxEQEvalDelay<br><br>The amount of time in ns that an SPIPE model takes to respond to an RxEqEval request. SPIPE only.<br><br>Default values: min 10, max 50 ns | lane_en(32)        | I   |                                                                         |
|                                                                                                                                                                    | min(32)            | I   |                                                                         |
|                                                                                                                                                                    | max(32)            | I   |                                                                         |
| SetEQPresetValidationDelay<br><br>Set min/max preset/coefficient time to either accept or reject a request.<br><br>Default: 0 ns                                   | lane_en(32)        | I   | Bit vector enable preset applies to.                                    |
|                                                                                                                                                                    | min(32)            | I   | Minimum delay time to validate preset/ coefficient request.<br>Default: |
|                                                                                                                                                                    | max(32)            | I   | Maximum delay time to validate preset/ coefficient request.             |

**Table 6-6 Equalization Tasks (Continued)**

| <b>Task Name</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>Arguments (length)</b>     | <b>I/O</b> | <b>Values</b>                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QueueEQFigureMeritResponse<br>Sets a Figure of Merit response from equalization evaluation. Response range is 0 – 255.<br>If no responses are queued then the SVC will return a figure of merit value of 255.                                                                                                                                                                                                                                                                                                         | lane_en(32)                   | I          | Bit vector enable the figure of merit response applies to.                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | min(32)                       | I          | Minimum Figure of Merit response from equalization evaluation.                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | max(32)                       | I          | Maximum Figure of Merit response from equalization evaluation.                                                                                                         |
| QueueEQDirectionChangeResponse<br>Sets the direction change response from equalization evaluation.<br><br>Default is no change on any coefficients if no responses are queued.                                                                                                                                                                                                                                                                                                                                        | lane_en(32)                   |            | Bit vector enable response applies to.                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | direction_change_response(32) |            | Sets the direction change response from a link evaluation request. Please refer to the PIPE spec for encoding of this signal. Bits 6-31 of this argument are reserved. |
| QueueEQTxRequestPresetCoeff<br>Queue either Preset or Coeff Request.<br>SVC sends this request in TS1 at 8G in Recovery.Equalization. As long as a request is queued, SVC will issue a new request when the previous request completes. Phase will complete if no more requests are queued and transition criteria have been met.<br><br>Downstream port: in Phase 0 (as init preset for Upstream port, default = 15), Phase 3 as new preset/coeff request.<br>Upstream port: In Phase 2 as new preset/coeff request. | lane_en(32)                   | I          | Bit vector which enables preset. For example, a value of three would enable lanes zero and one.                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | preset_precursor(32)          | I          | Preset if preset_valid = 1 or precursor coefficient if preset_valid=0.                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | preset_valid(1)               | I          | If asserted, preset entry is queued, else coeff will be queued and requested in appropriate phase.                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | preshoot(32)                  | I          | Same as precursor                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | cursor_coeff                  | I          | This is the Cursor Coefficient value.                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | deemphasis(32)                | I          | Same as post cursor                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | expect_reject(1)              | I          | When set to 'b1 the SVC will expect the request to be rejected. When set to 'b0 the SVC will expect the request to be accepted.                                        |
| SetEQDownstreamPresetDefault<br>Set per lane<br>Downstream_Preset_Reg_Var to default value. Will be sent in EQTS1 by Downstream port in Phase 1.<br>Defaults to 15.                                                                                                                                                                                                                                                                                                                                                   | lane_en(32)                   | I          | Bit vector enable preset applies to.                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | preset(32)                    | I          | preset value                                                                                                                                                           |

**Table 6-6 Equalization Tasks (Continued)**

| <b>Task Name</b>                                                                                                                                                                                                                                                                                                          | <b>Arguments (length)</b> | <b>I/O</b> | <b>Values</b>                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetEQPreset2CoeffTable<br><br>This table is used to map received preset requests to coefficients for use in local Transmitter settings.<br><br>Default behavior is to enable all presets at initial time and set each entry to the parameter values PRECURSOR_COEFFICIENT, CURSOR_COEFFICIENT and POSTCURSOR_COEFFICIENT. | preset(32)                | I          | preset value                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                           | precursor_coeff(32)       | I          | precursor coefficient                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                           | cursor_coeff(32)          | I          | cursor coefficient                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                           | postcursor_coeff(32)      | I          | postcursor coefficient                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                           | enable(1)                 | I          | Enable preset entry. If the entry is not enabled then the SVC will reject any requests to use this preset.                                                 |
| SetEQExpectedPreset2CoeffTable<br><br>This table is used to verify DUT's preset to coefficient mapping. Table should be programmed exactly like the DUT's preset table.<br><br>If an entry is not enabled then SVC will not check received coefficients.                                                                  | preset(32)                | I          | preset value                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                           | precursor(32)             | I          | precursor coefficient corresponding to the preset value                                                                                                    |
|                                                                                                                                                                                                                                                                                                                           | cursor(32)                | I          | cursor coefficient corresponding to the preset value                                                                                                       |
|                                                                                                                                                                                                                                                                                                                           | postcursor(32)            | I          | postcursor coefficient corresponding to the preset value                                                                                                   |
|                                                                                                                                                                                                                                                                                                                           | reject(1)                 | I          | When set to 1 the SVC will expect for the preset to be rejected. Else the preset should be accepted.                                                       |
|                                                                                                                                                                                                                                                                                                                           | enable(1)                 | I          | Enable preset entry. If enabled then the SVC will check that incoming TS1 show the correct coefficient values when a particular preset has been requested. |
| GetEQRxRequestedPresetCoefficients<br><br>The SVC will capture preset and/or coefficients requested by the DUT. If "use_preset" field was set in TS OS, preset_valid will be asserted.                                                                                                                                    | lane(32)                  | I          | Lane number                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                           | preset(32)                | O          | preset value                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                           | use_preset(1)             | O          | use_preset bit                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                           | precursor_coeff(32)       | O          | precursor coefficient                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                           | cursor_coeff(32)          | O          | cursor coefficient                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                           | postcursor_coeff(32)      | O          | postcursor coefficient                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                           | status(32)                | O          | [0] : Request was processed<br>[1]: Request was rejected                                                                                                   |
|                                                                                                                                                                                                                                                                                                                           | valid(1)                  | O          | If 1, preset and coefficients have been captured from the DUT but not accepted or rejected.                                                                |

**Table 6-6 Equalization Tasks (Continued)**

| <b>Task Name</b>                                                                                                                                                                                                                                                                                       | <b>Arguments (length)</b>                   | <b>I/O</b>          | <b>Values</b>                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetEQUpstreamReceiverPresetHint<br><br>Downstream Ports:<br>Set the receiver preset hint transmitted in EQ TS2s to the DUT before equalization phase 0.<br><br>Upstream Ports: No effect                                                                                                               | lane_en(32)<br><br>preset(32)               | I<br><br>O          | Bit vector enable preset applies to.<br><br>preset value                                                                                                                        |
| GetEQUpstreamReceiverPresetHint<br><br>Downstream Ports:<br>Gets the suggested receiver preset hint advertised in EQTS2 before equalization phase 0<br><br>Upstream ports:<br>Gets the captured receiver preset hint received in EQ TS2s from the DUT before equalization phase 0. Upstream port only. | lane (32)<br><br>preset(32)<br><br>valid(1) | I<br><br>O<br><br>O | Lane number<br><br>preset value<br><br>If 1, receiver preset hint has been captured from the DUT.                                                                               |
| SetEQDownstreamReceiverPresetHint<br><br>Downstream Lanes: Sets the value of the downstream_receiver_preset_reg which controls the receiver preset hint advertised in EQTS1.<br><br>Upstream lanes: no effect                                                                                          | lane_en (32)<br><br>preset_hint(32)         | I<br><br>I          | 32 bit lane enable vector<br><br>Preset hint value                                                                                                                              |
| GetEQDownstreamReceiverPresetHint<br><br>Downstream lanes: Gets the value of the downstream_receiver_preset_reg which controls the receiver preset hint advertised in EQTS1.<br><br>Upstream lanes: Gets the preset hint value received in EQTS1.                                                      | lane(32)<br><br>preset_hint(32)             | I<br><br>I          | Lane to query<br><br>Preset hint value                                                                                                                                          |
| SetPerformEqualization<br><br>When 8G supported, this task is called, and then RetrainLink is called, Downstream port will initiate equalization. Valid for Downstream port only.                                                                                                                      | N/A                                         | N/a                 | Task sets the perform_equalization variable in the VIP. Note: VIP must not be running at 8G for equalization to be performed again. At 8g, use SetRequestEqualization to rerun. |

**Table 6-6 Equalization Tasks (Continued)**

| Task Name                                                                                                                                              | Arguments (length) | I/O | Values                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| SetRequestEqualization<br><br>Request equalization to be run again.<br>This task sets TS2 symbol 6, bit 7 in Recovery.RcvrCfg @8G. See Spec Table 4-6. | N/A                | N/A | Task sets the request_equalization variable in the VIP. Equalization will only be rerun if currently operating at 8G.                              |
| SetQuiesceGuarantee                                                                                                                                    |                    |     | Task sets the quiesce_guarantee variable in the VIP. This variable is reflected in Symbol 6 bit 6 of TS2 OS transmitted at 8G in Recovery.RcvrCfg. |
| GetEqualizationStatus                                                                                                                                  | status (32)        | 0   | Get equalization status values:<br>[0] = eq_complete<br>[1] = phase 1 complete<br>[2] = phase 2 complete<br>[3] = phase 3 complete                 |

## 6.6 Physical Layer Parameters

### 6.6.1 General Parameters

General Physical Layer parameters are listed in [Table 6-7](#).

**Table 6-7 Physical Layer general parameters**

| Parameter Name                                 | Settable VAR?* | Type    | Range                    | Default           | Description                                                                          |
|------------------------------------------------|----------------|---------|--------------------------|-------------------|--------------------------------------------------------------------------------------|
| <b>PCIE_SPEC_VER</b>                           |                |         |                          |                   |                                                                                      |
|                                                | Yes            | Real    | 1.1,<br>2.0,<br>2.1, 3.0 | PCIE_SPEC_VER_2_1 | See Include/pciesvc_parms.v: PCIE_SPEC_VER_*<br>Note: Please set this in the model.  |
| <b>PIPE_SPEC_VER</b>                           |                |         |                          |                   |                                                                                      |
|                                                | Yes            | Integer | 2, 4                     | PIPE_SPEC_VER_2   | See Include/pciesvc_parms.v: PIPE_SPEC_VER_*                                         |
| <b>INVERT_TX_POLARITY</b>                      |                |         |                          |                   |                                                                                      |
|                                                | Yes            | Integer | 0-1                      | 32'b0             | When a bit is set, the corresponding lane will invert polarity on all outgoing data. |
| <b>LOOPBACK_MASTER_SPEED_CHANGE_TIMEOUT_NS</b> |                |         |                          |                   |                                                                                      |
|                                                | Yes            | Integer |                          | 1000              | Speed change delay for loopback master.                                              |

**Table 6-7 Physical Layer general parameters (Continued)**

| Parameter Name                                               | Settable VAR?* | Type    | Range            | Default | Description                                                                                                                      |
|--------------------------------------------------------------|----------------|---------|------------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| <b>LOOPBACK_SLAVE_SPEED_CHANGE_TIMEOUT_NS</b>                |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | integer |                  | 2000    | Speed change delay for loopback slave                                                                                            |
| <b>LOOPBACK_EXIT_ELEC_IDLE_TIMEOUT_NS</b>                    |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | integer |                  | 2000    | Amount of time the LTSSM transmit electrical idle in Loopback.exit before entering detect.                                       |
| <b>LOOPBACK_MASTER_ENTER_COMPLIANCE_TX_TS1_TIMEOUT_NS</b>    |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | integer |                  | 2000    | Time before the loopback master enters loopback.active if no TS1s are received w/ the enter compliance bit set                   |
| <b>LOOPBACK_MASTER_NO_ENTER_COMPLIANCE_TX_TS1_TIMEOUT_NS</b> |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | integer |                  | 20000   | Time before the loopback master enters detect if no TS1s are received w/ the enter compliance bit clear;                         |
| <b>MAX_TX_SKP_INTERVAL_IN_SYMBOL_TIMES</b>                   |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | 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)        |
| <b>MIN_TX_SKP_INTERVAL_IN_BLOCKS</b>                         |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | Integer | 2 - large value  | 375     | Minimum number of blocks before the upper phy must schedule the insertion of a SKP ordered set (8GT/s)                           |
| <b>MAX_TX_SKP_INTERVAL_IN_BLOCKS</b>                         |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | Integer | 2 - large value  | 375     | Maximum number of blocks before the upper phy must schedule the insertion of a SKP ordered set (8GT/s)                           |
| <b>MIN_RX_SKP_INTERVAL_IN_SYMBOL_TIMES</b>                   |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | 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)      |
| <b>MAX_RX_SKP_INTERVAL_IN_SYMBOL_TIMES</b>                   |                |         |                  |         |                                                                                                                                  |
|                                                              | Yes            | 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) |
| <b>MIN_RX_SKP_INTERVAL_IN_BLOCKS</b>                         |                |         |                  |         |                                                                                                                                  |

**Table 6-7 Physical Layer general parameters (Continued)**

| <b>Parameter Name</b>                       | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>    | <b>Default</b> | <b>Description</b>                                                                                                                                               |
|---------------------------------------------|-----------------------|-------------|-----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             | Yes                   | 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)                                                        |
| <b>MAX_RX_SKP_INTERVAL_IN_BLOCKS</b>        |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | 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)                                                            |
| <b>MIN_TX_SKP_SYMBOLS_IN_ORDERED_SET</b>    |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 1-5             | 3              | Minimum number of SKP symbols in an ordered set at 2.5GT/s and 5GT/s.                                                                                            |
| <b>MAX_TX_SKP_SYMBOLS_IN_ORDERED_SET</b>    |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 1-5             | 3              | Maximum number of SKP symbols in an ordered set at 2.5GT/s and 5GT/s.                                                                                            |
| <b>MIN_TX_SKP_SYMBOLS_IN_ORDERED_SET_8G</b> |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 1-5             | 3              | Minimum number of SKP symbols in an ordered set at 8GT/s. Acceptable values: 1 – 5.                                                                              |
| <b>MAX_TX_SKP_SYMBOLS_IN_ORDERED_SET_8G</b> |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 1-5             | 3              | Maximum number of SKP symbols in an ordered set at 8GT/s. Acceptable values: 1 – 5.                                                                              |
| <b>DISABLE_SCRAMBLING</b>                   |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 0-1             | 0              | When set to '1' scrambling will be disabled, and the LTSSM will set the disable scrambling bit on all transmitted TS1 and TS2 ordered sets.                      |
| <b>MIN_TX_LANE_SKEW_2_5G</b>                |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 0-16            | 0              | Sets the minimum lane skew between transmit lanes in symbol times at 2.5Gb/s. Skew is randomized on every link down event, speed change, and at initial startup. |
| <b>MAX_TX_LANE_SKEW_2_5G</b>                |                       |             |                 |                |                                                                                                                                                                  |
|                                             | Yes                   | Integer     | 0-16            | 0              | Sets the maximum lane skew between transmit lanes in symbol times at 2.5Gb/s. Skew is randomized on every link down event, speed change, and at initial startup. |
| <b>MIN_TX_LANE_SKEW_5G</b>                  |                       |             |                 |                |                                                                                                                                                                  |

**Table 6-7 Physical Layer general parameters (Continued)**

| <b>Parameter Name</b>              | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b> | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------------------------------|-----------------------|-------------|--------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                    | Yes                   | Integer     | 0-16         | 0              | Sets the minimum lane skew between transmit lanes in symbol times at 5Gb/s. Skew is randomized on every link down event, speed change, and at initial startup.                                                      |
| <b>MAX_TX_LANE_SKEW_5G</b>         |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-16         | 0              | Sets the maximum lane skew between transmit lanes in symbol times at 5Gb/s. Skew is randomized on every link down event, speed change, and at initial startup.                                                      |
| <b>MIN_TX_LANE_SKEW_8G</b>         |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-16         | 0              | Sets the minimum lane skew between transmit lanes in symbol times at 8Gb/s. Skew is randomized on every link down event, speed change, and at initial startup.                                                      |
| <b>MAX_TX_LANE_SKEW_8G</b>         |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-16         | 0              | Sets the maximum lane skew between transmit lanes in symbol times at 8Gb/s. Skew is randomized on every link down event, speed change, and at initial startup.                                                      |
| <b>MAX_RX_LANE_SKEW_2_5G</b>       |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-16         | 1              | Maximum allowed lane skew before the VIP flags a skew violation on the receive side at 2.5G.                                                                                                                        |
| <b>MAX_RX_LANE_SKEW_5G</b>         |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-16         | 1              | Maximum allowed lane skew before the VIP flags a skew violation on the receive side at 5G.                                                                                                                          |
| <b>MAX_RX_LANE_SKEW_8G</b>         |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-16         | 1              | Maximum allowed lane skew before the VIP flags a skew violation on the receive side at 8G.                                                                                                                          |
| <b>ENABLE_RELAXED_SKP_CHECKING</b> |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-1          | 0              | When set, the Physical Layer will relax its checking for the number of SKP symbols in a SKP ordered set. This should only be set when the VIP is connected to a switch or repeater that does not regenerate refclk. |
| <b>MIN_SPIPE_PHYSTATUS_DELAY</b>   |                       |             |              |                |                                                                                                                                                                                                                     |
|                                    | Yes                   | Integer     | 0-1024       | 12 ns          | Minimum number of pipe clk cycles the VIP will wait before asserting phystatus indicating completion of a phy function (e.g. power state change or rate change). Valid only for SPIPE models.                       |

**Table 6-7 Physical Layer general parameters (Continued)**

| Parameter Name                                  | Settable VAR?* | Type    | Range  | Default | Description                                                                                                                                                                                   |
|-------------------------------------------------|----------------|---------|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MAX_SPIPE_PHYSTATUS_DELAY</b>                |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            | Integer | 0-1024 | 16 ns   | Maximum number of pipe clk cycles the VIP will wait before asserting phystatus indicating completion of a phy function (e.g. power state change or rate change). Valid only for SPIPE models. |
| <b>MIN_SPIPE_PRESET_COEFFICIENTS_DELAY</b>      |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            | Integer |        | 8 ns    | Minimum number of pipe clk cycles the SVC will wait before asserting local_tx_coefficients_valid when requested to get local preset coefficients. Valid only for SPIPE 8G models.             |
| <b>MAX_SPIPE_PRESET_COEFFICIENTS_DELAY</b>      |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            | Integer | 0-1024 | 12 ns   | Maximum number of pipe clk cycles the SVC will wait before asserting local_tx_coefficients_valid when requested to get local preset coefficients. Valid only for SPIPE 8G models.             |
| <b>GET_LOCAL_PRESET_COEFFICIENTS_TIMEOUT_NS</b> |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            | Integer | 0-1024 | 128     | Number of ns before an MPIPE flags a timeout on a get local preset coefficient request.                                                                                                       |
| <b>TX_SWING_2_5G</b>                            |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            | Integer | 0-1024 | 0       | Value driven on pipe signal tx_swing at 2.5G. Valid for mpipe 8G models only.                                                                                                                 |
| <b>TX_SWING_5G</b>                              |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            |         | 0-1024 | 0       | Value driven on pipe signal tx_swing at 5G. Valid for mpipe 8G models only.                                                                                                                   |
| <b>TX_SWING_8G</b>                              |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            |         | 0-1024 | 0       | Value driven on pipe signal tx_swing at 8G. Valid for mpipe 8G models only.                                                                                                                   |
| <b>TX_MARGIN_2_5G</b>                           |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            |         | 0-1024 | 0       | Value driven on pipe signal tx_margin at 2.5G. Valid for mpipe 8G models only.                                                                                                                |
| <b>TX_MARGIN_5G</b>                             |                |         |        |         |                                                                                                                                                                                               |
|                                                 | Yes            |         | 0-1024 | 0       | Value driven on pipe signal tx_margin at 5G. Valid for mpipe 8G models only.                                                                                                                  |
| <b>TX_MARGIN_8G</b>                             |                |         |        |         |                                                                                                                                                                                               |

**Table 6-7 Physical Layer general parameters (Continued)**

| Parameter Name              | Settable VAR?* | Type    | Range  | Default                     | Description                                                                                                                                                                            |
|-----------------------------|----------------|---------|--------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | Yes            |         | 0-1024 | 0                           | Value driven on pipe signal tx_margin at 8G.<br>Valid for mpipe 8G models only.                                                                                                        |
| <b>ASSERT_CLKREQ_N</b>      |                |         |        |                             |                                                                                                                                                                                        |
|                             | Yes            | Integer | 0-1    | 0                           | When PCIE_SPEC_VER is set to 3.0, this var can be used to force assertion of CLKREQ#. When not asserted, model will drive CLKREQ# signal to 1 since it is declared as tri1 internally. |
| <b>DISPLAY_NAME</b>         |                |         |        |                             |                                                                                                                                                                                        |
|                             | No             | String  |        | pciesvc_pl0                 | Default display name for the Physical Layer.                                                                                                                                           |
| <b>ENABLE_SYMBOL_LOG</b>    |                |         |        |                             |                                                                                                                                                                                        |
|                             | Yes            | Integer | 0-1    | 0                           | If enabled and if the symbol log has not been disabled via msglog_control (see “ <a href="#">Symbol Logging</a> ”) symbols will be written to the symbol log.                          |
| <b>MAX_SIZE_PACKET</b>      |                |         |        |                             |                                                                                                                                                                                        |
|                             | Yes            | Integer |        | 4096 + MAX_HEADER_SIZE      | Maximum possible header size plus maximum possible payload size. You can use this parameter to check the total packet size received from DUT.                                          |
| <b>MAX_HEADER_SIZE</b>      |                |         |        |                             |                                                                                                                                                                                        |
|                             | No             | Integer |        | 8 + MAX_NUM_PREFIXES*4 + 32 | Maximum possible header size plus maximum possible prefixes.                                                                                                                           |
| <b>MAX_NUM_PREFIXES</b>     |                |         |        |                             |                                                                                                                                                                                        |
|                             | No             | Integer |        | 0                           | Maximum possible prefixes.                                                                                                                                                             |
| <b>RX_STANDBY_SUPPORTED</b> |                |         |        |                             |                                                                                                                                                                                        |
|                             | Yes            | Integer |        | 1                           | When not supporting rx_standby, this parameter must be set to 0.                                                                                                                       |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “\_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

## 6.6.2 Physical Layer LTSSM-specific Parameters

Physical Layer LTSSM-specific parameters are listed in [Table 6-8](#).

**Table 6-8 LTSSM-specific parameters**

| Parameter Name                      | Settable VAR?* | Type    | Range | Default | Description                                                                                                                                                                                                                 |
|-------------------------------------|----------------|---------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SKIP_INITIAL_LINK_TRAINING</b>   |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-1   | 0       | Allows link training to be completely skipped. The VIP will enter L0 once lane alignment has been achieved.                                                                                                                 |
| <b>SKIP_POLLING_ACTIVE</b>          |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-1   | 0       | Allows Polling.Active to be skipped during link training. This helps speed up link training for cases not specifically testing the ltssm states.                                                                            |
| <b>NUM_RX_FTS_REQUIRED_2_5G</b>     |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-255 | 255     | The minimum number of FTS ordered sets required for a receiver to infer lock when exiting from electrical idle at 2.5GT/s.                                                                                                  |
| <b>NUM_RX_FTS_REQUIRED_5G</b>       |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-255 | 255     | The minimum number of FTS ordered sets required for a receiver to infer lock when exiting from electrical idle at 5GT/s.                                                                                                    |
| <b>NUM_TX_FTS_REQUIRED_2_5G</b>     |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-255 | 255     | When SKIP_INITIAL_LINK_TRAINING is set, this is the default N_FTS value which the LTSSM will use at 2.5G when exiting from P1. All subsequent exits will use a value obtained from training sets used during link training. |
| <b>NUM_TX_FTS_REQUIRED_5G</b>       |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-255 | 255     | When SKIP_INITIAL_LINK_TRAINING is set, this is the default N_FTS value which the LTSSM will use at 5G when exiting from P1. All subsequent exits will use a value obtained from training sets used during link training.   |
| <b>SET_TS_COMPLIANCE_RECEIVE</b>    |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-1   | 0       | When set, outgoing training sets will have the compliance receive bit set.                                                                                                                                                  |
| <b>TRANSMIT_MODIFIED_COMPLIANCE</b> |                |         |       |         |                                                                                                                                                                                                                             |
|                                     | Yes            | Integer | 0-1   | 0       | When set, the VIP will transmit the modified compliance pattern upon entry into Polling.Compliance.                                                                                                                         |

**Table 6-8 LTSSM-specific parameters (Continued)**

| Parameter Name                                   | Settable VAR?* | Type    | Range             | Default    | Description                                                                                                                                                                                             |
|--------------------------------------------------|----------------|---------|-------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DETECT QUIET TIMEOUT_NS</b>                   |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 120_000ns  | Timeout interval for Detect.Quiet state.                                                                                                                                                                |
| <b>DETECT QUIET SPEED CHANGE_NS</b>              |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 1000ns     | If the LTSSM enters Detect.Quiet at a speed other than 2.5G, this is the time the LTSSM will stay in Detect.Quiet to complete a speed change back to 2.5G regardless of whether data is being received. |
| <b>DETECT ACTIVE TIMEOUT_NS</b>                  |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 120_000ns  | Timeout interval for the Detect.Active state.                                                                                                                                                           |
| <b>POLLING ACTIVE TIMEOUT_NS</b>                 |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 240_000ns  | If at least one but not all unconfigured lanes detect a receiver, this configures the time between receiver detect sequences.                                                                           |
| <b>POLLING CONFIGURATION TIMEOUT_NS</b>          |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 480_0000ns | Timeout limit for the Polling.Configuration state.                                                                                                                                                      |
| <b>CONFIGURATION LINKWIDTH START TIMEOUT_NS</b>  |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 240_000ns  | Timeout value in the Configuration.Linkwidth state                                                                                                                                                      |
| <b>CONFIGURATION LINKWIDTH ACCEPT TIMEOUT_NS</b> |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 20_000ns   | Timeout value in the Configuration.Linkwidth state                                                                                                                                                      |
| <b>CONFIGURATION LANENUM WAIT TIMEOUT_NS</b>     |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 20_000ns   | Timeout value in the Configuration.Lanenum.Wait state                                                                                                                                                   |
| <b>CONFIGURATION COMPLETE TIMEOUT_NS</b>         |                |         |                   |            |                                                                                                                                                                                                         |
|                                                  | Yes            | Integer | 200 - large value | 20_000ns   | Timeout value in the Configuration.Configuratn.Complete state                                                                                                                                           |
| <b>CONFIGURATION IDLE TIMEOUT_NS</b>             |                |         |                   |            |                                                                                                                                                                                                         |

**Table 6-8 LTSSM-specific parameters (Continued)**

| <b>Parameter Name</b>               | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>      | <b>Default</b> | <b>Description</b>                                                                                                                                               |
|-------------------------------------|-----------------------|-------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     | Yes                   | Integer     | 200 - large value | 20_000ns       | Timeout value in the Configuration.Idle state                                                                                                                    |
| <b>RECOVERY_RCVRLOCK_TIMEOUT_NS</b> |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 200 - large value | 240_000ns      | Timeout in Recovery.RcvrLock state.                                                                                                                              |
| <b>RECOVERY_RVCRCFG_TIMEOUT_NS</b>  |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 200 - large value | 240_000ns      | Timeout value in Recovery.RcvrCfg                                                                                                                                |
| <b>RECOVERY_IDLE_TIMEOUT_NS</b>     |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 200 - large value | 20_000ns       | Timeout value in Recovery.Idle state.                                                                                                                            |
| <b>HOT_RESET_TIMEOUT_NS</b>         |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 200 - large value | 200_000ns      | Timeout value in Hot_Reset state.                                                                                                                                |
| <b>DISABLED_TIMEOUT_NS</b>          |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 200 - large value | 2_000ns        | Time before a downstream component will exit the Disabled state if no EIOS is detected                                                                           |
| <b>PHYSTATUS_TIMEOUT_NS</b>         |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 10 - large value  | 1_000ns        | When VIP pl is a pipe master, this is the time the pl will wait for a PHYSTATUS to go high to acknowledge a receiver detect, a rate change, or powerdown change. |
| <b>ENABLE_EXTENDED_SYNCH</b>        |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 0-1               | 0              | When set, the transmitter for each lane must transmit 1024 TS1 ordered sets before transitioning from Recovery.RcvrLock to Recover.RcvrConfig.                   |
| <b>MIN_NUM_TX_EIEOS_BEFORE_FTS</b>  |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 0-16              | 4              | Minimum number of EIEOS ordered sets transmitted before transmitting FTS. (5GT/s only)                                                                           |
| <b>MAX_NUM_TX_EIEOS_BEFORE_FTS</b>  |                       |             |                   |                |                                                                                                                                                                  |
|                                     | Yes                   | Integer     | 0-16              | 4              | Maximum number of EIEOS ordered sets transmitted before transmitting FTS. (5GT/s only)                                                                           |
| <b>NUM_TX_TS1_IN_POLLING_ACTIVE</b> |                       |             |                   |                |                                                                                                                                                                  |

**Table 6-8 LTSSM-specific parameters (Continued)**

| <b>Parameter Name</b>                            | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>      | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|--------------------------------------------------|-----------------------|-------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                  | Yes                   | Integer     | 16-4096           | 1024           | Sets the number of training sets the LTSSM must transmit in Polling.Active before exiting this state.                                                                                                                                                                                       |
| <b>RECOVERY_SPEED_ELECTRICAL_IDLE_TIME_IN_NS</b> |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | Yes                   | Integer     | 100 - large value | 1000           | Number of ns the transmitter is required to be transmitting electrical idle during a speed change once the receiver has detected/inferred electrical idle in the state RECOVERY_SPEED.                                                                                                      |
| <b>INFERRRED_ELECTRICAL_IDLE_SKP_TIME_NS</b>     |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | Yes                   | Integer     | 200 - large value | 12800          | The amount of time in L0 before the LTSSM will infer electrical idle if no SKP ordered sets are received.                                                                                                                                                                                   |
| <b>ALLOW_RATE_POWER_SIMULTANEOUS_CHANGE</b>      |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | Yes                   | Integer     | 0-1               | 1              | When set to a 1, the VIP in pipe slave mode will not flag rate and powerdown signals changing simultaneously. When set to 0, simultaneous rate and powerdown changes will be flagged.                                                                                                       |
| <b>ENABLE_RELAXED_SKP_CHECKING</b>               |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | Yes                   | Integer     | 0-1               | 0              | When set, the VIP will not flag skp ordered sets received with greater or less than 3 skp symbols. This should only be set when there are repeaters or switches between the root and endpoint.                                                                                              |
| <b>USER_TX_TS1_LANE_MASK</b>                     |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | Yes                   | Integer     | Any 32-bit value  | 32'hFFFF_FF FF | A bitwise lane enable for user training sets. A 'b1 enables user training sets for a particular lane and 'b0 disables user training sets. Bit 0 of this vector corresponds to lane 0, bit 1 corresponds to lane 1 and so on. Refer to the user training set tasks section for more details. |
| <b>USER_TX_TS2_LANE_MASK</b>                     |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | Yes                   | Integer     | Any 32-bit value  | 32'hFFFF_FF FF | A bitwise lane enable for user training sets. A 'b1 enables user training sets for a particular lane and 'b0 disables user training sets. Bit 0 of this vector corresponds to lane 0, bit 1 corresponds to lane 1 and so on. Refer to the user training set tasks section for more details. |
| <b>IS_TX_DOWNSTREAM</b>                          |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |
|                                                  | No                    | Integer     | 0-1               | 0              | Indicates whether the transmitter is downstream or not. This affects link training behavior.                                                                                                                                                                                                |
| <b>IS_PIPE_MASTER</b>                            |                       |             |                   |                |                                                                                                                                                                                                                                                                                             |

**Table 6-8 LTSSM-specific parameters (Continued)**

| <b>Parameter Name</b>                                                                                                                                                                                                                                                                                                       | <b>Settable VAR?*</b> | <b>Type</b> | <b>Range</b>     | <b>Default</b> | <b>Description</b>                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------|------------------|----------------|------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                             | No                    | Integer     | 0-1              | 1              | When set to a 1, the VIP will behave as a pipe master. When set to 0, the VIP will behave as a pipe slave. |
| <b>ENABLE_EQUALIZATION_PHASE</b>                                                                                                                                                                                                                                                                                            |                       |             |                  |                |                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes                   | Integer     | 0, 1, 3          | 3              | Enable the last equalization phase.<br>NOTE: 0 will disable equalization.                                  |
| <b>ENABLE_EQUALIZATION_COEFFICIENT_CHECKS</b>                                                                                                                                                                                                                                                                               |                       |             |                  |                |                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes                   | Integer     | Any 32-bit value | 0              | Enables equalization coefficient checks. Default is off.                                                   |
| <b>MIN_L1_IDLE_TIME_NS_VAR</b>                                                                                                                                                                                                                                                                                              |                       |             |                  |                |                                                                                                            |
|                                                                                                                                                                                                                                                                                                                             | Yes                   | Integer     | Any 32-bit value | 0              | Controls the min amount of time the VIP will remain in L1.Idle at speeds other than 2.5G.                  |
| *Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module. |                       |             |                  |                |                                                                                                            |

### 6.6.3 Equalization Parameters

Equalization parameters are listed in [Table 6-9](#).

**Table 6-9 Equalization parameters**

| <b>Parameter Name</b>                 | <b>Settable VAR?</b> | <b>Default</b> | <b>Description</b>                                                                            |
|---------------------------------------|----------------------|----------------|-----------------------------------------------------------------------------------------------|
| ENABLE_EQUALIZATION_VERIFICATION_MODE | YES                  | 0              | Enable equalization checking. See other Vars/Interface tasks to setup proper checking in SVC. |
| ENABLE_EQUALIZATION_PHASE             | YES                  | 3              | Enable the last equalization phase. Valid values = 0, 2, 3. 0 will disable equalization.      |
| NUM_ADDITIONAL_TS_EQ_BEFORE_TRANS_EQ0 | YES                  | 0              | Number of additional TS1 to transmit before transitioning out of phase 0 equalization.        |
| NUM_ADDITIONAL_TS_EQ_BEFORE_TRANS_EQ1 | YES                  | 0              | Number of additional TS1 to transmit before transitioning out of phase 1 equalization.        |

**Table 6-9 Equalization parameters (Continued)**

| Parameter Name                                     | Settable VAR? | Default | Description                                                                                                                                                                                                                                              |
|----------------------------------------------------|---------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NUM_ADDITIONAL_TS_EQ_BEFORE_TRANS_EQ0              | YES           | 0       | Number of additional TS1 to transmit before transitioning out of phase 2 equalization.                                                                                                                                                                   |
| NUM_ADDITIONAL_TS_EQ_BEFORE_TRANS_EQ0              | YES           | 0       | Number of additional TS1 to transmit before transitioning out of phase 3 equalization.                                                                                                                                                                   |
| RECOVERY_EQUALIZATION_PHASE0_UPSTREAM_TIMEOUT_NS   | YES           | 12,000  | Timeout for upstream lanes in phase 0 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| RECOVERY_EQUALIZATION_PHASE1_UPSTREAM_TIMEOUT_NS   | YES           | 12,000  | Timeout for upstream lanes in phase 1 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| RECOVERY_EQUALIZATION_PHASE2_UPSTREAM_TIMEOUT_NS   | YES           | 24,000  | Timeout for upstream lanes in phase 2 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| RECOVERY_EQUALIZATION_PHASE3_UPSTREAM_TIMEOUT_NS   | YES           | 32_000  | Timeout for upstream lanes in phase 3 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| RECOVERY_EQUALIZATION_PHASE1_DOWNSTREAM_TIMEOUT_NS | YES           | 24,000  | Timeout for upstream lanes in phase 1 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| RECOVERY_EQUALIZATION_PHASE2_DOWNSTREAM_TIMEOUT_NS | YES           | 32_000  | Timeout for upstream lanes in phase 2 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| RECOVERY_EQUALIZATION_PHASE3_DOWNSTREAM_TIMEOUT_NS | YES           | 24,000  | Timeout for upstream lanes in phase 3 of recovery.equalization.<br>Default = Spec_value/1000                                                                                                                                                             |
| REJECT_PRESET_COEFF_REQUEST                        | Yes           | 0       | Each bit corresponds to a lane. Valid only in Equalization Phase 2 for Downstream Port and Phase 3 for Upstream port. Setting a bit forces the corresponding lane for side of the link receiving preset/coefficient requests to reject all new requests. |
| SET_TX_TS1_RESET_EIEOS_INTERVAL_COUNT_BIT          | Yes           | 0       | When set and transmitting at 8G in equalization phases, TS1s are sent with the Reset_EEOS_Interval_Count bit set.                                                                                                                                        |

**Table 6-9 Equalization parameters (Continued)**

| Parameter Name            | Settable VAR? | Default | Description                                                                                                                                                              |
|---------------------------|---------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FULL_SWING                | NO            | 6'd48   | Default fs value port will advertise in outgoing EQTS. It is recommended to use the SetTxTS1FSLF task to change this value rather than using a defparam.                 |
| LOW_FREQUENCY_COEFFICIENT | NO            | 'd3     | Default LF value port will advertise in outgoing EQTS. It is recommended to use the SetTxTS1FSLF task to change this value rather than using a defparam.                 |
| PRECURSOR_COEFFICIENT     | NO            | 0       | Default precursor coefficient value that is loaded into all preset settings. Users should use the task SetEQPreset2CoeffTable to change preset to coefficient mappings.  |
| CURSOR_COEFFICIENT        | NO            | 36      | Default cursor coefficient value that is loaded into all preset settings. Users should use the task SetEQPreset2CoeffTable to change preset to coefficient mappings.     |
| POSTCURSOR_COEFFICIENT    | NO            | 12      | Default postcursor coefficient value that is loaded into all preset settings. Users should use the task SetEQPreset2CoeffTable to change preset to coefficient mappings. |

## 6.7 Physical Layer Events

Physical Layer events are listed in [Table 6-10](#).

**Table 6-10 Physical Layer events**

| Event Name                       | Description                                                                                                                                                                  | Usage                                                                   |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| event_rx_new_preset_coefficients | Event triggered when 2 TS1 OS are received with requested presets and/or coefficients. Triggered in Phase 2 for SVC as Downstream port and Phase 3 for SVC as Upstream port. | Can be used to determine when to call GetEQRequestedPresetCoefficients. |
| event_eq_phase_complete          | An equalization phase has completed. Triggered each time phase 0, 1, 2, or 3 completes.                                                                                      | Can be used to check the equalization_complete_var                      |
| event_eq_complete                | Equalization has completed. Asserted on LTSSM transition from equalization state to Recovery.RcvrLock.                                                                       |                                                                         |

## 6.8 Physical Layer ASCII Signals

Physical Layer ASCII signals are listed in [Table 6-11](#).

**Table 6-11 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.                             |

## 6.9 Physical Layer Statistics

Types of Physical Layer statistics are listed in [Table 6-12](#).

**Table 6-12 Physical Layer Statistics**

| <b>Stat Name</b>                        | <b>Width</b>      | <b>Description</b>                                                                                 |
|-----------------------------------------|-------------------|----------------------------------------------------------------------------------------------------|
| stat_num_rx_skp_ordered_sets            | 32                | Number of skip ordered sets received on configured lanes                                           |
| stat_num_tx_skp_ordered_sets            | 32                | Number of skip ordered sets transmitted on configured lanes.                                       |
| stat_num_tx_ts1                         | Array of integers | Number of TS1 sent per lane.                                                                       |
| stat_num_tx_ts2                         | Array of integers | Number of TS2 sent per lane.                                                                       |
| stat_num_rx_ts1                         | Array of integers | Number of TS1 received per lane                                                                    |
| stat_num_rx_ts2                         | Array of integers | Number of TS2 ordered sets received per lane                                                       |
| stat_num_rx_eios                        | Array of integers | Number of EIOS received per lane.                                                                  |
| stat_num_rx_eieos                       | Array of integers | Number of EIEOS received per lane.                                                                 |
| stat_num_rx_fts                         | Array of integers | Number of FTS received per lane.                                                                   |
| stat_num_rx_compliance_pattern          | Array of integers | Number of compliance pattern sequences received per lane.                                          |
| stat_num_rx_modified_compliance_pattern | Array of integers | Number of modified compliance pattern sequences received per lane.                                 |
| stat_num_loopback_pattern               | Array of integers | Number of times the VIP detected its own loopback pattern while a loopback master.                 |
| stat_num_hot_resets_received            | 32                | Number of times the LTSSM entered hot reset by receiving training sets with the hot reset bit set. |
| stat_num_hot_resets_initiated           | 32                | Number of times the LTSSM initiated a hot reset.                                                   |
| stat_num_link_disabled                  | 32                | Number of times the link entered the DISABLED state.                                               |
| stat_num_l0s_tx_entry                   | 32                | Number of times the transmit side of the link entered L0s.                                         |
| stat_num_l0s_rx_entry                   | 32                | Number of times the receive side of the link entered L0s.                                          |
| stat_num_l1_entry                       | 32                | Number of times the LTSSM entered the L1 low power state.                                          |
| stat_num_link_up                        | 32                | Number of times the LTSSM declares the link up.                                                    |
| stat_num_link_down                      | 32                | Number of times the LTSSM changes the link from up to down.                                        |
| stat_num_retrain_request                | 32                | Number of times the LTSSM is requested to retrain the link.                                        |
| stat_num_ei_tx_ts1_missing_comma        | Array of integers | Number of times a TS1 missing comma EI was injected on each lane.                                  |
| stat_num_ei_tx_ts1_corrupt_link_number  | Array of integers | Number of times a TS1 link number EI was injected on each lane.                                    |
| stat_num_ei_tx_ts1_corrupt_lane_number  | Array of integers | Number of times a TS1 lane number EI was injected on each lane.                                    |

**Table 6-12 Physical Layer Statistics (Continued)**

| <b>Stat Name</b>                            | <b>Width</b>      | <b>Description</b>                                                                    |
|---------------------------------------------|-------------------|---------------------------------------------------------------------------------------|
| stat_num_ei_tx_ts1_corrupt_n_fts            | Array of integers | Number of times a TS1 N_FTS EI was injected on each lane.                             |
| stat_num_ei_tx_ts1_corrupt_data_rate        | Array of integers | Number of times a TS1 data rate EI was injected on each lane                          |
| stat_num_ei_tx_ts1_corrupt_training_control | Array of integers | Number of times a TS1 training control EI was injected on each lane                   |
| stat_num_ei_tx_ts1_corrupt_identifier       | Array of integers | Number of times a TS1 identifier EI was injected on each lane                         |
| stat_num_ei_tx_ts1_make_ts2                 | Array of integers | Number of times a make TS2 EI was injected on each lane.                              |
| stat_num_ei_tx_ts1_corrupt_disparity        | Array of integers | Number of times a TS1 corrupt disparity EI was injected on each lane                  |
| stat_num_ei_tx_ts1_invalid_codeword         | Array of integers | Number of times a TS1 invalid codeword EI was injected on each lane                   |
| stat_num_ei_tx_ts2_missing_comma            | Array of integers | Number of times a TS2 missing comma EI was injected on each lane.                     |
| stat_num_ei_tx_ts2_corrupt_link_number      | Array of integers | Number of times a TS2 link number EI was injected on each lane.                       |
| stat_num_ei_tx_ts2_corrupt_lane_number      | Array of integers | Number of times a TS2 lane number EI was injected on each lane.                       |
| stat_num_ei_tx_ts2_corrupt_n_fts            | Array of integers | Number of times a TS2 N_FTS EI was injected on each lane.                             |
| stat_num_ei_tx_ts2_corrupt_data_rate        | Array of integers | Number of times a TS2 data rate EI was injected on each lane                          |
| stat_num_ei_tx_ts2_corrupt_training_control | Array of integers | Number of times a TS2 training control EI was injected on each lane                   |
| stat_num_ei_tx_ts2_corrupt_identifier       | Array of integers | Number of times a TS2 identifier EI was injected on each lane                         |
| stat_num_ei_tx_ts2_make_ts1                 | Array of integers | Number of times a make TS1 EI was injected on each lane.                              |
| stat_num_ei_tx_ts2_corrupt_disparity        | Array of integers | Number of times a TS2 corrupt disparity EI was injected on each lane                  |
| stat_num_ei_tx_ts2_invalid_codeword         | Array of integers | Number of times a TS2 invalid codeword EI was injected on each lane                   |
| stat_num_eq_phase_[1 2 3]_successful        | 32                | Number of successful completions for equalization phase [1 2 3].                      |
| stat_num_eq_completions                     | 32                | Number of times Equalization has completed.                                           |
| stat_num_rx_eq_preset_requests              | array of integers | Number of preset requests received. Preset value changes and use_preset field is set. |

**Table 6-12 Physical Layer Statistics (Continued)**

| <b>Stat Name</b>                             | <b>Width</b>      | <b>Description</b>                                                                                          |
|----------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------|
| stat_num_rx_eq_coefficient_requests          | array of integers | Number of coefficient requests received. At least 1 coefficient field changes and use_preset is deasserted. |
| stat_num_tx_eq_preset_requests               | array of integers | Number of preset requests transmitted.                                                                      |
| stat_num_tx_eq_coefficient_requests          | array of integers | Number of coefficient requests transmitted.                                                                 |
| stat_num_rx_eq_preset_requests_rejected      | array of integers | Number of preset requests which were rejected.                                                              |
| stat_num_rx_eq_coefficient_requests_rejected | array of integers | Number of coefficient requests which were rejected.                                                         |
| stat_num_eq_phase_1_successful               | 32                | Number of successful completions for equalization phase [1 2 3].                                            |
| stat_num_eq_phase_2_successful               | 32                | Number of successful completions for equalization phase [1 2 3].                                            |
| stat_num_eq_phase_3_successful               | 32                | Number of successful completions for equalization phase [1 2 3].                                            |
| stat_num_eq_completions                      | 32                | Number of times Equalization has completed.                                                                 |

## 6.10 LTSSM Error Injection Controls

Physical Layer LTSSM error injection control parameters are listed in [Table 6-13](#).

**Table 6-13 LTSSM error injection control parameters**

| <b>Parameter Name</b>                                                     | <b>Type</b> | <b>Range</b>     | <b>Description</b>                                                                          | <b>DUT Action</b>                                                                                                                         |
|---------------------------------------------------------------------------|-------------|------------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EI_TX_TRAINING_PERCENTAGE</b>                                          |             |                  |                                                                                             |                                                                                                                                           |
|                                                                           | Integer     | 0-100            | Percentage probability of a training type EI occurring                                      |                                                                                                                                           |
| <b>EI_TX_TRAINING_FORCE_POLLING_ACTIVE_TIMEOUT_WEIGHT</b>                 |             |                  |                                                                                             |                                                                                                                                           |
|                                                                           | Integer     | Typically 0-1000 | Force the LTSSM to stay in Polling.Active state until it has timed out.                     | Dut should transition to either Detect.Quiet transmit electrical idle.                                                                    |
| <b>EI_TX_TRAINING_FORCE_POLLING_CONFIGURATION_TIMEOUT_WEIGHT</b>          |             |                  |                                                                                             |                                                                                                                                           |
|                                                                           | Integer     | Typically 0-1000 | Force the LTSSM to stay in Polling.Configuration until it has timed out.                    | DUT should transition to Detect after the timeout and cease transmitting.                                                                 |
| <b>EI_TX_TRAINING_FORCE_CONFIGURATION_LINKWIDTH_START_TIMEOUT_WEIGHT</b>  |             |                  |                                                                                             |                                                                                                                                           |
|                                                                           | Integer     | Typically 0-1000 | Force the LTSSM stay in Configuration.Linkwidth.Start until the timeout period has expired. | DUT should timeout and transition to Detect after its timer has expired. No TS1 or TS2 ordered sets should be detected after the timeout. |
| <b>EI_TX_TRAINING_FORCE_CONFIGURATION_LINKWIDTH_ACCEPT_TIMEOUT_WEIGHT</b> |             |                  |                                                                                             |                                                                                                                                           |

**Table 6-13 LTSSM error injection control parameters (Continued)**

| <b>Parameter Name</b>                                                   | <b>Type</b> | <b>Range</b>     | <b>Description</b>                                                                            | <b>DUT Action</b>                                                                                                                                                               |
|-------------------------------------------------------------------------|-------------|------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in Linkwidth.Accept until the timeout period has expired.             | Dut should timeout and transition to Detect after its timer has expired. No TS1 or TS2 ordered sets should be sent after transitioning to Detect.                               |
| <b>EI_TX_TRAINING_FORCE_CONFIGURATION_LANENUM_ACCEPT_TIMEOUT_WEIGHT</b> |             |                  |                                                                                               |                                                                                                                                                                                 |
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in Configuration.Lanenum.Accept until the timeout period has expired. | Dut should timeout and transition to detect after its timer has expired.                                                                                                        |
| <b>EI_TX_TRAINING_CONFIGURATION_COMPLETE_TIMEOUT_WEIGHT</b>             |             |                  |                                                                                               |                                                                                                                                                                                 |
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in Configuration.Complete until the timeout period has expired.       | Dut should timeout and transition to detect after the timer has expired. No TS1 or TS2 ordered sets should be sent after the timeout.                                           |
| <b>EI_TX_TRAINING_CONFIGURATION_IDLE_TIMEOUT_WEIGHT</b>                 |             |                  |                                                                                               |                                                                                                                                                                                 |
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in Configuration.Idle until the timeout period has expired.           | Dut should timeout and transition to detect after a 2ms timer has expired. No transmission of any kind should be sent after the timeout.                                        |
| <b>EI_TX_TRAINING_FORCE_RECOVERY_RCVRLOCK_TIMEOUT_WEIGHT</b>            |             |                  |                                                                                               |                                                                                                                                                                                 |
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in Recovery.Rcvrlock until the timeout period has expired.            | Depending on conditions, the DUT should transition to Recovery.Rvcrcfg or Recovery.Speed.                                                                                       |
| <b>EI_TX_TRAINING_FORCE_RECOVERY_RCVRCFG_TIMEOUT_WEIGHT</b>             |             |                  |                                                                                               |                                                                                                                                                                                 |
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in Recovery.Rvcrcfg until the timeout period has expired.             | Dut should transition to the detect state                                                                                                                                       |
| <b>EI_TX_TRAINING_FORCE_RECOVERY_IDLE_TIMEOUT_WEIGHT</b>                |             |                  |                                                                                               |                                                                                                                                                                                 |
|                                                                         | Integer     | Typically 0-1000 | Force the LTSSM to stay in the Recovery.Idle until the timeout period has expired.            | Dut may initially transition to L0, but after LTSSM has timed out the DUT should detect ordered sets and transition to Recovery.Rcvrlock when it detects training ordered sets. |

## 6.11 TS1 Error Injection Controls

### 6.11.1 TS1 Randomized Injections

Controls that can be used to randomize by weighting various types of errors are listed in [Table 6-14](#).

**Table 6-14 TS1 error injection control parameters**

| <b>Parameter Name</b>                            | <b>Type</b> | <b>Range</b>     | <b>Description</b>                                                                                                                                      | <b>DUT Action</b>                                                                                     |
|--------------------------------------------------|-------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>EI_TX_TS1_PERCENTAGE</b>                      |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | 0-100            | Percentage probability of a TS1 type EI occurring                                                                                                       |                                                                                                       |
| <b>EI_TX_TS1_LANE_MASK</b>                       |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Any 32-bit value | A bitwise enable mask for only applying TX_TS1 EIs to certain lanes. Default value is 32'hFFFF_FFFF (all lanes enabled).                                |                                                                                                       |
| <b>EI_TX_TS1_MISSING_COMMA_WEIGHT</b>            |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | Changes the starting K28.5 of a TS1 into random data.                                                                                                   | DUT should not detect a TS1 and reset its consecutive training set count.                             |
| <b>EI_TX_TS1_CORRUPT_LINK_NUMBER_WEIGHT</b>      |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | If PAD is supposed to be sent, the assigned link number will be sent instead. If the link number is supposed to be sent, then PAD will be sent instead. | This EI should reset the consecutive count of training sets and halt link training progress.          |
| <b>EI_TX_TS1_CORRUPT_LANE_NUMBER_WEIGHT</b>      |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | If PAD is supposed to be sent, the assigned lane number will be sent instead. If the lane number is supposed to be sent, then PAD will be sent instead. | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS1_CORRUPT_N_FTS_WEIGHT</b>            |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | Sends a PAD in place of data on the N_FTS byte of a training set.                                                                                       | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS1_CORRUPT_DATA_RATE_WEIGHT</b>        |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | Sends a PAD in place of data on the data rate field of a training set.                                                                                  | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS1_CORRUPT_TRAINING_CONTROL_WEIGHT</b> |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | Sends PAD in place of the training control field of a training set.                                                                                     | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS1_CORRUPT_IDENTIFIER_WEIGHT</b>       |             |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer     | Typically 0-1000 | Sends random data in place of one of the training control identifiers (bytes 6-15 of a training set).                                                   | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS1_MAKE_TS2_WEIGHT</b>                 |             |                  |                                                                                                                                                         |                                                                                                       |

**Table 6-14 TS1 error injection control parameters (Continued)**

| <b>Parameter Name</b>                     | <b>Type</b> | <b>Range</b>     | <b>Description</b>                                                                          | <b>DUT Action</b>                                                                                          |
|-------------------------------------------|-------------|------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|                                           | Integer     | Typically 0-1000 | Changes all of the TS1 identifier byte of a TS1 set (bytes 6-15) into TS2 identifier bytes. | DUT should detect a TS2 instead of a TS1. The net result of detecting a TS2 ordered set is state specific. |
| <b>EI_TX_TS1_CORRUPT_DISPARITY_WEIGHT</b> |             |                  |                                                                                             |                                                                                                            |
|                                           | Integer     | Typically 0-1000 | Sends the wrong disparity on a random data byte of a training set.                          | This EI should reset the consecutive count of received training sets and halt link training progress.      |
| <b>EI_TX_TS1_INVALID_CODEWORD_WEIGHT</b>  |             |                  |                                                                                             |                                                                                                            |
|                                           | Integer     | Typically 0-1000 | Replaces random data byte of a training set with an invalid codeword.                       | This EI should reset the consecutive count of received training sets and halt link training progress.      |

### 6.11.2 Directed Sequences of TS1 Injected Errors

For advanced LTSSM testing, the `SetEiTxTs1Pattern` directed task can be used to send specified sequences of good and bad training sets. The `SetEiTxTs1Pattern` task is described in [Table 6-15](#).

In order to use this task, `EI_TX_TS1_PERCENTAGE_VAR` must be set to 0. All other weights and the lane mask need to be set in order to choose what type of error will be selected on bad TS1s

**Table 6-15 Task to send sequences of training sets**

| <b>Task Name</b>  | <b>Arguments (length)</b>                                                                | <b>I/O</b>                   | <b>Values</b>                                                                                                                                                                                                                                                                                             |
|-------------------|------------------------------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetEiTxTs1Pattern | enable_i (32)<br><br>Defines a constrained random burst of TS1 ordered sets with errors. | I<br><br>I<br><br>I<br><br>I | '1' enables the training set pattern, '0' disables it<br><br>Minimum number of bad TS1 sets in the error burst.<br><br>Maximum number of bad TS1 sets in the error burst.<br><br>Minimum number of good TS1 sets between the error burst.<br><br>Minimum number of good TS1 sets between the error burst. |

## 6.12 TS2 Error Injection Controls

### 6.12.1 TS2 Randomized Injections

Controls that can be used to randomize by weighting various types of errors are listed in [Table 6-16](#).

**Table 6-16 TS2 randomized injection control parameters**

| Parameter Name                                   | Type    | Range            | Description                                                                                                                                             | DUT Action                                                                                            |
|--------------------------------------------------|---------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>EI_TX_TS2_PERCENTAGE</b>                      |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | 0-100            | Percentage probability of a TS2 type EI occurring                                                                                                       |                                                                                                       |
| <b>EI_TX_TS2_LANE_MASK</b>                       |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Any 32-bit value | A bitwise enable mask for only applying TX_TS1 EIs to certain lanes. Default value is 32'hFFFF_FFFF (all lanes enabled).                                |                                                                                                       |
| <b>EI_TX_TS2_MISSING_COMMAS_WEIGHT</b>           |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Typically 0-1000 | Changes the starting K28.5 of a TS1 into random data.                                                                                                   | DUT should not detect a TS1 and reset its consecutive training set count.                             |
| <b>EI_TX_TS2_CORRUPT_LINK_NUMBER_WEIGHT</b>      |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Typically 0-1000 | If PAD is supposed to be sent, the assigned link number will be sent instead. If the link number is supposed to be sent, then PAD will be sent instead. | This EI should reset the consecutive count of training sets and halt link training progress.          |
| <b>EI_TX_TS2_CORRUPT_LANE_NUMBER_WEIGHT</b>      |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Typically 0-1000 | If PAD is supposed to be sent, the assigned lane number will be sent instead. If the lane number is supposed to be sent, then PAD will be sent instead. | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS2_CORRUPT_N_FTS_WEIGHT</b>            |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Typically 0-1000 | Sends a PAD in place of data on the N_FTS byte of a training set.                                                                                       | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS2_CORRUPT_DATA_RATE_WEIGHT</b>        |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Typically 0-1000 | Sends a PAD in place of data on the data rate field of a training set.                                                                                  | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS2_CORRUPT_TRAINING_CONTROL_WEIGHT</b> |         |                  |                                                                                                                                                         |                                                                                                       |
|                                                  | Integer | Typically 0-1000 | Sends PAD in place of the training control field of a training set.                                                                                     | This EI should reset the consecutive count of received training sets and halt link training progress. |
| <b>EI_TX_TS2_CORRUPT_IDENTIFIER_WEIGHT</b>       |         |                  |                                                                                                                                                         |                                                                                                       |

**Table 6-16 TS2 randomized injection control parameters (Continued)**

| Parameter Name                             | Type    | Range            | Description                                                                                           | DUT Action                                                                                                 |
|--------------------------------------------|---------|------------------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|                                            | Integer | Typically 0-1000 | Sends random data in place of one of the training control identifiers (bytes 6-15 of a training set). | This EI should reset the consecutive count of received training sets and halt link training progress.      |
| <b>EI_TX_TS2_MAKE_TS1_WEIGHT</b>           |         |                  |                                                                                                       |                                                                                                            |
|                                            | Integer | Typically 0-1000 | Changes all of the TS2 identifier byte of a TS1 set (bytes 6-15) into TS21 identifier bytes.          | DUT should detect a TS1 instead of a TS2. The net result of detecting a TS1 ordered set is state specific. |
| <b>EI_TX_TS2_CORRUPT_DISPARIETY_WEIGHT</b> |         |                  |                                                                                                       |                                                                                                            |
|                                            | Integer | Typically 0-1000 | Sends the wrong disparity on a random data byte of a training set.                                    | This EI should reset the consecutive count of received training sets and halt link training progress.      |
| <b>EI_TX_TS2_INVALID_CODEWORD_WEIGHT</b>   |         |                  |                                                                                                       |                                                                                                            |
|                                            | Integer | Typically 0-1000 | Replaces random data byte of a training set with an invalid codeword.                                 | This EI should reset the consecutive count of received training sets and halt link training progress.      |

### 6.12.2 Directed Sequences of TS2 Injected Errors

For advanced LTSSM testing, the `SetEiTxs2Pattern` directed task (see [Table 6-17](#)) can be used to send specified sequences of good and bad training sets. In order to use this task, `EI_TX_TS2_PERCENTAGE_VAR` must be set to 0. All other weights and the lane mask need to be set in order to choose what type of error will be selected on bad TS1s.

**Table 6-17 SetEiTxs2Pattern task**

| Task Name                                                        | Arguments (length)                   | I/O | Values                                                   |
|------------------------------------------------------------------|--------------------------------------|-----|----------------------------------------------------------|
| <code>SetEiTxs2Pattern</code>                                    | <code>enable_i (32)</code>           | I   | '1' enables the training set pattern, '0' disables it    |
| Defines a constrained random burst TS1 ordered sets with errors. | <code>min_ei_tx_ts1_burst_i</code>   | I   | Minimum number of bad TS2 sets in the error burst.       |
|                                                                  | <code>max_ei_tx_ts1_burst_i</code>   | I   | Maximum number of bad TS2 sets in the error burst.       |
|                                                                  | <code>min_ei_tx_ts1_spacing_i</code> | I   | Minimum number of good TS2 sets between the error burst. |
|                                                                  | <code>max_ei_tx_ts1_spacing_i</code> | I   | Minimum number of good TS2 sets between the error burst. |

## 6.13 Ordered Set Error Injection Controls

### 6.13.1 EIOS Injected Errors

Controls that can be used to inject errors into EIOS blocks are listed in [Table 6-18](#).

**Table 6-18 EIOS injected errors**

| <b>Parameter Name</b>                 | <b>Settable VAR*</b> | <b>Default Value</b> | <b>Description</b>                                                                                      |
|---------------------------------------|----------------------|----------------------|---------------------------------------------------------------------------------------------------------|
| EI_TX_EIOS_PERCENTAGE                 | YES                  | 0                    | Percentage probability of an EIOS type EI occurring                                                     |
| EI_TX_EIOS_LANE_MASK                  | YES                  | 32'hFFF F_FFFF       | A bitwise enable mask for only applying TX_EIOS EIs to certain lanes.                                   |
| EI_TX_EIOS_INVALID_DATA_BYTE0_WEIGHT  | YES                  | 0                    | Changes the first byte of an EIOS to randomly generated data.                                           |
| EI_TX_EIOS_INVALID_DATA_BYTE1_WEIGHT  | YES                  | 0                    | Changes byte one of the EIOS to randomly generated data.                                                |
| EI_TX_EIOS_INVALID_DATA_BYTE2_WEIGHT  | YES                  | 0                    | Changes byte two of the EIOS to randomly generated data.                                                |
| EI_TX_EIOS_INVALID_DATA_BYTE3_WEIGHT  | YES                  | 0                    | Changes byte three of the EIOS to randomly generated data.                                              |
| EI_TX_EIOS_INVALID_DATA_BYTE4_WEIGHT  | YES                  | 0                    | Changes byte four of the EIOS to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_EIOS_INVALID_DATA_BYTE5_WEIGHT  | YES                  | 0                    | Changes byte five of the EIOS to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_EIOS_INVALID_DATA_BYTE6_WEIGHT  | YES                  | 0                    | Changes byte six of the EIOS to randomly generated data. Valid only at speeds of 8G and above.          |
| EI_TX_EIOS_INVALID_DATA_BYTE7_WEIGHT  | YES                  | 0                    | Changes byte seven of the EIOS symbol to randomly generated data. Valid only at speeds of 8G and above. |
| EI_TX_EIOS_INVALID_DATA_BYTE8_WEIGHT  | YES                  | 0                    | Changes byte eight of the EIOS to randomly generated data. Valid only at speeds of 8G and above.        |
| EI_TX_EIOS_INVALID_DATA_BYTE9_WEIGHT  | YES                  | 0                    | Changes byte nine of the EIOS to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_EIOS_INVALID_DATA_BYTE10_WEIGHT | YES                  | 0                    | Changes byte ten of the EIOS to randomly generated data. Valid only at speeds of 8G and above.          |
| EI_TX_EIOS_INVALID_DATA_BYTE11_WEIGHT | YES                  | 0                    | Changes byte eleven of the EIOS to randomly generated data. Valid only at speeds of 8G and above.       |
| EI_TX_EIOS_INVALID_DATA_BYTE12_WEIGHT | YES                  | 0                    | Changes byte twelve of the EIOS to randomly generated data. Valid only at speeds of 8G and above.       |

**Table 6-18 EIOS injected errors (Continued)**

|                                           |     |   |                                                                                                         |
|-------------------------------------------|-----|---|---------------------------------------------------------------------------------------------------------|
| EI_TX_EIOS_INVALID_DATA_BYTE13_WEIGHT     | YES | 0 | Changes byte thirteen of the EIOS to randomly generated data. Valid only at speeds of 8G and above.     |
| EI_TX_EIOS_INVALID_DATA_BYTE14_WEIGHT     | YES | 0 | Changes byte fourteen of the EIOS set to randomly generated data. Valid only at speeds of 8G and above. |
| EI_TX_EIOS_INVALID_DATA_BYTE15_WEIGHT     | YES | 0 | Changes byte 15 of the EIOS to randomly generated data. Valid only at speeds of 8G and above.           |
| EI_TX_EIOS_CORRUPT_DISPARITY_BYTE0_WEIGHT | YES | 0 | Inserts a disparity error on byte 0 of the ordered set                                                  |
| EI_TX_EIOS_CORRUPT_DISPARITY_BYTE1_WEIGHT | YES | 0 | Inserts a disparity error on byte 1 of the ordered set. Valid at 2.5G and 5G speeds only.               |
| EI_TX_EIOS_CORRUPT_DISPARITY_BYTE2_WEIGHT | YES | 0 | Inserts a disparity error on byte 2 of the ordered set. Valid at 2.5G and 5G speeds only.               |
| EI_TX_EIOS_CORRUPT_DISPARITY_BYTE3_WEIGHT | YES | 0 | Inserts a disparity error on byte 3 of the ordered set. Valid at 2.5G and 5G speeds only.               |
| EI_TX_EIOS_INVALID_CODEWORD_BYTE0_WEIGHT  | YES | 0 | Inserts an invalid codeword on byte 0 of the ordered set. Valid at 2.5G and 5G speeds only.             |
| EI_TX_EIOS_INVALID_CODEWORD_BYTE1_WEIGHT  | YES | 0 | Inserts an invalid codeword on byte 1 of the ordered set. Valid at 2.5G and 5G speeds only.             |
| EI_TX_EIOS_INVALID_CODEWORD_BYTE2_WEIGHT  | YES | 0 | Inserts an invalid codeword on byte 2 of the ordered set. Valid at 2.5G and 5G speeds only.             |
| EI_TX_EIOS_INVALID_CODEWORD_BYTE3_WEIGHT  | YES | 0 | Inserts an invalid codeword on byte 3 of the ordered set. Valid at 2.5G and 5G speeds only.             |

### 6.13.2 EEIOS Injected Errors

Controls that can be used to inject errors into EEIOS blocks are listed in [Table 6-19](#).

**Table 6-19 EEIOS injected errors**

| Parameter Name        | Settable VAR* | Default Value  | Description                                                           |
|-----------------------|---------------|----------------|-----------------------------------------------------------------------|
| EI_TX_EEOS_PERCENTAGE | YES           | 0              | Percentage probability of an EIOS type EI occurring                   |
| EI_TX_EEOS_LANE_MASK  | YES           | 32'hFFF F_FFFF | A bitwise enable mask for only applying TX_EEOS Els to certain lanes. |

**Table 6-19 EIEOS injected errors (Continued)**

|                                            |     |   |                                                                     |
|--------------------------------------------|-----|---|---------------------------------------------------------------------|
| El_TX_EIEOS_INVALID_DATA_BYTE0_WEIGHT      | YES | 0 | Changes byte 0 of the EIEOS ordered set to randomly generated data. |
| El_TX_EIEOS_INVALID_DATA_BYTE1_WEIGHT      | YES | 0 | Changes byte one of the EIEOS to randomly generated data.           |
| El_TX_EIEOS_INVALID_DATA_BYTE2_WEIGHT      | YES | 0 | Changes byte two of the EIEOS to randomly generated data.           |
| El_TX_EIEOS_INVALID_DATA_BYTE3_WEIGHT      | YES | 0 | Changes byte three of the EIEOS to randomly generated data.         |
| El_TX_EIEOS_INVALID_DATA_BYTE4_WEIGHT      | YES | 0 | Changes byte four of the EIEOS to randomly generated data.          |
| El_TX_EIEOS_INVALID_DATA_BYTE5_WEIGHT      | YES | 0 | Changes byte five of the EIEOS to randomly generated data.          |
| El_TX_EIEOS_INVALID_DATA_BYTE6_WEIGHT      | YES | 0 | Changes byte six of the EIEOS to randomly generated data.           |
| El_TX_EIEOS_INVALID_DATA_BYTE7_WEIGHT      | YES | 0 | Changes byte seven of the EIEOS to randomly generated data.         |
| El_TX_EIEOS_INVALID_DATA_BYTE8_WEIGHT      | YES | 0 | Changes byte eight of the EIEOS to randomly generated data.         |
| El_TX_EIEOS_INVALID_DATA_BYTE9_WEIGHT      | YES | 0 | Changes byte nine of the EIEOS to randomly generated data.          |
| El_TX_EIEOS_INVALID_DATA_BYTE10_WEIGHT     | YES | 0 | Changes byte ten of the EIEOS to randomly generated data.           |
| El_TX_EIEOS_INVALID_DATA_BYTE11_WEIGHT     | YES | 0 | Changes byte eleven of the EIEOS to randomly generated data.        |
| El_TX_EIEOS_INVALID_DATA_BYTE12_WEIGHT     | YES | 0 | Changes byte twelve of the EIEOS to randomly generated data.        |
| El_TX_EIEOS_INVALID_DATA_BYTE13_WEIGHT     | YES | 0 | Changes byte thirteen of the EIEOS to randomly generated data.      |
| El_TX_EIEOS_INVALID_DATA_BYTE14_WEIGHT     | YES | 0 | Changes byte fourteen of the EIEOS to randomly generated data.      |
| El_TX_EIEOS_INVALID_DATA_BYTE15_WEIGHT     | YES | 0 | Changes byte 15 symbol to some other randomly generated data value  |
| El_TX_EIEOS_CORRUPT_DISPARITY_BYTE0_WEIGHT | YES | 0 | Inserts a disparity error on byte 0 of the ordered set              |
| El_TX_EIEOS_CORRUPT_DISPARITY_BYTE1_WEIGHT | YES | 0 | Inserts a disparity error on byte 1 of the ordered set              |
| El_TX_EIEOS_CORRUPT_DISPARITY_BYTE2_WEIGHT | YES | 0 | Inserts a disparity error on byte 2 of the ordered set              |
| El_TX_EIEOS_CORRUPT_DISPARITY_BYTE3_WEIGHT | YES | 0 | Inserts a disparity error on byte 3 of the ordered set              |
| El_TX_EIEOS_CORRUPT_DISPARITY_BYTE4_WEIGHT | YES | 0 | Inserts a disparity error on byte 4 of the ordered set              |

**Table 6-19 EEOS injected errors (Continued)**

|                                            |     |   |                                                          |
|--------------------------------------------|-----|---|----------------------------------------------------------|
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE5_WEIGHT  | YES | 0 | Inserts a disparity error on byte 5 of the ordered set   |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE6_WEIGHT  | YES | 0 | Inserts a disparity error on byte 6 of the ordered set   |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE7_WEIGHT  | YES | 0 | Inserts a disparity error on byte 7 of the ordered set   |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE8_WEIGHT  | YES | 0 | Inserts a disparity error on byte 8 of the ordered set   |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE9_WEIGHT  | YES | 0 | Inserts a disparity error on byte 9 of the ordered set   |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE10_WEIGHT | YES | 0 | Inserts a disparity error on byte 10 of the ordered set  |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE11_WEIGHT | YES | 0 | Inserts a disparity error on byte 11 of the ordered set  |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE12_WEIGHT | YES | 0 | Inserts a disparity error on byte 12 of the ordered set  |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE13_WEIGHT | YES | 0 | Inserts a disparity error on byte 13 of the ordered set  |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE14_WEIGHT | YES | 0 | Inserts a disparity error on byte 14 of the ordered set  |
| EI_TX_EEOS_CORRUPT_DISPARITY_BYTE15_WEIGHT | YES | 0 | Inserts a disparity error on byte 15 of the ordered set  |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE0_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 0 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE1_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 1 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE2_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 2 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE3_WEIGHT   | YES | 0 | Inserts a disparity error on byte 3 of the ordered set   |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE4_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 4 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE5_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 5 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE6_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 6 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE7_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 7 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE8_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 8 of the ordered set |
| EI_TX_EEOS_INVALID_CODEWORD_BYTE9_WEIGHT   | YES | 0 | Inserts an invalid codeword on byte 9 of the ordered set |

**Table 6-19 EIEOS injected errors (Continued)**

|                                            |     |   |                                                           |
|--------------------------------------------|-----|---|-----------------------------------------------------------|
| EI_TX_EIEOS_INVALID_CODEWORD_BYTE10_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 10 of the ordered set |
| EI_TX_EIEOS_INVALID_CODEWORD_BYTE11_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 11 of the ordered set |
| EI_TX_EIEOS_INVALID_CODEWORD_BYTE12_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 12 of the ordered set |
| EI_TX_EIEOS_INVALID_CODEWORD_BYTE13_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 13 of the ordered set |
| EI_TX_EIEOS_INVALID_CODEWORD_BYTE14_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 14 of the ordered set |
| EI_TX_EIEOS_INVALID_CODEWORD_BYTE15_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 15 of the ordered set |

### 6.13.3 FTS Injected Errors

FTS are sent exclusively in the state Tx.L0s.Exit. FTS injected errors are listed in [Table 6-20](#).

**Table 6-20 FTS injected errors**

| Parameter Name                      | Settable VAR* | Default Value     | Description                                                                                    |
|-------------------------------------|---------------|-------------------|------------------------------------------------------------------------------------------------|
| EI_TX_FTS_PERCENTAGE                | YES           |                   | Percentage probability of an FTS type EI occurring                                             |
| EI_TX_FTS_LANE_MASK                 | YES           | 32'hFFF<br>F_FFFF | A bitwise enable mask for only applying TX_FTS EIs to certain lanes.                           |
| EI_TX_FTS_INVALID_DATA_BYTE0_WEIGHT | YES           | 0                 | Changes the first byte of an FTS to randomly generated data.                                   |
| EI_TX_FTS_INVALID_DATA_BYTE1_WEIGHT | YES           | 0                 | Changes byte one of the FTS to randomly generated data.                                        |
| EI_TX_FTS_INVALID_DATA_BYTE2_WEIGHT | YES           | 0                 | Changes byte two of the FTS to randomly generated data.                                        |
| EI_TX_FTS_INVALID_DATA_BYTE3_WEIGHT | YES           | 0                 | Changes byte three of the FTS to randomly generated data.                                      |
| EI_TX_FTS_INVALID_DATA_BYTE4_WEIGHT | YES           | 0                 | Changes byte four of the FTS to randomly generated data. Valid only at speeds of 8G and above. |
| EI_TX_FTS_INVALID_DATA_BYTE5_WEIGHT | YES           | 0                 | Changes byte five of the FTS to randomly generated data. Valid only at speeds of 8G and above. |
| EI_TX_FTS_INVALID_DATA_BYTE6_WEIGHT | YES           | 0                 | Changes byte six of the FTS to randomly generated data. Valid only at speeds of 8G and above.  |

**Table 6-20 FTS injected errors (Continued)**

|                                          |     |   |                                                                                                        |
|------------------------------------------|-----|---|--------------------------------------------------------------------------------------------------------|
| EL_TX_FTS_INVALID_DATA_BYTE7_WEIGHT      | YES | 0 | Changes byte seven of the FTS symbol to randomly generated data. Valid only at speeds of 8G and above. |
| EL_TX_FTS_INVALID_DATA_BYTE8_WEIGHT      | YES | 0 | Changes byte eight of the FTS to randomly generated data. Valid only at speeds of 8G and above.        |
| EL_TX_FTS_INVALID_DATA_BYTE9_WEIGHT      | YES | 0 | Changes byte nine of the FTS to randomly generated data. Valid only at speeds of 8G and above.         |
| EL_TX_FTS_INVALID_DATA_BYTE10_WEIGHT     | YES | 0 | Changes byte ten of the FTS to randomly generated data. Valid only at speeds of 8G and above.          |
| EL_TX_FTS_INVALID_DATA_BYTE11_WEIGHT     | YES | 0 | Changes byte eleven of the FTS to randomly generated data. Valid only at speeds of 8G and above.       |
| EL_TX_FTS_INVALID_DATA_BYTE12_WEIGHT     | YES | 0 | Changes byte twelve of the FTS to randomly generated data. Valid only at speeds of 8G and above.       |
| EL_TX_FTS_INVALID_DATA_BYTE13_WEIGHT     | YES | 0 | Changes byte thirteen of the FTS to randomly generated data. Valid only at speeds of 8G and above.     |
| EL_TX_FTS_INVALID_DATA_BYTE14_WEIGHT     | YES | 0 | Changes byte fourteen of the FTS set to randomly generated data. Valid only at speeds of 8G and above. |
| EL_TX_FTS_INVALID_DATA_BYTE15_WEIGHT     | YES | 0 | Changes byte 15 of the FTS to randomly generated data. Valid only at speeds of 8G and above.           |
| EL_TX_FTS_CORRUPT_DISPARITY_BYTE0_WEIGHT | YES | 0 | Inserts a disparity error on byte 0 of the ordered set                                                 |
| EL_TX_FTS_CORRUPT_DISPARITY_BYTE1_WEIGHT | YES | 0 | Inserts a disparity error on byte 1 of the ordered set. Valid at 2.5G and 5G speeds only.              |
| EL_TX_FTS_CORRUPT_DISPARITY_BYTE2_WEIGHT | YES | 0 | Inserts a disparity error on byte 2 of the ordered set. Valid at 2.5G and 5G speeds only.              |
| EL_TX_FTS_CORRUPT_DISPARITY_BYTE3_WEIGHT | YES | 0 | Inserts a disparity error on byte 3 of the ordered set. Valid at 2.5G and 5G speeds only.              |
| EL_TX_FTS_INVALID_CODEWORD_BYTE0_WEIGHT  | YES | 0 | Inserts an invalid codeword on byte 0 of the ordered set. Valid at 2.5G and 5G speeds only.            |

**Table 6-20 FTS injected errors (Continued)**

|                                         |     |   |                                                                                             |
|-----------------------------------------|-----|---|---------------------------------------------------------------------------------------------|
| EL_TX_FTS_INVALID_CODEWORD_BYTE1_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 1 of the ordered set. Valid at 2.5G and 5G speeds only. |
| EL_TX_FTS_INVALID_CODEWORD_BYTE2_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 2 of the ordered set. Valid at 2.5G and 5G speeds only. |
| EL_TX_FTS_INVALID_CODEWORD_BYTE3_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 3 of the ordered set. Valid at 2.5G and 5G speeds only. |

#### 6.13.4 SKP Injected Errors

The error injections and controls listed in [Table 6-21](#) assume that the user is transmitting SKPs with the lengths specified in the PCIE standard (4 bytes for 8/b10b encoding and 16bytes for 128/130b encoding). There are controls to make SKPs longer or shorter than the normal length, but it is assumed for the purposes of injecting errors that standard lengths are used.

**Table 6-21 SKP injected errors**

| Parameter Name                      | Settable VAR* | Default Value  | Description                                                                                            |
|-------------------------------------|---------------|----------------|--------------------------------------------------------------------------------------------------------|
| EL_TX_SKP_PERCENTAGE                | YES           | 0              | Percentage probability of an SKP type EI occurring                                                     |
| EL_TX_SKP_LANE_MASK                 | YES           | 32'hFFF F_FFFF | A bitwise enable mask for only applying TX_SKP EIs to certain lanes.                                   |
| EL_TX_SKP_INVALID_DATA_BYTE0_WEIGHT | YES           | 0              | Changes the first byte of an SKP to randomly generated data.                                           |
| EL_TX_SKP_INVALID_DATA_BYTE1_WEIGHT | YES           | 0              | Changes byte one of the SKP to randomly generated data.                                                |
| EL_TX_SKP_INVALID_DATA_BYTE2_WEIGHT | YES           | 0              | Changes byte two of the SKP to randomly generated data.                                                |
| EL_TX_SKP_INVALID_DATA_BYTE3_WEIGHT | YES           | 0              | Changes byte three of the SKP to randomly generated data.                                              |
| EL_TX_SKP_INVALID_DATA_BYTE4_WEIGHT | YES           | 0              | Changes byte four of the SKP to randomly generated data. Valid only at speeds of 8G and above.         |
| EL_TX_SKP_INVALID_DATA_BYTE5_WEIGHT | YES           | 0              | Changes byte five of the SKP to randomly generated data. Valid only at speeds of 8G and above.         |
| EL_TX_SKP_INVALID_DATA_BYTE6_WEIGHT | YES           | 0              | Changes byte six of the SKP to randomly generated data. Valid only at speeds of 8G and above.          |
| EL_TX_SKP_INVALID_DATA_BYTE7_WEIGHT | YES           | 0              | Changes byte seven of the SKP symbol to randomly generated data. Valid only at speeds of 8G and above. |

**Table 6-21 SKP injected errors (Continued)**

|                                          |     |   |                                                                                                        |
|------------------------------------------|-----|---|--------------------------------------------------------------------------------------------------------|
| EI_TX_SKP_INVALID_DATA_BYTE8_WEIGHT      | YES | 0 | Changes byte eight of the SKP to randomly generated data. Valid only at speeds of 8G and above.        |
| EI_TX_SKP_INVALID_DATA_BYTE9_WEIGHT      | YES | 0 | Changes byte nine of the SKP to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_SKP_INVALID_DATA_BYTE10_WEIGHT     | YES | 0 | Changes byte ten of the SKP to randomly generated data. Valid only at speeds of 8G and above.          |
| EI_TX_SKP_INVALID_DATA_BYTE11_WEIGHT     | YES | 0 | Changes byte eleven of the EIOS to randomly generated data. Valid only at speeds of 8G and above.      |
| EI_TX_SKP_INVALID_DATA_BYTE12_WEIGHT     | YES | 0 | Changes byte twelve of the SKP to randomly generated data. Valid only at speeds of 8G and above.       |
| EI_TX_SKP_INVALID_DATA_BYTE13_WEIGHT     | YES | 0 | Changes byte thirteen of the SKP to randomly generated data. Valid only at speeds of 8G and above.     |
| EI_TX_SKP_INVALID_DATA_BYTE14_WEIGHT     | YES | 0 | Changes byte fourteen of the SKP set to randomly generated data. Valid only at speeds of 8G and above. |
| EI_TX_SKP_INVALID_DATA_BYTE15_WEIGHT     | YES | 0 | Changes byte 15 of the SKP to randomly generated data. Valid only at speeds of 8G and above.           |
| EI_TX_SKP_CORRUPT_DISPARITY_BYTE0_WEIGHT | YES | 0 | Inserts a disparity error on byte 0 of the ordered set                                                 |
| EI_TX_SKP_CORRUPT_DISPARITY_BYTE1_WEIGHT | YES | 0 | Inserts a disparity error on byte 1 of the ordered set. Valid at 2.5G and 5G speeds only.              |
| EI_TX_SKP_CORRUPT_DISPARITY_BYTE2_WEIGHT | YES | 0 | Inserts a disparity error on byte 2 of the ordered set. Valid at 2.5G and 5G speeds only.              |
| EI_TX_SKP_CORRUPT_DISPARITY_BYTE3_WEIGHT | YES | 0 | Inserts a disparity error on byte 3 of the ordered set. Valid at 2.5G and 5G speeds only.              |
| EI_TX_SKP_INVALID_CODEWORD_BYTE0_WEIGHT  | YES | 0 | Inserts an invalid codeword on byte 0 of the ordered set. Valid at 2.5G and 5G speeds only.            |

**Table 6-21 SKP injected errors (Continued)**

|                                         |     |   |                                                                                             |
|-----------------------------------------|-----|---|---------------------------------------------------------------------------------------------|
| EI_TX_SKP_INVALID_CODEWORD_BYTE1_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 1 of the ordered set. Valid at 2.5G and 5G speeds only. |
| EI_TX_SKP_INVALID_CODEWORD_BYTE2_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 2 of the ordered set. Valid at 2.5G and 5G speeds only. |
| EI_TX_SKP_INVALID_CODEWORD_BYTE3_WEIGHT | YES | 0 | Inserts an invalid codeword on byte 3 of the ordered set. Valid at 2.5G and 5G speeds only. |

### 6.13.5 SDS Injected Errors

The errors listed in [Table 6-22](#) are defined for the start of data stream ordered set.

**Table 6-22 SDS injected errors**

| Parameter Name                      | Settable VAR* | Default Value | Description                                                                                            |
|-------------------------------------|---------------|---------------|--------------------------------------------------------------------------------------------------------|
| EI_TX_SDS_PERCENTAGE                | YES           | 0             | Percentage probability of an SDS type EI occurring                                                     |
| EI_TX_SDS_LANE_MASK                 | YES           | 32'hFFFF_FFFF | A bitwise enable mask for only applying TX_SDS EIs to certain lanes.                                   |
| EI_TX_SDS_INVALID_DATA_BYTE0_WEIGHT | YES           | 0             | Changes the first byte of an SDS to randomly generated data.                                           |
| EI_TX_SDS_INVALID_DATA_BYTE1_WEIGHT | YES           | 0             | Changes byte one of the SDS to randomly generated data.                                                |
| EI_TX_SDS_INVALID_DATA_BYTE2_WEIGHT | YES           | 0             | Changes byte two of the SDS to randomly generated data.                                                |
| EI_TX_SDS_INVALID_DATA_BYTE3_WEIGHT | YES           | 0             | Changes byte three of the SDS to randomly generated data.                                              |
| EI_TX_SDS_INVALID_DATA_BYTE4_WEIGHT | YES           | 0             | Changes byte four of the SDS to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_SDS_INVALID_DATA_BYTE5_WEIGHT | YES           | 0             | Changes byte five of the SDS to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_SDS_INVALID_DATA_BYTE6_WEIGHT | YES           | 0             | Changes byte six of the SDS to randomly generated data. Valid only at speeds of 8G and above.          |
| EI_TX_SDS_INVALID_DATA_BYTE7_WEIGHT | YES           | 0             | Changes byte seven of the SDS symbol to randomly generated data. Valid only at speeds of 8G and above. |

**Table 6-22 SDS injected errors (Continued)**

|                                      |     |   |                                                                                                        |
|--------------------------------------|-----|---|--------------------------------------------------------------------------------------------------------|
| EI_TX_SDS_INVALID_DATA_BYTE8_WEIGHT  | YES | 0 | Changes byte eight of the SDS to randomly generated data. Valid only at speeds of 8G and above.        |
| EI_TX_SDS_INVALID_DATA_BYTE9_WEIGHT  | YES | 0 | Changes byte nine of the SDS to randomly generated data. Valid only at speeds of 8G and above.         |
| EI_TX_SDS_INVALID_DATA_BYTE10_WEIGHT | YES | 0 | Changes byte ten of the SDS to randomly generated data. Valid only at speeds of 8G and above.          |
| EI_TX_SDS_INVALID_DATA_BYTE11_WEIGHT | YES | 0 | Changes byte eleven of the SDS to randomly generated data. Valid only at speeds of 8G and above.       |
| EI_TX_SDS_INVALID_DATA_BYTE12_WEIGHT | YES | 0 | Changes byte twelve of the SDS to randomly generated data. Valid only at speeds of 8G and above.       |
| EI_TX_SDS_INVALID_DATA_BYTE13_WEIGHT | YES | 0 | Changes byte thirteen of the SDS to randomly generated data. Valid only at speeds of 8G and above.     |
| EI_TX_SDS_INVALID_DATA_BYTE14_WEIGHT | YES | 0 | Changes byte fourteen of the SDS set to randomly generated data. Valid only at speeds of 8G and above. |
| EI_TX_SDS_INVALID_DATA_BYTE15_WEIGHT | YES | 0 | Changes byte 15 of the SDS to randomly generated data. Valid only at speeds of 8G and above.           |

### 6.13.6 EDS Injected Errors

The EDS token replaces the last 4 bytes of the data stream preceding an ordered set with the bytes {‘h1f, 8’h80, 8’h90, 8’h00}. This is set on the last 4 bytes of the block, and thus the location of these symbols will vary based on link width. EDS injected errors are listed in [Table 6-23](#).

**Table 6-23 EDS injected errors**

| Parameter Name                      | Settable VAR* | Default Value | Description                                                  |
|-------------------------------------|---------------|---------------|--------------------------------------------------------------|
| EI_TX_EDS_PERCENTAGE                | YES           | 0             | Percentage probability of an FTS type EI occurring           |
| EI_TX_EDS_INVALID_DATA_BYTE0_WEIGHT | YES           | 0             | Changes the first byte of an EDS to randomly generated data. |
| EI_TX_EDS_INVALID_DATA_BYTE1_WEIGHT | YES           | 0             | Changes byte one of the EDS to randomly generated data.      |
| EI_TX_EDS_INVALID_DATA_BYTE2_WEIGHT | YES           | 0             | Changes byte two of the EDS to randomly generated data.      |
| EI_TX_EDS_INVALID_DATA_BYTE3_WEIGHT | YES           | 0             | Changes byte three of the EDS to randomly generated data.    |

### 6.13.7 IDLE Data Injected Errors

IDLE data error injections are not injected randomly, so there is an enable control rather than a percentage. This EI is meant to be used in directed test cases where the user specifically needs to prevent logical idle or IDL tokens from being received. These EIs work on logical idle symbols at 2.5/5G and on IDL tokens at 8G. IDLE data injected errors are listed in [Table 6-24](#).

**Table 6-24 IDLE data injected errors**

| Parameter Name                           | Settable VAR* | Default Value | Description                                                                                                          |
|------------------------------------------|---------------|---------------|----------------------------------------------------------------------------------------------------------------------|
| EI_TX_IDLE_DATA_ENABLE                   | YES           | 0             | Enables the injection of errors onto IDLE data or IDL tokens.                                                        |
| EI_TX_IDLE_DATA_LANE_MASK                | YES           | 32'hFFFF_FFFF | Lane mask vector for IDLE_DATA EI's. A bit set to 0 will prevent any errors being injected on the corresponding lane |
| EI_TX_IDLE_DATA_INVALID_BYTE_WEIGHT      | YES           | 0             | Changes the byte of an IDLE DATA to randomly generated non-zero data. Valid at all speeds.                           |
| EI_TX_IDLE_DATA_CORRUPT_DISPARITY_WEIGHT | YES           | 0             | Inserts a disparity error on byte of IDLE DATA. Valid at 2.5G and 5G speeds only.                                    |
| EI_TX_IDLE_DATA_INVALID_CODEWORD_WEIGHT  | YES           | 0             | Inserts an invalid codeword on byte IDLE DATA. Valid at 2.5G and 5G speeds only.                                     |

### 6.13.8 Directed Sequences of IDLE Injected Errors

For advanced LTSSM testing, the SetEiTxDlidleDataPattern directed task can be used to send specified sequences of good and bad idle symbols. In order to use this task, EI\_TX\_IDLE\_DATA\_ENABLE\_VAR must be set to 0. All other weights and the lane mask need to be set in order to choose what type of error will be selected on bad IDLE symbols. Arguments to the SetEiTxDlidleDataPattern task are listed in [Table 6-25](#).

**Table 6-25 SetEiTxDlidleDataPattern task**

| Task Name                | Arguments                                                                                                                                                                                       | I/O | Values                                                                                                                                                                                                                                                                                                                    |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetEiTxDlidleDataPattern | enable_i(32)<br><br>Defines a constrained random burst of IDLE symbols with errors.<br><br>min_ei_tx_ts1_burst_i<br>max_ei_tx_ts1_burst_i<br>min_ei_tx_ts1_spacing_i<br>max_ei_tx_ts1_spacing_i | I   | '1' enables the training set pattern, '0' disables it<br><br>Minimum number of bad IDLE symbols in the error burst.<br><br>Maximum number of bad idle symbols in the error burst.<br><br>Minimum number of good idle symbols between the error burst.<br><br>Minimum number of good idle symbols between the error burst. |

## 6.14 Physical Layer Internal Interface Tasks

Physical Layer internal interface tasks are listed in <Xref>Table 6-26.

**Table 6-26 Physical Layer internal interface tasks**

| Task Name   | Arguments (length)       | I/O | Values                                                                                                                                                                 |
|-------------|--------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TransmitPhy | data_in (256)            | I   | One byte of outgoing data per lane.                                                                                                                                    |
|             | control_bus (256)        | I   | Indication of whether the outgoing byte is valid or not, or whether it is a start of TLP, end of TLP, etc. Each byte of the control bus corresponds to a byte of data. |
|             | ei_code (256)            | I   | Error injection code. There is a 1 byte error injection code per byte of data.                                                                                         |
|             | hold (1)                 | O   | Indication to the link that the phy cannot accept data.                                                                                                                |
|             | force_align_packet (1)   | O   | Indication to the link that it should align the next start of packet to byte 0 of the next symbol time.                                                                |
| ReceivePhy  | data_out (256)           | O   | One byte of outgoing data per lane.                                                                                                                                    |
|             | control_bus (256)        | O   | Indication of whether the outgoing byte is valid or not, or whether it is a start of TLP, end of TLP, etc. Each byte of the control bus corresponds to a byte of data. |
|             | ei_code (256)            | O   | Error injection code. There is a 1 byte error injection code per byte of data.                                                                                         |
| TransmitPCS | pcs_lanenum_i (32)       | I   | Lane which the transmit data goes on                                                                                                                                   |
|             | txd_o (32)               | O   | Transmit data. If all 4 bytes are utilized, txd[7:0] contains the byte which is to be transmitted first, txd[15:8] is to be transmitted second, and so on.             |
|             | txc_o (4)                | O   | Control bit. txc[0] corresponds to txd[7:0] and so on.                                                                                                                 |
|             | ei_code_o (32)           | O   | Error injection code                                                                                                                                                   |
|             | tx_elec_idle_o (1)       | O   | Transmit electrical idle PIPE signal.                                                                                                                                  |
|             | tx_compliance_o (1)      | O   | Instructs the PCS to send the compliance pattern to the serdes.                                                                                                        |
|             | tx_data_valid_o (1)      | O   | Indication that data transmitted by the VIP is valid. Used primarily for rate matching. NOTE: pipe 3 only.                                                             |
|             | tx_start_block_o (1)     | O   | Bitwise indication that a new ordered set/data block will start on this byte. NOTE: pipe 3 only.                                                                       |
|             | tx_sync_header_o (2)     | O   | The sync header to be inserted when a new block is started. Only used at 8GT/s.                                                                                        |
|             | invert_tx_polarity_o (1) | O   | Indication to the PCS to invert polarity on the transmit side for testing purposes.                                                                                    |
|             | rx_status_o (3)          | O   | When VIP is in the pipe slave configuration, this is the status that accompanies the outgoing data. Not valid in other configurations.                                 |

**Table 6-26 Physical Layer internal interface tasks (Continued)**

| Task Name         | Arguments (length)   | I/O | Values                                                                                                                                                                                                                                                                                                  |
|-------------------|----------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ReceivePCS        | pcs_lanenum (32)     | I   | PCS number which the data came from.                                                                                                                                                                                                                                                                    |
|                   | rx_d_i (32)          | I   | Sent data. If all four bytes are used, rx_d[7:0] was sent first and rx_d[31:24] was sent most recently.                                                                                                                                                                                                 |
|                   | rx_c_i (32)          | I   | Control bit for the receive data. Bit 0 corresponds to the low byte of data and bit 3 corresponds to the high byte.                                                                                                                                                                                     |
|                   | ei_code_i (32)       | I   | Receive error injection code                                                                                                                                                                                                                                                                            |
|                   | rx_status_i (3)      | I   | Receiver status encoding:<br>3'b000 – Receive OK<br>3'b001 – 1 SKP added<br>3'b010 – 1 SKP removed<br>3'b011 – Receiver detected<br>3'b100 – 128/130B decode error and/or disparity error.<br>3'b101 – Elastic buffer overflow<br>3'b110 – Elastic buffer underflow<br>3'b111 – Receive disparity error |
|                   | rx_valid_i (1)       | I   | Indication that the receiver has detected valid data and achieved symbol lock.                                                                                                                                                                                                                          |
|                   | rx_data_valid_i (1)  | I   | Indication that data coming into the VIP is valid. Used primarily for rate matching. NOTE: pipe 3 only.                                                                                                                                                                                                 |
|                   | rx_elec_idle_i (1)   | I   | Indication that electrical idle is being received into the VIP<br>Note: Any used ports must be tied to a 1.                                                                                                                                                                                             |
|                   | rx_start_block_i (1) | I   | Indication that data coming into the VIP is the first byte of data in the block.<br>NOTE: pipe 3 only.                                                                                                                                                                                                  |
|                   | rx_elec_idle_i (1)   | I   | Indication that the receiver has detected electrical idle.                                                                                                                                                                                                                                              |
| rx_polarity_i (1) | I                    | I   | Pipe slave signal. Determined if DUT has detected polarity inversion. Not valid in pipe master config.                                                                                                                                                                                                  |
|                   | rx_polarity_o (1)    | O   | Receive polarity inversion. Directs receive PCS decoder to invert polarity on incoming symbols. Used only as a pipe master, not valid when VIP is configured as a pipe slave.<br>1'b0 – No polarity inversion should be performed<br>1'b1 - Polarity inversion should occur                             |

## 6.15 Using Local Preset Coefficients

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.** When set to a value of “1”, model enables the PIPE GetLocalPresetCoefficients interface of the PHY. [Table 6-27](#) lists the signals and their function which are enabled. If your interfaced is a SERDES, this parameter has effect. Following are the actions for interface types:

- ◆ **For an "MPIPE" model.** If the "ENABLE\_GET\_LOCAL\_PRESET\_COEFFICIENTS\_VAR" is a "1", it enables the per-Lane "GetLocalPresetStateMachine" to drive the per-Lane "get\_local\_preset\_coefficients/local\_preset\_index[3: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\_VAR" is a "0", there will be no activity presented on the above outputs nor any response to the above inputs.
  - ◆ **For an "SPIPE" model.** If the "ENABLE\_GET\_LOCAL\_PRESET\_COEFFICIENTS\_VAR" is a "1", it enables the per-Lane "RespLocalTxPresetCoeffStateMachine" to interpret a "get\_local\_preset\_coefficients/local\_preset\_index[3: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\_VAR" is a "0", there will be no response to any per-Lane "get\_local\_preset\_coefficients/local\_preset\_index[3: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 6-27 PIPE GetLocalPresetCoefficients Signals**

| Name                     | Direction | Active Level | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GetLocalPresetCoeffcents | 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><br>Maximum Response time of PHY is 128 nSec.<br><br>Note. A MAC can make this request any time after reset.<br><br>Note. After a local preset coefficient request a MAC could assert GetLocalPresetCoeffcents again as soon as the next PCLK after LocalTxCoefficientsValid deasserts. |

**Table 6-27 PIPE GetLocalPresetCoefficients Signals (Continued)**

| Name                            | Direction | Active Level | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LocalPresetIndex[3:0]           | Input     | NA           | <p>Index for local PHY preset coefficients requested by the MAC</p> <p>The preset index value is encoded as follows:</p> <ul style="list-style-type: none"> <li>0000b – Preset P0.</li> <li>0001b – Preset P1.</li> <li>0010b – Preset P2.</li> <li>0011b – Preset P3.</li> <li>0100b – Preset P4.</li> <li>0101b – Preset P5.</li> <li>0110b – Preset P6.</li> <li>0111b – Preset P7.</li> <li>1000b – Preset P8.</li> <li>1001b – Preset P9.</li> <li>1010b – Preset P10.</li> <li>1011b – Reserved</li> <li>1100b – Reserved</li> <li>1101b – Reserved</li> <li>1110b – Reserved</li> <li>1111b – Reserved.</li> </ul> |
| 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.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 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>                                                                                                                                                                                                                              |

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 8 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 12 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.



# 7 Physical Coding Sublayer (2.5Gb / 5Gb / 8Gb)

---

The Physical Coding Sublayer (PCS) checks for commas and performs symbol lock at 2.5GT/s, 5GT/s, and 8GT/s (Optional). It also does 8b/10b encoding at 2.5GT/s and 5GT/s and inserts data sync headers at 8GT/s. The PCS also contains the elastic buffer which inserts/deletes SKP symbols from skip ordered sets. The PCS task pair interface and module inputs/outputs comply with Intel's PIPE interface specification. The PCS module-level inputs/outputs are listed in [Table 7-1](#).

**Table 7-1 PCS module-level I/Os**

| Name                | I/O  | Description                                                                                    |
|---------------------|------|------------------------------------------------------------------------------------------------|
| reset               | I(1) | Active high reset. Must only be asserted for 100ns ONCE per simulation at the beginning.       |
| data_bus_width      | I(2) | Indicates the width of the pipe data bus.                                                      |
| rate                | I(2) | Pipe rate signal.                                                                              |
| powerdown           | I(2) | Power state of the transmitter/receiver pair.                                                  |
| detect_receiver     | I(1) | Indication from the phy to perform a receiver detect.                                          |
| loopback_enable     | I(1) | Indication from the Physical Layer to loop back incoming data on the transmitter.              |
| block_align_control | I(1) | Controls slave block alignment. NOTE: pipe 3 only.                                             |
| receiver_present    | I(1) | Indication to the PCS that it should indicate a receiver is present.                           |
| serdes_locked       | I(1) | Indication from the attached serdes that the receiver has locked onto the incoming bit stream. |

## 7.1 Physical Coding Sublayer Parameters

PCS parameters are listed in [Table 7-2](#).

**Table 7-2 PCS parameters**

| Parameter Name           | Settable VAR?* | Type    | Range                  | Default     | Description                                                                                        |
|--------------------------|----------------|---------|------------------------|-------------|----------------------------------------------------------------------------------------------------|
| COMMA_SYNC_COUNT         |                |         |                        |             |                                                                                                    |
|                          | Yes            | Integer | 1-16                   | 3           | Number of commas that must be detected in the same bit position to declare successful symbol lock. |
| ENABLE_RX_ELASTIC_BUFFER |                |         |                        |             |                                                                                                    |
|                          | No             | Integer | 0-1                    | 1           | Enables the receive elastic buffer. This is not necessary for most simulations.                    |
| NUM_PMA_INTERFACE_BITS   |                |         |                        |             |                                                                                                    |
|                          | No             | Integer | 10, 16, 32,<br>64, 128 | 10          | Number of bits on the PMA interface.<br>NOTE: please set this in the model.                        |
| DISPLAY_NAME             |                |         |                        |             |                                                                                                    |
|                          | No             | String  |                        | pciesvc_pcs | Default display name for msglog statements.                                                        |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with "\_VAR". This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

## 7.2 Physical Coding Sublayer Interface Tasks

PCS interface tasks are listed in [Table 7-3](#).

**Table 7-3 PCS interface tasks**

| Task Name   | Arguments (length)       | I/O | Values                                                                                                                                               |
|-------------|--------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------|
| TransmitPCS | txd_i (32)               | I   | Transmit data. If the 32-bit interface is used, byte txd[7:0] is the byte to be transmitted first, txd[15:8] is to be transmitted second, and so on. |
|             | txc_i (4)                | I   | Control bit. Each bit corresponds to a byte in txd.                                                                                                  |
|             | ei_code (32)             | I   | Error injection code                                                                                                                                 |
|             | tx_elec_idle_i (1)       | I   | Indication for transmitter to send electrical idle.                                                                                                  |
|             | tx_compliance_i (1)      | I   | Indication to transmit the compliance pattern.                                                                                                       |
|             | tx_data_valid_i (1)      | I   | Indication that data transmitted by the VIP is valid. Used primarily for rate matching. NOTE: pipe 3 only.                                           |
|             | tx_start_block_i(1)      | I   | Bitwise indication that a new ordered set/data block will start on this byte. NOTE: pipe 3 only.                                                     |
|             | tx_sync_header_i (2)     | I   | The sync header to be inserted when a new block is started. NOTE: pipe 3 only.                                                                       |
|             | invert_tx_polarity_i (1) | I   | Indication to the encoder to invert transmit polarity.                                                                                               |

**Table 7-3 PCS interface tasks (Continued)**

| <b>Task Name</b> | <b>Arguments (length)</b>      | <b>I/O</b> | <b>Values</b>                                                                                                                                                                                                                                                                                                        |
|------------------|--------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ReceivePCS       | rx_d_o (32)                    | O          | One byte of outgoing data per lane.                                                                                                                                                                                                                                                                                  |
|                  | rx_c_o (4)                     | O          | Control bit for the receive data. Bit 0 corresponds to the low byte of data and bit 3 corresponds to the high byte.                                                                                                                                                                                                  |
|                  | ei_code_o (32)                 | O          | Error injection code                                                                                                                                                                                                                                                                                                 |
|                  | rx_status_o (3)                | O          | Receive status:<br>3'b000: RX data OK<br>3'b001: 1 SKP added to elastic buffer<br>3'b010: 1 skp removed from elastic buffer<br>3'b011: Receiver detected<br>3'b100: 8b/10b decode error and rx disparity error.<br>3'b101: elastic buffer overflow<br>3'b110: elastic buffer underflow<br>3'b111: rx disparity error |
|                  | rx_valid_o (1)                 | O          | Indication that the receiver has detected valid data and achieved symbol lock.                                                                                                                                                                                                                                       |
|                  | rx_data_valid_o (1)            | O          | Indication that data received by the VIP is valid. Used primarily for rate matching. NOTE: pipe 3 only.                                                                                                                                                                                                              |
|                  | rx_start_block_o (1)           | O          | Bitwise indication that a new ordered set/data block will start on this byte. NOTE: pipe 3 only.                                                                                                                                                                                                                     |
|                  | rx_sync_header_o (2)           | O          | The sync header to be inserted when a new block is started. NOTE: pipe 3 only.                                                                                                                                                                                                                                       |
| TransmitPMA      | data_o(NUM_PMA_INTERFACE_BITS) | O          | Data to transmit to serdes                                                                                                                                                                                                                                                                                           |
|                  | tx_elec_idle_o (1)             | O          | Indication for serdes to transmit electrical idle.                                                                                                                                                                                                                                                                   |
| ReceivePMA       | data_i(NUM_PMA_INTERFACE_BITS) | I          | Incoming 8b/10b encoded (2.5GT/s & 5GT/s) or scrambled data (8GT/s)                                                                                                                                                                                                                                                  |



# 8 Serializer/Deserializer (pciesvc\_serdes.v)

The Serializer/Deserializer (SERDES) is used to convert the serial, differential bit stream into a stream of 10-bit bytes. In addition, it also does signal-level validation, receiver clock-recovery and bit alignment.

The SERDES model supplied is not an analog SERDES model, but a digital representation, and is not meant for verifying an analog SERDES design. It is provided so that Phy Layer functionality such as speed negotiation may be tested.

## 8.1 Module Port List

The SERDES module is instantiated by the models. It may also be used by a DUT to alleviate the simulation performance penalty often observed from timing information laden analog models. The ports are listed in [Table 8-1](#).

**Table 8-1 SERDES module ports**

| Port Name         | I/O | Description                                                                    |
|-------------------|-----|--------------------------------------------------------------------------------|
| reset             | I   | Causes the SERDES to reset, positive active                                    |
| tx_enable (1)     | I   | Indicates input bits are valid – also used to modulate the bit stream for OOB. |
| tx_bit_clk (1)    | I   | clock for transmitting tx_byte10                                               |
| tx_byte10 (10)    | I   | Outbound transmit byte                                                         |
| rx_datap (1)      | I   | Bit stream of RX data                                                          |
| rx_datan (1)      | I   | Bit stream of RX data (differential).                                          |
| pll_locked (1)    | O   | PLL/DLL has locked to incoming bit stream                                      |
| serdes_locked (1) | O   | SERDES has locked to incoming COMMA characters                                 |
| rbc (2)           | O   | Receive bit clock                                                              |
| rx_byte10_clk (1) | O   | Receive byte clock                                                             |
| rx_byte10 (10)    | O   | Sent byte                                                                      |
| comma_det (1)     | O   | Indicates COMMA character detected                                             |

**Table 8-1 SERDES module ports (Continued)**

| Port Name           | I/O | Description                                                         |
|---------------------|-----|---------------------------------------------------------------------|
| tx_datap (1)        | O   | Bit stream of TX data                                               |
| tx_datan (1)        | O   | Bit stream of TX data (differential).                               |
| sig_level_valid (1) | O   | Signal level deemed valid – also used to receive bit stream for OOB |

## 8.2 SERDES Parameters

There are a few parameters that affect the behavior of the SERDES. These parameters are listed in [Table 8-2](#).

**Table 8-2 SERDES parameters**

| Parameter Name        | Settable VAR?* | Type    | Range            | Default         | Description                                                                                                                                                                           |
|-----------------------|----------------|---------|------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COMMA_SYNC_COUNT      |                |         |                  |                 |                                                                                                                                                                                       |
|                       | No             | Integer | 0 - large value  | 0               | Number of aligned commas before SERDES lock declared. Not used in PCIE.                                                                                                               |
| BIT_SYNC_COUNT        |                |         |                  |                 |                                                                                                                                                                                       |
|                       | No             | Integer | 10 - large value | 1000            | Number of min bit periods seen before PLL lock declared. Must be larger than maximum time of OOB active burst.                                                                        |
| CLK_TOLERANCE         |                |         |                  |                 |                                                                                                                                                                                       |
|                       | No             | Integer | Any value        | 0.0001          | Tolerance in ns. Equivalent to 100 PPM SAS requirement. This should not be changed as it affects SSC clock tracking.                                                                  |
| USE_ZERO_FOR_DISABLED |                |         |                  |                 |                                                                                                                                                                                       |
|                       | Yes            | Integer | 0-1              | 0 (FALSE)       | If set, the SERDES when disabled will transmit n = p = 0 (ground).                                                                                                                    |
| USE_Z_FOR_DISABLED    |                |         |                  |                 |                                                                                                                                                                                       |
|                       | Yes            | Integer | 0-1              | 1 (TRUE)        | If set, the SERDES when disabled will transmit n = p = Z (high impedance).<br>Note: If neither USE_ZERO_FOR_DISABLED nor USE_Z_FOR_DISABLED are set, then n = p = random (no spread). |
| COMMA_P               |                |         |                  |                 |                                                                                                                                                                                       |
|                       | No             | Integer | Any 10-bit value | 10'b0011 111010 | Definition of positive COMMA character.                                                                                                                                               |
| COMMA_N               |                |         |                  |                 |                                                                                                                                                                                       |
|                       | No             | Integer | Any 10-bit value | 10'b1100 000101 | Definition of negative COMMA character.                                                                                                                                               |
| DISPLAY_NAME          |                |         |                  |                 |                                                                                                                                                                                       |

**Table 8-2 SERDES parameters (Continued)**

| Parameter Name                                | Settable VAR?* | Type    | Range | Default         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------|----------------|---------|-------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                               | No             | String  |       | pciesvc_serdes. | String prefixed to messages to display in the output log.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| ALLOW_RECOVE<br>RED_CLK_WIDTH<br>_ADJUSTMENTS | Yes            | Integer | 0-1   | 0               | <p>When this parameter is set to 1, it affects how the <i>serdes</i> model adjusts its recovered_bit_clk on the receive side (CDR of the data from rx_datap/rx_datan) thus also affecting the rx_byte10_clk/rx_byte10 output of that <i>serdes</i>—adjusting the clock edge to follow the data and maintain the maximum data eye.</p> <p>Typically, digital simulations have no jitter, therefore the ALLOW_RECORED_CLK_WIDTH_ADJUSTMENT default value of 0 disables this tracking and the overhead associated with it and there must be no issues due to the data period always being constant. However, if you have simulations with jitter, this parameter may be overridden with a <i>defparam</i> or the serdes—ALLOW_RECORED_CLK_WIDTH_ADJUSTMENTS_VAR may be assigned a value of 1 (after 1 nS or more of simulation time has passed). Also, assure that every serdes instance in the VIP model had this parameter or_VAR is set to 1 or some PCIE Lanes may become unlocked while others will not.</p> <p>Note: The jitter is expected and not just as a result of incorrect modeling or other unexpected behavior. It is not recommended to set the ALLOW_RECORED_CLK_WIDTH_ADJUSTMENTS to 1 as the default behavior.</p> |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “\_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.



# 9 PCIE Verification Tools

## 9.1 The Global PCIE Address Space Shadow

The purpose of this component is to provide a shadow 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.

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. These regions in the shadow memory can be marked as *IGNORED* via the *AddMemRange()* task.

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). These regions in the shadow memory can be marked as *ORDERED* via the *AddMemRange()* task.

Typically the system shadow is instantiated (usually at the top-level file, analogously to the `svc_mem`) as `global_shadow0`; with a path define set in the testcase to point to it. When multiple root hierarchies are in use (see above discussion on multiple root hierarchies), the hard-coded definition is not used and a lookup task will instead provide the handle to the appropriate hierarchy's shadow.

If the shadow memory is not instantiated, please make sure the following shadow-checking parameters/\_VARs are not enabled:

ENABLE\_SHADOW\_CFG\_LOOKUP (Transaction layer. See [Table 4-4](#))  
 ENABLE\_TX\_TLP\_REPORTING (Driver application. See [Table 3-1](#))  
 ENABLE\_TX\_TLP\_REPORTING (Requester application. See [Table 3-3](#))  
 ENABLE\_TX\_TLP\_REPORTING (Data Link layer. See [Table 3-1](#))  
 ENABLE\_SHADOW\_MEMORY\_CHECKING (model configuration. See [Table 1-4](#))  
 ENABLE\_SHADOW\_MEMORY\_CHECKING (Driver application. See [Table 3-1](#))  
 ENABLE\_SHADOW\_MEMORY\_CHECKING (Requester application. See [Table 3-3](#))

### 9.1.1 Instantiating and Enabling the Global Shadow

In your top file instantiate the shadow memory (or memories) with:

```
`ifdef EXPERTIO_PCIESVC_GLOBAL_SHADOW_PATH      // single root hierarchy:  
  pciesvc_global_shadow global_shadow0();  
  defparam global_shadow0.DISPLAY_NAME = "global_shadow0.";  
  
`else      // Multiple root hierarchies:  
  // root0  
  pciesvc_global_shadow global_shadow0();  
  defparam global_shadow0.DISPLAY_NAME = "global_shadow0.";  
  defparam global_shadow0.HIERARCHY_NUMBER=0; // match your root hierarchy  
  // root1  
  pciesvc_global_shadow global_shadow1();  
  defparam global_shadow1.DISPLAY_NAME = "global_shadow1.";  
  defparam global_shadow1.HIERARCHY_NUMBER=1;  
`endif // EXPERTIO_PCIESVC_GLOBAL_SHADOW_PATH
```

#### 9.1.1.1 Accessing the Shadow Tasks – Single Root Hierarchy

In the case of a single root hierarchy, knowing where you instantiated the global shadow memory, you can then set the global define to provide access to this; either on the command line or in an .fl (filelist) file:

```
+define+EXPERTIO_PCIESVC_GLOBAL_SHADOW_PATH=top.global_shadow0
```

This provides the path to allow the various VIP components to access the global shadow memory. For example:

```
`EXPERTIO_PCIESVC_GLOBAL_SHADOW_PATH.GetExpectedReadData(  
  mem_start_addr,  
  dword_num,  
  byte_enables,  
  transaction_id,  
  exp_word_data,  
  status  
) ;
```

See below for additional examples. See [“Shadow Tasks” on page 193](#) for descriptions of the shadow tasks.

#### 9.1.1.2 Accessing the Shadow Tasks – Multiple Root Hierarchies

In the case of multiple root hierarchies, make sure that the EXPERTIO\_PCIESVC\_GLOBAL\_SHADOW\_PATH define is not defined, but turn on the SystemVerilog

API with the PCIESVC\_INCLUDE\_SYSTEMVERILOG\_API define. In your code, you then need to import to provide access to the global\_shadow\_api, then declare the handle to the global\_shadow:

```
'ifdef PCIESVC_INCLUDE_SYSTEMVERILOG_API
    import pciesvc_api_pkg::pciesvc_global_shadow_api;
    pciesvc_global_shadow_api      global_shadow; // Handle
`endif // PCIESVC_INCLUDE_SYSTEMVERILOG_API
```

Then to get the fill in the handle to the associated SystemVerilog Global Shadow API tasks, call the *LookupGlobalShadow()* task:

With this handle, you will then be able to access the various Shadow API tasks (recall that SystemVerilog API tasks have “Api” appended to their name, so an analogous example to the above would be:

```
pciesvc_global_shadow_api::LookupGlobalShadow(HIERARCHY_NUMBER_VAR,
                                              global_shadow);
if (global_shadow == null)
begin
    $msglog(LOG_NOTE, "%sCheckReceivedData: Could not find a global shadow
(hier_num=%0d)", DISPLAY_NAME, HIERARCHY_NUMBER_VAR);
end
else
begin
    global_shadow.GetExpectedReadDataApi(
        mem_start_addr,
        dword_num,
        byte_enables,
        transaction_id,
        exp_word_data,
        status);
end
```

See <Xref>“Shadow Tasks” on page 193 for descriptions of the shadow tasks.

### 9.1.1.3 Modifying the Shadow Memory Configuration

Within the shadow memory a memory target component is instantiated. To modify the behavior of the shadow’s underlying memory, you will need to explicitly scope into that memory target at instantiation time. (See “[Memory Target Parameters](#)” for a detailed description of the target memory parameters.) Note that you typically will be setting parameters here. Modifying the shadow’s target memory could cause the shadow to become corrupted.

Here is an example of how to modify the number of 32-bit pages for the shadow memory:

```
defparam global_shadow0.shadow_mem0.NUM_32_BIT_PAGES = 8192;
```

### 9.1.2 Shadow Tasks

Shadow tasks are accessed via the EXPERTIO\_PCIESVC\_GLOBAL\_SHADOW\_PATH definition discussed in “[Instantiating and Enabling the Global Shadow](#)”, and are used to configure and control the shadow memory. The shadow tasks are described in [Table 9-1](#).

If you are using the SystemVerilog API version of the tasks (that is, if you have multiple root hierarchies), remember that these have “Api” appended to their name.

**Table 9-1** Shadow tasks

| <b>Task Name</b>                                                                                                                                                                                                                                                                                             | <b>Arguments (length)</b> | <b>I/O</b> | <b>Values</b>                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------|------------------------------------------------------------------------------------------------------------------|
| AddMemRange<br><br>Define a special region of memory in the Transaction Handler's shadow memory. Note that is only required if non-default attributes are required on the memory range. Currently the only attribute is "ignored".                                                                           | min_range (64)            | I          | Minimum memory address for the region.                                                                           |
|                                                                                                                                                                                                                                                                                                              | max_range (64)            | I          | Maximum memory address for the region.                                                                           |
|                                                                                                                                                                                                                                                                                                              | attributes (32)           | I          | The attribute(s) for the specified region. Attributes are listed in the <i>pciesvc_application_parms.v</i> file. |
|                                                                                                                                                                                                                                                                                                              | error (1)                 | O          | Returned status for the AddMemRange.                                                                             |
| RemoveMemRange<br><br>Remove a special region of memory that was added previously. Note that the min/max_range must <u>exactly</u> match that which was specified in AddMemRange.                                                                                                                            | min_range(64)             | I          | Minimum memory address for the region.                                                                           |
|                                                                                                                                                                                                                                                                                                              | max_range (64)            | I          | Maximum memory address for the region.                                                                           |
|                                                                                                                                                                                                                                                                                                              | attributes (32)           | I          | The attribute(s) for the specified region to be removed.                                                         |
|                                                                                                                                                                                                                                                                                                              | error (1)                 | O          | Returned error status for the RemoveMemRange call.                                                               |
| GetExpectedReadData<br><br>Fetch the expected dword data for the given transaction. Typically called once per dword being checked, where the offset is in the range [0-data_length_in_dwords) and the byte_enables will match those of the request.                                                          | pcie_start_addr (64)      | I          | Base address for reading the expected data.                                                                      |
|                                                                                                                                                                                                                                                                                                              | offset (32)               | I          | Offset to the <i>pcie_start_addr</i> above. Valid offsets are from 0 to ( <i>data_length_in_dwords</i> -1)       |
|                                                                                                                                                                                                                                                                                                              | byte_enables (4)          | I          | Data word byte enables.                                                                                          |
|                                                                                                                                                                                                                                                                                                              | transaction_id (32)       | I          | The combination of <i>RequesterID</i> and <i>Tag</i> to keep track of a given transaction.                       |
|                                                                                                                                                                                                                                                                                                              | data (32)                 | O          | Dword of expected data being retrieved from the shadow.                                                          |
|                                                                                                                                                                                                                                                                                                              | status (32)               | O          | Returned status for this call                                                                                    |
| TransactionComplete<br><br>Tell the shadow that your application is finished with the identified transaction, and that it should commit or release any resources held for that transaction.<br><br>This task must be called for every memory transaction that results in a returned completion (e.g. MemRd). | pcie_start_addr (64)      | I          | Base address for reading the expected data.                                                                      |
|                                                                                                                                                                                                                                                                                                              | length_in_dwords (32)     | I          | Dword length of the requested transaction (for the full transaction, not just one completion).                   |
|                                                                                                                                                                                                                                                                                                              | transaction_id            | I          | The combination of <i>RequesterID</i> and <i>Tag</i> for the transaction to cleanup.                             |
|                                                                                                                                                                                                                                                                                                              | status (32)               | O          | Returned status for this call                                                                                    |

**Table 9-1** Shadow tasks (Continued)

| Task Name                                                                                                                                                                                       | Arguments (length) | I/O | Values                                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| ReadShadowCfgReg<br><br>Read the given configuration register for a particular device in the shadow configuration space.                                                                        | bdf (16)           | I   | Bus-Device-Function for the device you are reading.                                                                                                |
|                                                                                                                                                                                                 | cfg_reg (10)       | I   | The specific configuration-register number.                                                                                                        |
|                                                                                                                                                                                                 | data (32)          | O   | Value of the shadowed copy of the configuration register.                                                                                          |
|                                                                                                                                                                                                 | status (32)        | O   | Returned status of the task (parameters are in the file <i>pciesvc_cfg_params.v</i> )                                                              |
| ReadShadowCfgCapReg<br><br>Read the given configuration register for a particular device in the shadow configuration space.                                                                     | bdf (16)           | I   | Bus-Device-Function for the device you are reading.                                                                                                |
|                                                                                                                                                                                                 | cfg_cap (8)        | I   | The specific configuration-capability we are reading.                                                                                              |
|                                                                                                                                                                                                 | cfg_reg (10)       | I   | The specific configuration-register offset.                                                                                                        |
|                                                                                                                                                                                                 | data (32)          | O   | Value of the shadowed copy of the configuration register.                                                                                          |
|                                                                                                                                                                                                 | status (32)        | O   | Returned status of the task (parameters are in the file <i>pciesvc_cfg_params.v</i> )                                                              |
| ModifyShadowCfgReg<br><br>Modify the given configuration register with the data provided. Note that the only bits that will be modified are those set in the <i>data_mask</i> .                 | bdf (16)           | I   | Bus-Device-Function for the device you are reading.                                                                                                |
|                                                                                                                                                                                                 | cfg_reg (10)       | I   | The specific configuration-register number.                                                                                                        |
|                                                                                                                                                                                                 | data (32)          | I   | Data to be written to the configuration-register (qualified with the below <i>mask</i> .)                                                          |
|                                                                                                                                                                                                 | data_mask (32)     | I   | Asserted bits indicate which bits of above <i>data</i> argument will be modified in the configuration-register (remaining bits will be unchanged.) |
|                                                                                                                                                                                                 | status (32)        | O   | Returned status of the task (parameters are in the file <i>pciesvc_cfg_params.v</i> )                                                              |
| ModifyShadowCfgCapReg<br><br>Modify the given configuration capabilities register with the data provided. Note that the only bits that will be modified are those set in the <i>data_mask</i> . | bdf (16)           | I   | Bus-Device-Function for the device you are reading.                                                                                                |
|                                                                                                                                                                                                 | cfg_cap (8)        | I   | The specific configuration-capability we are modifying. <b>NOTE: the capability must already exist in the device's configuration database.</b>     |
|                                                                                                                                                                                                 | cfg_reg (10)       | I   | The specific configuration-register offset.                                                                                                        |
|                                                                                                                                                                                                 | data (32)          | I   | Data to be written to the configuration-register (qualified with the below <i>mask</i> .)                                                          |
|                                                                                                                                                                                                 | data_mask (32)     | I   | Asserted bits indicate which bits of above <i>data</i> argument will be modified in the configuration-register (remaining bits will be unchanged.) |
|                                                                                                                                                                                                 | status (32)        | O   | Returned status of the task (parameters are in the file <i>pciesvc_cfg_params.v</i> )                                                              |

Note that each instantiation of the VIP Link Layer has its own means to enable the reporting of transmitted TLPs via the parameter/\_VAR **ENABLE\_TX\_TLP\_REPORTING**. This is set (enabled) by default.

The driver and requester applications also have the same **ENABLE\_TX\_TLP\_REPORTING** parameter/\_VAR, however this should, in general, only be enabled when the corresponding VIP LinkLayer parameter is *not* used (e.g. when the driver/requester are driving a DUT, there isn't any instantiation of the VIP LinkLayer, so in order to capture the transmitted TLPs, this parameter/\_VAR should be set in the driver and/or requester instantiations.)

### 9.1.3 Example Global Shadow Memory Usage

To use the global shadow memory, a few items need to be instantiated and configured, once this is done, the driver and requester will automatically check the memory transactions for data validity.

Set the handle to the tasks, either via the shadow define

(`EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH` in “[Instantiating and Enabling the Global Shadow](#)”) or the SystemVerilog handle (in “[Accessing the Shadow Tasks - Multiple Root Hierarchies](#)”).

Setup the optional ignored memory ranges: by default, the memory in the shadow memory is allocated automatically upon writes to it. If, however, you need to define memory range that is “ignored” when checked (where the reads do not necessarily match the preceding writes – clear-on-write registers are one example.)

```
reg [63:0] MIN_IGNORED_MEM_ADDR,
           MAX_IGNORED_MEM_ADDR; //must be 64 bits wide
reg [31:0] ignored_mem_attr;
reg         mem_error; // returned error
ignored_mem_attr = 0;
// Various MEM_CHECK... params are in pciesvc_application_params.v
ignored_mem_attr[MEM_CHECK_ATTR_IGNORE_BIT];
// Ignore memory between 0x1_0000 for 64KB
MIN_IGNORED_MEM_ADDR = 64'h0000_0000_0001_0000;
MAX_IGNORED_MEM_ADDR = 64'h0000_0000_0001_ffff;
// Now add the ignored memory regions to the shadow memory. Note
// that we are only demonstrating the single-root method:
`EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH.AddMemRange(
    MIN_IGNORED_MEM_ADDR,
    MAX_IGNORED_MEM_ADDR,
    ignored_mem_attr, mem_error
);
// When the test-case, driver or requester compares the memory
// between the MIN/MAX_IGNORED_MEM_ADDR addresses, the shadow
// will return status of "ignored" to indicate that this
// comparison can be ignored.
```

Run your simulation. The VIP driver and requester will automatically check the results of read completions against the original written value (except, of course, the above ignored ranges.)

### 9.1.4 Example Global Shadow Configuration Usage

To use the global shadow configuration space, one must make sure the DUT's default configuration values are written, once this is done, the Transaction Layer will automatically check the transactions against the configuration shadow for validity.

Set the shadow-define (or the multiple-hierarchy setup) as described above.

Make sure any configuration registers in the Shadow Configuration Space match those in the DUT's configuration space by one of the following methods:

- ❖ Writing to the DUTs configuration registers to initialize or change their behavior (which automatically will update the shadow copy).
- ❖ Using the *ModifyShadowCfgReg* and/or *ModifyShadowCfgCapReg* tasks to update the shadow configuration space of non-default startup values for your device – for example, the default value of the ENABLE\_NO\_SNOOP bit in the Device Control Register is '1', if the DUT's default is '0', we need to tell the Global Shadow about that non-default behavior:

```
`ifdef EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH
    // Set the data value
    cfg_data = 0;    // Start with a fresh variable.
    cfg_data[CFG_CAP_DEV_CONTROL_REG_ENABLE_NO_SNOOP_BIT] = 0;
    // Set value mask off the bit(s) we want to modify
    cfg_data_mask = 0;
    cfg_data_mask[CFG_CAP_DEV_CONTROL_REG_ENABLE_NO_SNOOP_BIT]=1;
    //Set mask
    // Modify the bit(s)
`EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH.ModifyShadowCfgCapReg(
    endpoint0_driver0_req_id,
    CFG0_PCIE_CAP_ID,
    CFG0_PCIE_CAP_DEV_CONTROL_REG,
    cfg_data,
    cfg_data_mask,
    cfg_status
);
`endif // EXPERTIO_PCIE_SVC_GLOBAL_SHADOW_PATH
```

Run your simulation. The VIP will check values of the configuration for appropriate behavior.

**Note:** Currently only a subset of the configuration registers is initialized.

## 9.2 The Transaction Logger

All inbound and outbound transactions to/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, call the *\$msglog\_control* task:

```
$msglog_control(
    MSGLOG_CONTROL_SET_TRANSACTION_LOG_FILE,
    0,    // unused argument
    "logfile"
);      // log file or "" to end logging
```

The "*logfile*" is either a relative or full-path name filename. If the log file is given as the empty string (""), the transaction log is closed. See also the Msglog documentation (in Util/Doc) for additional information regarding *\$msglog\_control* and other related tasks.

Transaction log file has a column to display errors. The following table lists errors which can show up in the transaction log file.

| Error                                 | Description                                                             |
|---------------------------------------|-------------------------------------------------------------------------|
| SENT_TLP_STATUS_GOOD_BIT              | Indication that TLP is good                                             |
| SENT_TLP_STATUS_BAD_CRC_BIT           | "CrcEr"; indication that CRC was bad                                    |
| SENT_TLP_STATUS_BAD_SEQ_NUM_BIT :     | "SeqEr"; indication that seq number was not as expected                 |
| SENT_TLP_STATUS_NULLIFIED_BIT         | "Nulif"; indication that TLP was nullified                              |
| SENT_TLP_STATUS_BAD_END_BIT           | "EndEr"; indication that TLP had a bad end                              |
| SENT_TLP_STATUS_MISSING_START_BIT     | "NoSTP"; indication that TLP was sent with missing/corrupt STP          |
| SENT_TLP_STATUS_MISSING_END_BIT       | "NoEND"; indication that TLP was sent with missing/corrupt END          |
| SENT_TLP_STATUS_8G_BAD_HEADER_BIT     | "HdrEr"; indication that TLP was sent with bad STP token header         |
| RECEIVED_TLP_STATUS_GOOD_BIT          | Indication that TLP is good                                             |
| RECEIVED_TLP_STATUS_BAD_CRC_BIT       | "CrcEr"; indication that TLP CRC was bad                                |
| RECEIVED_TLP_STATUS_BAD_SEQ_NUM_BIT : | "SeqEr"; indication that seq number was not as expected                 |
| RECEIVED_TLP_STATUS_NULLIFIED_BIT     | "Nulif"; indication that TLP was nullified                              |
| RECEIVED_TLP_STATUS_BAD_END_BIT       | "EndEr"; indication that TLP was BAD-END                                |
| RECEIVED_TLP_STATUS_PHY_ERR_BIT       | "PhyEr"; indication that TLP was received with phy error                |
| RECEIVED_TLP_STATUS_EI_RX_BIT         | "EIErr"; indication that TLP has EI applied in receiver FIX: redundant. |

### 9.3 The Protocol Analyzer Logger

The VIP supports the Synopsys Protocol Analyzer (PA) tool, which 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.

PA logging is disabled by default. In order to enable PA logging, the variable PCIESVC\_INCLUDE\_PA must be defined, and the file Include/pciesvc\_pa\_pkg.sv must be added to the compile list. There are tasks located in the Transaction Layer, the Data Link Layer, and the Physical Layer to enable and disable which items are logged. All of the parameters that are used below are located in Include/pciesvc\_parms.sv.

<Xref>Table 9-2 describes the Protocol Analyzer tasks in the Transaction Layer.

To invoke Protocol Analyzer, do:

```
% $DESIGNWARE_HOME/bin/pa
```

Documentation is available at

`$DESIGNWARE_HOME/vip/tools/pa/latest/doc/protocol_analyzer_getting_started_guide.pdf`

For more information, see to the Protocol Analyzer documentation.

**Table 9-2 Protocol Analyzer tasks in the Transaction Layer**

| Task Name            | Arguments (length) | I/O | Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|--------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetPATransactionMode | mode (32)          | I   | <p>Configures logging for transactions.</p> <p>PA_TRANSACTION_MODE_TRANSACTION_LOGGING_ENABLED- Transaction logging is enabled.</p> <p>PA_TRANSACTION_MODE_TRANSACTION_LOGGING_DISABLED- Transaction logging is disabled.</p> <p>Enables or disables the logging of transactions for the PA tool. Transaction logging is disabled by default.</p>                                                                                                                                                                                      |
| SetPALLogFile        | string filename    | I   | <p>Path and filename where the xml file should be logged.</p> <p>Example: SetPALLogFile("output/my_file.pcie_svc.xml") will redirect the logfile to output/my_file.pcie_svc.xml.</p> <p>NOTE: If changing the default filename, it is recommended that the new logfile end in .pcie_svc_.xml so that the PA tool reads in the log properly.</p> <p>Sets the path and name of the output file. The default file name is <i>instance_name</i>.pcie_svc.xml, where <i>instance_name</i> is the hierarchical path of the device model.</p> |

Control of TLP/DLLP logging is located in the Data Link Layer. [Table 9-3](#) describes the Protocol Analyzer tasks in the Data Link Layer.

**Table 9-3 Protocol Analyzer tasks in the Data Link Layer**

| Task Name     | Arguments (length) | I/O | Values                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|--------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetPALinkMode | mode (32)          | I   | <p>Configures logging for TLP/DLLPs.</p> <p>PA_LINK_MODE_PACKET_LOGGING_DISABLED- TLP/DLLP logging is disabled.</p> <p>PA_LINK_MODE_PACKET_LOGGING_ENABLED- TLP/DLLP logging is enabled</p> <p>PA_LINK_MODE_PAYLOAD_LOGGING_ENABLED- Enabled the logging of payloads when TLP/DLLP logging is enabled.</p> <p>Enables or disables the logging of TLPs and DLLPs for the PA tool. TLP/DLLP logging is disabled by default.</p> |

The Physical Layer has a task to control the logging of ordered sets and the LTSSM states. [Table 9-4](#) describes the Protocol Analyzer task in the Physical Layer.

**Table 9-4 Protocol Analyzer tasks in the Physical Layer**

| Task Name     | Arguments (length) | I/O | Values                                                                                                                                                                                                                                                                                                     |
|---------------|--------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SetPAPhysMode | mode (32)          | I   | <p>Configures logging for ordered sets and the LTSSM state machine.</p> <p>PA_PHY_MODE_LOGGING_DISABLED – all logging in the phy is disabled</p> <p>PA_PHY_MODE_OS_LOGGING_ENABLED – Logging of ordered sets is enabled</p> <p>PA_PHY_MODE_LTSSM_LOGGING_ENABLED – Logging of LTSSM states is enabled.</p> |

Only one configuration parameter can be enabled at a time, so if you want to enable multiple items from the tables above, you must OR the parameters together. Below is an example of how to enable logging for the PA tool:

```
top.root0.t10.SetPATransactionMode(
    PA_TRANSACTION_MODE_TRANSACTION_LOGGING_ENABLED
);
// Enable logging of TLPs and DLLPs with payload:
top.root0.d10.SetPALinkMode(
    PA_LINK_MODE_PACKET_LOGGING_ENABLED |
    PA_LINK_MODE_PAYLOAD_LOGGING_ENABLED
);
// Enable logging of ordered sets only in the phy layer:
top.root0.p10.SetPAPhysMode(PA_PHY_MODE_OS_LOGGING_ENABLED);
```

## Protocol Analyzer Verilog example

```
`ifdef PCIESVC_INCLUDE_PA
    // Enable logging for transactions
    top.root0.port0.t10.SetPALogfile("output/root.xml");
    top.root0.port0.t10.SetTransactionMode(
        PA_TRANSACTION_MODE_TRANSACTION_LOGGING_ENABLED
    );
    // Collect TLP/DLLP and payload data
    top.root0.port0.d10.SetPALinkMode(
        PA_LINK_MODE_PACKET_LOGGING_ENABLED |
        PA_LINK_MODE_PAYLOAD_LOGGING_ENABLED
    );
    // Collect ordered sets and LTSSM information
    top.root0.port0.p10.SetPAPhysMode(
        PA_PHY_MODE_OS_LOGGING_ENABLED |
        PA_PHY_MODE_LTSSM_LOGGING_ENABLED
    );
`endif
```

## Protocol Analyzer UVM example

```
virtual task run_phase(uvm_phase phase) ;  
    ...  
    pciesvc_phy_set_pa_phy_mode_item set_pa_phy_mode;  
    pciesvc_dl_set_pa_link_mode_item set_pa_link_mode;  
    pciesvc_t1_set_pa_transaction_mode_item  
        set_pa_transaction_mode;  
    pciesvc_t1_set_pa_logfile_item set_pa_logfile;  
  
    // Create sequence items  
    set_pa_phy_mode =  
        pciesvc_phy_set_pa_phy_mode_item::type_id::create(  
            "set_pa_phy_mode"  
        );  
    set_pa_link_mode =  
        pciesvc_dl_set_pa_link_mode_item::type_id::create(  
            "set_pa_link_mode"  
        );  
    set_pa_transaction_mode =  
        pciesvc_t1_set_pa_transaction_mode_item::type_id::creat  
(  
            "set_pa_transaction_mode"  
        );  
    set_pa_logfile =  
pciesvc_t1_set_pa_logfile_item::type_id::create(  
    "set_pa_logfile"  
);  
// Enable Protocol Analyzer options  
set_pa_phy_mode.mode = PA_PHY_MODE_OS_LOGGING_ENABLED |  
    PA_PHY_MODE_LTSSM_LOGGING_ENABLED;  
set_pa_link_mode.mode=PA_LINK_MODE_PAYLOAD_LOGGING_ENABLED |  
    PA_LINK_MODE_PACKET_LOGGING_ENABLED;  
set_pa_transaction_mode.mode =  
    PA_TRANSACTION_MODE_TRANSACTION_LOGGING_ENABLED;  
set_pa_logfile.filename = "output/root.xml";  
// Set values by executing  
env.root0.port[0].pl[0].control_agent.sequencer.execute_item ( (set_pa_phy_mode);  
env.root0.port[0].dl[0].control_agent.sequencer.execute_item ( (set_pa_link_mode);  
env.root0.port[0].t1[0].control_agent.sequencer.execute_item ( (set_pa_transaction_mode);  
env.root0.port[0].t1[0].control_agent.sequencer.execute_item ( (set_pa_logfile);  
endtask
```

## 9.4 Symbol Logging

All symbol traffic in and out of the VIP can be captured at the PIPE and recorded in the symbol log file. To enable symbol logging, set the phy layer parameter ENABLE\_SYMBOL\_LOG to 1. For example:

```
defparam top.endpoint0.port0.p10.ENABLE_SYMBOL_LOG = 1;
```

By default this parameter is 0 so symbol logging is disabled.

In simulations with multiple instances of the VIP, all symbol log information is recorded in the same file. Each line of symbol data includes the instance name, so it is possible to separate out the information for a specific instance using standard utilities like grep.

Symbol traffic is captured at the PIPE interface, even if the VIP interface to the simulation is not the PIPE. The PIPE datapath width may be configured as 1, 2 or 4 bytes. If the width is greater than 1 byte, all bytes that are captured on a given cycle are logged at the same time in the symbol log.

Symbols are logged from the perspective of the VIP: symbols received by the VIP are logged on the RX side and symbols transmitted by the vip are logged on the TX side.

The symbol log contains three additional types of information:

- ❖ It shows the current LTSSM state for the VIP. In states where the RX and TX state may differ it shows both states.
- ❖ If encoding, disparity, or bit flip errors are injected on the TX side, it shows which symbols will have those errors. Since all of these errors are injected after symbols pass through the PIPE, the symbol values shown in the symbol log are the original, pre-error values.
- ❖ When the link is operating with 128b/130b encoding, on the TX side it indicates which symbols are the start of TLP or DLLP tokens.

If symbol logging is enabled then by default the VIP will open and write to the file "symbol\_log". To change the file used for symbol logging, use this command:

```
$msglog_control(MSGLOG_CONTROL_SET_SYMBOL_LOG_FILE, 0, "logfile" );
```

The logfile may be either a relative or full-path name filename.

There are two ways to terminate symbol logging before the end of simulation:

- ❖ You can set ENABLE\_SYMBOL\_LOG to 0.
- ❖ Alternatively, you can set the symbol log file to "".

If you use the latter mechanism, then to restart logging during the same simulation you must set a non-null file name.

The following example shows the header of the symbol log and the first few lines in an example with two instances of the VIP.

```
=====
# Symbol logging is performed at the PIPE interface. If the pipe interface is
# configured as multiple bytes, all bytes transferred at a timestep are logged at the
# same timestep.
#
# Symbol logging uses the following special encodings for all link data rates:
#     z   - Electrical idle
#     ?   - Invalid or unknown value
#     .   - 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 timesteps
# at either 2.5 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 8 Gt/s, the symbols after sync headers are prepended with these
# encodings of the sync headers:
#     @   - 2'b'00 (reserved)
#     *   - 2'b'01 (OS block)
#     =   - 2'b'10 (Data block)
#     $   - 2'b'11 (reserved)
#
# Other special character encodings for link operation at 8 Gt/s:
#     ::  - 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.
#=====
```

| TIME | INSTANCE  | R00 |  | T00 | -> | LTSSM State  |
|------|-----------|-----|--|-----|----|--------------|
| 5:   | root0     | .   |  | z   | -> | initializing |
| 5:   | endpoint0 | .   |  | z   | -> | initializing |
| 9:   | root0     | z   |  | z   | -> | initializing |
| 9:   | endpoint0 | z   |  | z   | -> | initializing |
| 13:  | root0     | z   |  | z   | -> | initializing |
| 13:  | endpoint0 | z   |  | z   | -> | initializing |



# 10 Functional Coverage

---

The PCIe VIP provides callback routines which users can utilize for functional coverage. The callbacks 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.

## 10.1 Enabling Functional Coverage

To enable functional coverage the following define must be added to the compile line:

```
+define+PCIESVC_INCLUDE_COVERAGE  
+define+PCIESVC_FLAT_INCLUDES
```

In addition, the file `Include/pciesvc_coverage_pkg.sv` must be added to the compilation file list. If UVM is being used, `pciesvc_coverage_pkg.sv` should be listed after the UVM package.

## 10.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.

## 10.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.

### 10.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
);
```

### 10.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 10-1](#). These tasks may also be called through the SystemVerilog API.

**Table 10-1 Transaction override functions**

| Function Name               | Arguments                                                                                                                          | Layer               |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| SetTransactionCoverageClass | new_class – handle to the new coverage class. The new class must be derived from pciesvc_tl_fc_data or pciesvc_tl_fc_coverage.     | SVC_PATH.port0.tl0  |
| 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 |

## 10.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.

### 10.4.1 Transaction Layer Functional Coverage

[Table 10-2](#) lists the covergroups, coverpoints and bins present in the Transaction Layer coverage class.

**Table 10-2 Covergroups, coverpoints and bins in the Transaction Layer coverage class**

| Covergroup          | Coverpoints    | Bins                                                         |
|---------------------|----------------|--------------------------------------------------------------|
| cg_tx_tc_vc_mapping | cp_tc          | tc_0<br>tc_1<br>tc_2<br>tc_3<br>tc_4<br>tc_5<br>tc_6<br>tc_7 |
|                     | cp_vc          | vc_0<br>vc_1<br>vc_2<br>vc_3<br>vc_4<br>vc_5<br>vc_6<br>vc_7 |
|                     | cp_tc_cross_vc | All TC and VC combinations                                   |
| cg_rx_tc_vc_mapping | cp_tc          | tc_0<br>tc_1<br>tc_2<br>tc_3<br>tc_4<br>tc_5<br>tc_6<br>tc_7 |
|                     | cp_vc          | vc_0<br>vc_1<br>vc_2<br>vc_3<br>vc_4<br>vc_5<br>vc_6<br>vc_7 |
|                     | cp_tc_cross_vc | All TC and VC combinations                                   |

## 10.4.2 Transaction Layer Callbacks

Transaction Layer functional coverage class callbacks and arguments are listed in [Table 10-3](#).

**Table 10-3 Transaction Layer functional coverage class callbacks and arguments**

| Task Name                                                                                         | Arguments | I/O | Values                                                    |
|---------------------------------------------------------------------------------------------------|-----------|-----|-----------------------------------------------------------|
| UpdateTxTcVcMapping<br><br>Called every time the Transaction Layer passes a packet to the link.   | tx_tc     | I   | Traffic class of the transmitted TLP                      |
|                                                                                                   | tx_vc     | I   | VC which maps to the traffic class of the transmitted TLP |
| UpdateRxTcVcMapping<br><br>Called every time the Transaction Layer receives a packet from the DL. | rx_tc     | I   | Traffic class of the received TLP                         |
|                                                                                                   | rx_vc     | I   | VC which maps to the traffic class of the received TLP    |
| SampleTxTcVcMapping<br><br>Called immediately following UpdateTxTcVcMapping()                     | N/A       | N/A | N/a                                                       |
| SampleRxTcVcMapping<br><br>Called immediately following UpdateRxTcVcMapping()                     | N/A       | N/A | N/a                                                       |

## 10.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.

### 10.5.1 Data Link Layer Functional Coverage

[Table 10-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 10-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        |                        |
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint          | Bins                                                                                                                                                              | Comment                |
|------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint          | Bins                                                                                                                                                              | Comment                                                 |
|------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
|            | cp_dllp_type_fc_vc6 | initfc1_p_vc6<br>initfc1_np_vc6<br>initfc1_cpl_vc6<br>initfc2_p_vc6<br>initfc2_np_vc6<br>initfc2_cpl_vc6<br>updatefc_p_vc6<br>updatefc_np_vc6<br>updatefc_cpl_vc6 | VC6 Flow Control DLLPs                                  |
|            | cp_dllp_type_fc_vc7 | initfc1_p_vc7<br>initfc1_np_vc7<br>initfc1_cpl_vc7<br>initfc2_p_vc7<br>initfc2_np_vc7<br>initfc2_cpl_vc7<br>updatefc_p_vc7<br>updatefc_np_vc7<br>updatefc_cpl_vc7 | VC7 Flow Control DLLPs                                  |
|            | cp_hdr_fc           | less_8<br>less_32<br>less_128<br>less_255                                                                                                                         | HDR FC Value (sampled only on flow control type DLLPs)  |
|            | cp_data_fc          | less_128<br>less_512<br>less_1024<br>less_4096                                                                                                                    | DATA FC Value (sampled only on flow control type DLLPs) |
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint           | Bins                                                        | Comment                              |
|------------|----------------------|-------------------------------------------------------------|--------------------------------------|
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint                   | Bins                                                        | Comment                                |
|------------|------------------------------|-------------------------------------------------------------|----------------------------------------|
|            | 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<br>NAK                                                  | ACK/NAK DLLPs                          |
|            | cp_dllp_type_pm              | PM Enter L1<br>PM Enter L23                                 | Power Management DLLPS                 |
|            |                              | PM Active State Request                                     |                                        |
|            |                              | PM Request Ack                                              |                                        |
|            | cp_dllp_type_vendor_specific | Vendor Specific                                             | Vendor Specific                        |

**Table 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint          | Bins                                                                                                                                                              | Comment                |
|------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
|            | cp_dllp_type_fc_vc0 | initfc1_p_vc0<br>initfc1_np_vc0<br>initfc1_cpl_vc0<br>initfc2_p_vc0<br>initfc2_np_vc0<br>initfc2_cpl_vc0<br>updatefc_p_vc0<br>updatefc_np_vc0<br>updatefc_cpl_vc0 | VC0 Flow Control DLLPs |
|            | cp_dllp_type_fc_vc1 | initfc1_p_vc1<br>initfc1_np_vc1<br>initfc1_cpl_vc1<br>initfc2_p_vc1<br>initfc2_np_vc1<br>initfc2_cpl_vc1<br>updatefc_p_vc1<br>updatefc_np_vc1<br>updatefc_cpl_vc1 | VC1 Flow Control DLLPs |
|            | cp_dllp_type_fc_vc2 | initfc1_p_vc2<br>initfc1_np_vc2<br>initfc1_cpl_vc2<br>initfc2_p_vc2<br>initfc2_np_vc2<br>initfc2_cpl_vc2<br>updatefc_p_vc2<br>updatefc_np_vc2<br>updatefc_cpl_vc2 | VC2 Flow Control DLLPs |

**Table 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint          | Bins                                                                                                                                                              | Comment                |
|------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint          | Bins                                                                                                                                                              | Comment                                                 |
|------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
|            | cp_dllp_type_fc_vc6 | initfc1_p_vc6<br>initfc1_np_vc6<br>initfc1_cpl_vc6<br>initfc2_p_vc6<br>initfc2_np_vc6<br>initfc2_cpl_vc6<br>updatefc_p_vc6<br>updatefc_np_vc6<br>updatefc_cpl_vc6 | VC6 Flow Control DLLPs                                  |
|            | cp_dllp_type_fc_vc7 | initfc1_p_vc7<br>initfc1_np_vc7<br>initfc1_cpl_vc7<br>initfc2_p_vc7<br>initfc2_np_vc7<br>initfc2_cpl_vc7<br>updatefc_p_vc7<br>updatefc_np_vc7<br>updatefc_cpl_vc7 | VC7 Flow Control DLLPs                                  |
|            | cp_hdr_fc           | less_8<br>less_32<br>less_128<br>less_255                                                                                                                         | HDR FC Value (sampled only on flow control type DLLPs)  |
|            | cp_data_fc          | less_128<br>less_512<br>less_1024<br>less_4096                                                                                                                    | DATA FC Value (sampled only on flow control type DLLPs) |
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint           | Bins                                                        | Comment                              |
|------------|----------------------|-------------------------------------------------------------|--------------------------------------|
|            | 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 |

**Table 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint            | Bins                                                        | Comment                               |
|------------|-----------------------|-------------------------------------------------------------|---------------------------------------|
|            | 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  |
| 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint              | Bins                                                         | Comment                        |
|------------|-------------------------|--------------------------------------------------------------|--------------------------------|
|            | cp_atomic_ops           | FetchAdd32<br>FetchAdd64<br>Swap<br>Swap64<br>CAS32<br>CAS64 | fmt/type for Atomic Ops        |
|            | cp_traffic class        | tc0<br>tc1<br>tc2<br>tc3<br>tc4<br>tc5<br>tc6<br>tc7         | Traffic Class                  |
|            | 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<br>translation_request<br>translated    | Address transaction bit        |
|            | cp_length               | length_1<br>length_2_thru_1023<br>length_1024                | length field                   |
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint           | Bins                                                                                                                                                                                                                                                                                                         | Comment                                                        |
|------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
|            | 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_msg_code          | cp_assert_inta<br>cp_assert_intb<br>cp_assert_intc<br>cp_assert_intd<br>cp_deassert_inta<br>cp_deassert_intb<br>cp_deassert_intc<br>cp_deassert_intd<br>pm_active_state_nak<br>pm_pme<br>pm_pme_turn_off<br>pm_pme_to_ack<br>err_cor<br>err_non_fatal<br>err_fatal<br>unlock<br>set_slot_power_limit<br>OBFF | Message Code Type                                              |
|            | cp_completion_status | successful completion<br>unsupported request<br>completer abort<br>CRS                                                                                                                                                                                                                                       | Completion Status                                              |

**Table 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint      | Bins                                                                                                                                                                                                                                                                                                                                                                                                     | Comment                      |
|------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
|            | cp_sequence_num | seq_num_0<br>seq_num_1_thru_4095<br>seq_num_4095                                                                                                                                                                                                                                                                                                                                                         | TLP Sequence Number          |
|            | cp_ei_code      | ei_none<br>ei_corrupt_crc<br>ei_illegal_seq_num<br>ei_duplicate_seq_num<br>ei_nullified<br>ei_nullified_good_lcrc<br>ei_nullified_corrupt_lcrc<br>ei_corrupt_disparity<br>ei_codeViolation<br>ei_missing_start<br>ei_missing_end<br>ei_8g_corrupt_header_crc<br>ei_8g_corrupt_header_parity<br>ei_corrupt_ecrc<br>ei_ignore_credit<br>ei_expect_ur<br>ei_expect_crs<br>ei_expect_ca<br>ei_expect_timeout | Error Injection Codes        |
| cg_rx_tlp  | cp_mem_requests | mem_rd_req_32<br>mem_rd_req_64<br>mem_wr_req_32<br>mem_wr_req_64                                                                                                                                                                                                                                                                                                                                         | fmt/type for Memory Requests |

**Table 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint            | Bins             | Comment                               |
|------------|-----------------------|------------------|---------------------------------------|
|            | 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          |                                       |
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint          | Bins                                          | Comment                                                        |
|------------|---------------------|-----------------------------------------------|----------------------------------------------------------------|
|            | 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<br>length_2_thru_1023<br>length_1024 | length field                                                   |
|            | 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 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint           | Bins                                                                                                                                                                                                                                                                                                         | Comment                                 |
|------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
|            | cp_msg_code          | cp_assert_inta<br>cp_assert_intb<br>cp_assert_intc<br>cp_assert_intd<br>cp_deassert_inta<br>cp_deassert_intb<br>cp_deassert_intc<br>cp_deassert_intd<br>pm_active_state_nak<br>pm_pme<br>pm_pme_turn_off<br>pm_pme_to_ack<br>err_cor<br>err_non_fatal<br>err_fatal<br>unlock<br>set_slot_power_limit<br>OBFF | Message Code Type                       |
|            | cp_completion_status | successful completion<br>unsupported request<br>completer abort<br>CRS                                                                                                                                                                                                                                       | Completion Status                       |
|            | cp_sequence_num      | seq_num_0<br>seq_num_1_thru_4094<br>seq_num_4095                                                                                                                                                                                                                                                             | Sequence number assigned to TLP         |
| cg_tx_ipg  | cp_tx_ipg            | ipg_0<br>ipg_1<br>ipg_2<br>ipg_3_to_4<br>ipg_5_to_8<br>ipg_9_to_16<br>ipg_16_to_32<br>ipg_greater_than_32                                                                                                                                                                                                    | Inter packet gap of transmitted packets |

**Table 10-4 Covergroups, coverpoints and bins in the Data Link Layer layer coverage class (Continued)**

| Covergroup | Coverpoint | Bins                                                                                                      | Comment                              |
|------------|------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------|
| cg_rx_ipg  | cp_rx_ipg  | ipg_0<br>ipg_1<br>ipg_2<br>ipg_3_to_4<br>ipg_5_to_8<br>ipg_9_to_16<br>ipg_16_to_32<br>ipg_greater_than_32 | Inter packet gap of received packets |

## 10.5.2 Link Layer Callbacks

Data Link Layer callbacks are listed in [Table 10-5](#).

**Table 10-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.v</code> under <code>RECEIVED_TLP_STATUS*</code> |

**Table 10-5 Data Link Layer callbacks (Continued)**

| <b>Function Name</b>                                                   | <b>Arguments</b>   | <b>I/O</b> | <b>Values</b>                |
|------------------------------------------------------------------------|--------------------|------------|------------------------------|
| UpdateTxTLP<br><br>Called after the link sends the last byte of a TLP. | tlp_fmt[2:0]       | I          | Format field                 |
|                                                                        | tlp_type[4:0]      | I          | Type field                   |
|                                                                        | tc[2:0]            | I          | Traffic class                |
|                                                                        | th                 | I          | Transaction hint             |
|                                                                        | td                 | I          | TLP Digest bit               |
|                                                                        | ep                 | I          | Error/Poison bit             |
|                                                                        | attr_id_order      | I          | ID Order attribute bit       |
|                                                                        | attr_relax_order   | I          | Relaxed order attribute bit  |
|                                                                        | attr_no_snoop      | I          | No snoop attribute attribute |
|                                                                        | at[1:0]            | I          | address translation          |
|                                                                        | length[9:0]        | I          | length field                 |
|                                                                        | ecrc[31:0]         | I          | ECRC(digest) value           |
|                                                                        | lcrc[31:0]         | I          | Link CRC value               |
|                                                                        | sequence_num (int) | I          | Sequence number of the TLP   |
|                                                                        | requester_id[15:0] | I          | Requester ID field           |
|                                                                        | tag[7:0]           | I          | Tag value                    |
|                                                                        | first_dw_be[3:0]   | I          | First DW byte enable field.  |
|                                                                        | last_dw_be[3:0]    | I          | Last DW byte enable field.   |
|                                                                        | address[63:0]      | I          | Address field.               |

**Table 10-5 Data Link Layer callbacks (Continued)**

| <b>Function Name</b>                                                      | <b>Arguments</b>             | <b>I/O</b> | <b>Values</b>                                                                          |
|---------------------------------------------------------------------------|------------------------------|------------|----------------------------------------------------------------------------------------|
| UpdateRxTLP<br><br>Called after the link receives the last byte of a TLP. | ph[1:0]                      | I          | Processing hint                                                                        |
|                                                                           | bus_num[7:0]                 | I          | bus number                                                                             |
|                                                                           | device_num[2:0]              | I          | device number                                                                          |
|                                                                           | function_num[2:0]            | I          | function number                                                                        |
|                                                                           | register_num[9:0]            | I          | Combines reg and ext_reg field for config TLPs                                         |
|                                                                           | message_code[7:0]            | I          | Message code field                                                                     |
|                                                                           | message_dword2[31:0]         | I          | 2 <sup>nd</sup> dword of message TLP. This would be used for vendor specific messages. |
|                                                                           | message_dword3[31:0]         | I          | 3 <sup>rd</sup> dword of message TLP.                                                  |
|                                                                           | completer_id[15:0]           | I          | Completer ID field                                                                     |
|                                                                           | completion_status[2:0]       | I          | Completion status                                                                      |
|                                                                           | bcm                          | I          | Byte count modified field                                                              |
|                                                                           | byte_count[11:0]             | I          | Byte count field                                                                       |
|                                                                           | lower_address[6:0]           | I          | Lower address field.                                                                   |
|                                                                           | steering_tag[7:0]            | I          | Steering tag.                                                                          |
|                                                                           | payload_data (dynamic array) | I          | Payload data, if any present.                                                          |
|                                                                           | ei_code [31:0]               | I          | Error injection code associated with the TLP.                                          |
|                                                                           | tlp_fmt[2:0]                 | I          | Format field                                                                           |
|                                                                           | tlp_type[4:0]                | I          | Type field                                                                             |
|                                                                           | tc[2:0]                      | I          | Traffic class                                                                          |
|                                                                           | th                           | I          | Transaction hint                                                                       |
|                                                                           | td                           | I          | TLP Digest bit                                                                         |
|                                                                           | ep                           | I          | Error/Poison bit                                                                       |
|                                                                           | attr_id_order                | I          | ID Order attribute bit                                                                 |
|                                                                           | attr_relax_order             | I          | Rleaxed order attribute bit                                                            |
|                                                                           | attr_no_snoop                | I          | No snoop attribute attribute                                                           |

**Table 10-5 Data Link Layer callbacks (Continued)**

| <b>Function Name</b>                                | <b>Arguments</b>             | <b>I/O</b> | <b>Values</b>                                                                          |
|-----------------------------------------------------|------------------------------|------------|----------------------------------------------------------------------------------------|
|                                                     | at[1:0]                      | I          | address translation                                                                    |
|                                                     | length[9:0]                  | I          | length field                                                                           |
|                                                     | ecrc[31:0]                   | I          | ECRC(digest) value                                                                     |
|                                                     | lcrc[31:0]                   | I          | Link CRC value                                                                         |
|                                                     | sequence_num (int)           | I          | Sequence number of the TLP                                                             |
|                                                     | requester_id[15:0]           | I          | Requester ID field                                                                     |
|                                                     | tag[7:0]                     | I          | Tag value                                                                              |
|                                                     | first_dw_be[3:0]             | I          | First DW byte enable field.                                                            |
|                                                     | last_dw_be[3:0]              | I          | Last DW byte enable field.                                                             |
|                                                     | address[63:0]                | I          | Address field.                                                                         |
|                                                     | ph[1:0]                      | I          | Processing hint                                                                        |
|                                                     | bus_num[7:0]                 | I          | bus number                                                                             |
|                                                     | device_num[2:0]              | I          | device number                                                                          |
|                                                     | function_num[2:0]            | I          | function number                                                                        |
|                                                     | register_num[9:0]            | I          | Combines reg and ext_reg field for config TLPs                                         |
|                                                     | message_code[7:0]            | I          | Message code field                                                                     |
|                                                     | message_dword2[31:0]         | I          | 2 <sup>nd</sup> dword of message TLP. This would be used for vendor specific messages. |
|                                                     | message_dword3[31:0]         | I          | 3 <sup>rd</sup> dword of message TLP.                                                  |
|                                                     | completer_id[15:0]           | I          | Completer ID field                                                                     |
|                                                     | completion_status[2:0]       | I          | Completion status                                                                      |
|                                                     | bcm                          | I          | Byte count modified field                                                              |
|                                                     | byte_count[11:0]             | I          | Byte count field                                                                       |
|                                                     | lower_address[6:0]           | I          | Lower address field.l                                                                  |
|                                                     | steering_tag[7:0]            | I          | Steering tag.                                                                          |
|                                                     | payload_data (dynamic array) | I          | Payload data, if any present.                                                          |
| UpdateTxIpg                                         | ipg(int)                     | I          | Number of bytes between current packet and previously transmitted packet.              |
| Called every time a new packet starts transmission. |                              |            |                                                                                        |
| UpdateRxIpg                                         | ipg(int)                     | I          | Number of bytes between current packet and previously received packet                  |
| Called on the start of a new received packet.       |                              |            |                                                                                        |

**Table 10-5 Data Link Layer callbacks (Continued)**

| <b>Function Name</b>                                                                  | <b>Arguments</b> | <b>I/O</b> | <b>Values</b>                                                                                                |
|---------------------------------------------------------------------------------------|------------------|------------|--------------------------------------------------------------------------------------------------------------|
| UpdateDLCMSMState<br><br>This function is called every time the DLCMSM changes state. | state[31:0]      | I          | 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]      | I          | 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                                                                                                          |

## 10.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.

### 10.6.1 Physical Layer Functional Coverage

Covergroups, coverpoints and bins in the Physical Layer coverage class are described in [Table 10-6](#).

**Table 10-6 Covergroups, coverpoints and bins in the Physical Layer coverage class**

| Covergroup               | Coverpoint               | Bins          | Comment                       |
|--------------------------|--------------------------|---------------|-------------------------------|
| cg_negotiated_data_rate  | cp_negotiated_data_rate  | speed_2_5G    | Data rate upon entry into L0  |
|                          |                          | speed_5_0G    |                               |
|                          |                          | speed_8_0G*   |                               |
| cg_negotiated_link_width | cp_negotiated_link_width | link_width_1  | Link width upon entry into L0 |
|                          |                          | link_width_2  |                               |
|                          |                          | link_width_4  |                               |
|                          |                          | link_width_8  |                               |
|                          |                          | link_width_12 |                               |
|                          |                          | link_width_16 |                               |
|                          |                          | link_width_32 |                               |

**Table 10-6 Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)**

| Covergroup                 | Coverpoint | Bins                                                            | Comment                                                                                                     |
|----------------------------|------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| 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_loopback_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 10-6 Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)**

| Covergroup | Coverpoint | Bins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Comment |
|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|            |            | configuration_lanenum_accept_to_configuration_lanenum_wait<br>configuration_lanenum_accept_to_detect_quiet<br>configuration_lanenum_wait_to_configuration_lanenum_accept<br>configuration_lanenum_wait_to_detect_quiet<br>configuration_complete_to_configuration_idle<br>configuration_complete_to_detect_quiet<br>configuration_idle_to_I0<br>configuration_idle_to_detect_quiet<br>configuration_idle_to_recovery_rcvrlock<br>recovery_rcvrlock_to_recovery_equalization_phase0*<br>recovery_rcvrlock_to_recover_equalization_phase1*<br>recovery_rcvrlock_to_recovery_rcvrcfg<br>recovery_rcvrlock_to_recovery_speed<br>recovery_rcvrlock_to_configuration_linkwidth_start<br>recovery_rcvrlock_to_detect_quiet<br>recovery_equalization_phase0_to_recovery_speed*<br>recovery_equalization_phase0_to_recovery_equalization_phase1<br>recovery_equalization_phase1_to_recovery_rcvrlock*<br>recovery_equalization_phase1_to_recovery_speed* |         |

**Table 10-6 Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)**

| Covergroup | Coverpoint | Bins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Comment |
|------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
|            |            | recovery_equalization_phase2_to_recovery_speed*<br>recovery_equalization_phase2_to_recovery_equalization_phase3*<br>recovery_equalization_phase3_to_recovery_speed*<br>recovery_equalization_phase3_to_recovery_rcvrlock*<br>recovery_speed_to_recovery_rcvrlock<br>recovery_rcvrcfg_to_recovery_idle<br>recovery_rcvrcfg_to_configuration_linkwidth_start<br>recovery_rcvrcfg_to_recovery_idle<br>recovery_rcvrcfg_to_configuration_linkwidth_start<br>recovery_rcvrcfg_to_detect_quiet<br>recovery_idle_to_disabled<br>recovery_idle_to_hot_reset<br>recovery_idle_to_configuration_linkwidth_start<br>recovery_idle_to_loopback_entry<br>recovery_idle_to_l0<br>recovery_idle_to_detect_quiet<br>recovery_idle_to_recovery_rcvrlock<br>l0_to_recovery_rcvrlock<br>l0_to_l1_entry<br>l1_entry_to_l1_idle<br>l1_entry_to_recovery_rcvrlock<br>l1_idle_to_l1_1_idle* |         |

**Table 10-6 Covergroups, coverpoints and bins in the Physical Layer coverage class (Continued)**

| Covergroup                     | Coverpoint                     | Bins                                                                                                                                                                                                                                                                                                                                                                                                                | Comment                                        |
|--------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
|                                |                                | l1_idle_to_l1_2_entry*<br>l1_2_entry_to_l1_2_idle*<br>l1_2_idle_to_l1_2_exit*<br>l1_2_exit_to_l1_idle*<br>l1_1_idle_to_l1_idle*<br>l1_1_idle_to_recovery_rcvlock*<br>l0_to_l2_idle<br>l2_idle_to_detect_quiet<br>disabled_to_detect_quiet<br>loopback_entry_to_loopback_active<br>loopback_entry_to_loopback_exit<br>loopback_active_to_loopback_exit<br>loopback_exit_to_detect_quiet<br>hot_reset_to_detect_quiet |                                                |
| cg_tx_l0s_substate_transitions | cp_tx_l0s_substate             | l0_to_l0s_entry<br>l0s_entry_to_l0s_idle<br>l0s_idle_to_l0s_fts<br>l0s_fts_to_l0                                                                                                                                                                                                                                                                                                                                    | L0s substate transitions for the transmit side |
| cg_rx_l0s_substate_transitions | cp_rx_l0s_substate_transitions | l0_to_l0s_entry<br>l0s_entry_to_l0s_idle<br>l0s_idle_to_l0s_fts<br>l0s_fts_to_l0<br>los_fts_to_recovery_rcvlock                                                                                                                                                                                                                                                                                                     | L0s substate transitions for the receive side  |

\*Exist for 8G models only

## 10.6.2 Physical Layer Callbacks

Callbacks in the Physical Layer are defined in [Table 10-7](#).

**Table 10-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                              |

## 10.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`.

### 10.7.1 PIPE Functional Coverage

PIPE functional covergroups coverpoints, and bins are listed in [Table 10-8](#).

**Table 10-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

### 10.7.2 PIPE Interface Callbacks

Callbacks in the PIPE interface are listed in [Table 10-9](#).

**Table 10-9 PIPE callbacks**

| Function Name                                                                                              | Arguments           | I/O | Values                    |
|------------------------------------------------------------------------------------------------------------|---------------------|-----|---------------------------|
| UpdateRate<br><br>Called every time the pipe signal rate changes.                                          | rate [1:0]          | I   | Pipe rate value           |
| UpdataPowerDown<br><br>Called every time the pipe signal powerdown changes.                                | powerdown[2:0]      | I   | Pipe powerdown value      |
| UpdateDataBusWidth<br><br>This function is called every time the pipe signal data_bus_width changes value. | data_bus_width[1:0] | I   | Pipe data bus width value |

**Table 10-9 PIPE callbacks (Continued)**

| <b>Function Name</b>                                                                                                                                      | <b>Arguments</b>   | <b>I/O</b> | <b>Values</b>                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------|-------------------------------|
| 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          |
|                                                                                                                                                           | invert_rx_polarity |            | invert received polarity      |
| 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                                                                                                                  |                    |            |                               |



# 11 PCIe VIP Verification Plans

VCS Verification Planner is a verification planning system that is incorporated into the Synopsys PCIe VIP. It allows you to apply data from test runs to a verification plan which you can use to track the progress of the verification project.

A verification plan is a way to describe a scheme for achieving verification goals for the PCIe VIP. The verification plan contains feature declarations, attributes, goals, and metrics for analyzing the progress of the verification.

The Synopsys PCIe VIP provides predefined verification plans listed in the tables below. These verification plans are available in the Verilog/Doc/VerificationPlans directory.

## 11.1 Top-level Plans

Top-level PCIe VIP verification plans are listed in [Table 11-1](#).

**Table 11-1 Top-level verification plans for the PCIe VIP**

| DUT Operation | VIP Operation | Top-Level Plan                            |
|---------------|---------------|-------------------------------------------|
| Root          | Endpoint      | pciesvc_root_dut_toplevel_fc_plan.xml     |
| Endpoint      | Endpoint      | pciesvc_endpoint_dut_toplevel_fc_plan.xml |

## 11.2 Subplans

Subplans of the top-level PCIe VIP verification plan are listed in [Table 11-2](#).

**Table 11-2 Subplans of the top-level verification plan for the PCIe VIP**

| Subplan Name            | VIP Layer   | Comments                          |
|-------------------------|-------------|-----------------------------------|
| pciesvc_transaction.xml | Transaction | TC/VC Mapping                     |
| pciesvc_link.xml        | Link        | TX/RX packets and their fields    |
| pciesvc_phy.xml         | Physical    | Link speed, width, LTSSM and PIPE |

## 11.3 Back-annotation with VCS Verification Planner

Back-annotation of a verification plan refers to applying the results of a test to the verification plan. Use the following command to back-annotate the PCIe VIP verification plan:

```
hvp annotate -dir simv.vdb -plan usb_svt/doc/VerificationPlans/  
svt_usb_device_dut_ss_toplevel_fc_plan.xml
```

The inputs to the command above are:

- ❖ simv.vdb – The coverage database file
- ❖ usb\_svt/doc/VerificationPlans/svt\_usb\_device\_dut\_ss\_toplevel\_fc\_plan.xml – The top-level functional verification plan

# 12 Debugging the PCIe VIP

---

The PCIe VIP is implemented as a gray-box SystemVerilog model. Its internal states are identified by strings and can be observed in waveform viewers.

Runtime log files are particularly useful for debugging the PCIe. The model implements the SystemVerilog `$msglog` task to control what information is written to the log during a test run.

The Synopsys Protocol Analyzer also can be used as a debugging tool. The Protocol Analyzer tool provides the following debugging features:

- ❖ Protocol-aware GUI
- ❖ Viewing of protocol activity, including the ability to
  - ◆ View all layers with parent, child, and sibling
  - ◆ Browse multiple protocols simultaneously
- ❖ Immediate error identification
  - ◆ Highlights errors on a protocol-centric view
  - ◆ Provides detailed information on demand
  - ◆ Offers extensive filtering to speed up debugging
- ❖ Unified debugging
  - ◆ Synchronized to log files with back annotation of errors into the protocol view
  - ◆ Linked to Synopsys VIP user documentation
  - ◆ Can support customer VIPs
  - ◆ Supports synchronized debugging with DVE and Verdi.

## 12.1 Using Run Logs for Debugging

All `$msglog` PLI calls print to the standard output (see [PLI Task \\$msglog](#)). Each `$msglog` entry includes the path to the module that initiated the log entry.

### 12.1.1 Setting Log Severity Levels

The \$msglog task is used to display and log messages at a severity level you specify. The following are the levels for logging, in order of decreasing severity:

- ❖ ERROR
- ❖ WARNING
- ❖ NOTICE
- ❖ INFO
- ❖ TRANSACTION
- ❖ FSM / FRAME
- ❖ DWORD
- ❖ DEBUG

ERROR, WARNING, and NOTICE are three levels of critical errors and should always be addressed by the test writer.

### 12.1.2 Logging Transactions

Transactions are logged in a separate log, with each transaction on one line in the log. You use the \$msglog\_control task to with the MSGLOG\_CONTROL\_SET\_TRANSACTION\_LOG\_FILE command argument to enable transaction logging. See [The Transaction Logger](#).

### 12.1.3 Searching the Log

Search for “Queued” in the log file to find TLPs queued to the applications. For example:

```
100488: DEBUG4: root0.driver0.: Queued MemWr with request  
number 30 to address 0x2e980a7c
```

Requests initiated by the application are stored in a table. Each received completion is mapped to a request stored in the table with status of “ACTIVE” or “COMPLETE\_PARTIAL”.

Search for “TransmitTLP” or “ReceiveTLP” to see TLPs transmitted or received by the VIP.

Search for a transaction ID (for example XID = 0xd80014) to find related TLPs.

A transaction ID can be used to map a particular TLP to the transaction log (R\_ID/Tag column) or to waveforms (ASCII in the Transaction Layer).

### 12.1.4 Logging Symbols

Symbol traffic for all VIP instances can be logged in a separate log, with symbols for each timestep and each instance on one line in the log. Use the phy layer parameter ENABLE\_SYMBOL\_LOG to enable and disable logging. To specify a file name other than the default "symbol\_log", use the \$msglog\_control task with the MSGLOG\_CONTROL\_SET\_SYMBOL\_LOG\_FILE command argument. See [“Symbol Logging”](#).

## 12.2 Analyzing Runtime Statistics

Statistics about the current test are available during runtime. Separate statistics are logged for each layer and application.

The `DisplayStats()` function prints the internal statistics registers. You can also look in the `Application_app` directory and the `TransactionLayer`, `LinkLayer`, and `PhyLayer` directories for `stat_num_infokind`, to see what was logged for the statistic identified by `stat_num_infokind`.

## 12.3 Debugging Using the Protocol Analyzer

The Protocol Analyzer is a protocol-oriented analysis tool that can be used with the DVE tool to debug designs using Verification IPs (VIPs).

The DVE tool is a Graphical User Interface (GUI) that you can use for debugging SystemVerilog, VHDL, Verilog, and SystemC designs. You can drag-and-drop your signals in various views or use the menu options to view the signal source, trace drivers, compare waveforms, and view schematics.

The Protocol Analyzer tool supports the following PCIe features:

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

### 12.3.1 Protocol Analyzer Settings File

Protocol Analyzer settings are saved in a file named `~/pa/preferences`.

You can reset screen settings to their defaults by deleting `pa.pa.pg`.

### 12.3.2 Enabling the Protocol Analyzer for PCIE

The Protocol Analyzer tool is off by default. You must enable it to get XML output for Protocol Analyzer.

Define `PCIESVC_INCLUDE_PA`:

```
vcs ... +define+PCIESVC_INCLUDE_PA
```

Include the `pciesvc_pa_pkg.sv` file:

```
vcs ... +define+PCIESVC_INCLUDE_PA \
$EXPERTIO_PCIESVC_INSTALL_PATH/Include/pciesvc_pa_pkg.sv
```

### 12.3.3 Protocol Analyzer Controls

Enable the controls listed in [Table 12-1](#) before link training is performed. These controls should be set only once because multiple on/off attempts may result in data being lost.

**Table 12-1 Protocol Analyzer controls to set prior to link training**

| <b>Control</b>                              | <b>Description</b>                                                        |
|---------------------------------------------|---------------------------------------------------------------------------|
| SetPALLogFile<br>(Transaction Layer)        | Sets the log file name.<br>Default: <i>instance_name.pcie_svc.xml</i>     |
| SetPATransactionMode<br>(Transaction Layer) | On/Off control of transaction logging.<br>Default: Off.                   |
| SetPALinkMode<br>(Link Layer)               | On/Off control of DL logging of TLPs and DLLPs.<br>Default: Off.          |
| SetPAPhyMode<br>(Physical Layer)            | On/off control of Physical Layer logging of LTSSM state.<br>Default: Off. |

#### 12.3.4 Protocol Analyzer Flow with DVE

1. Enable the Protocol Analyzer tool.
2. Compile the code  
Set up defines, include files, and enable debug (for waveform interaction with the DVE tool).
3. Create a Protocol Analyzer project. [Figure 12-1](#) shows the dialog to create a project.
4. Import files. Add the .vpd and .tcl files to the project. The .tcl script builds the signal list in the waveform viewer.  
[Figure 12-2](#) shows the Import Files dialog for adding files to the project.
5. Run the test.
6. Navigate with transaction and log views to examine the test results. [Figure 12-3](#) shows the Protocol Analyzer transaction and log views combined in one GUI window.
7. Sync with the DVE tool.

**Figure 12-1 Creating a Protocol Analyzer project**



**Figure 12-2 Importing the .tcl and .vpd files to the project**



**Figure 12-3 Protocol Analyzer transaction and log view**

### 12.3.5 Launching the DVE Connection Wizard

1. Select the .vpd or .tcl file under “Waveform Views”.
2. Click the DVE connection wizard button.
3. Make sure the option to run the tcl script is selected.
4. Verify that you have selected the default signal grouping.

Figure 12-4 shows the DVE Connection Wizard dialog for connecting to the DVE waveform viewer.

**Figure 12-4 DVE connection wizard**

Protocol Analyzer results and test output waveforms can then be viewed together to analyze and debug the test run. [Figure 12-5](#) shows the Protocol Analyzer tool synced with the DVE tool.

**Figure 12-5 Synchronized Protocol Analyzer and DVE tools**

## 12.4 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.

### 12.4.1 Transaction Layer ASCII Signals

The ASCII signals listed in [Table 12-2](#) 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 12-2 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_xld     | 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_xld     | Sent TLP transaction ID.                                              |

## 12.4.2 Data Link Layer ASCII Signals

ASCII signals on the Data Link Layer are listed in [Table 12-3](#).

**Table 12-3 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.                    |
| 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]_fcs_m_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                           |

## 12.4.3 Physical Layer ASCII Signals

Physical Layer ASCII signals are listed in [Table 12-4](#).

**Table 12-4 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. |

**Table 12-4 Physical Layer ASCII signals (Continued)**

| Signal Name               | Description                                                                                     |
|---------------------------|-------------------------------------------------------------------------------------------------|
| ascii_lanen_tx_data       | Data transmitted on lane <i>n</i> , where <i>n</i> is a number between 0 and 31.                |
| ascii_pipe_lanen_rx_data; | Symbol data on received on PIPE lane <i>n</i> , where <i>n</i> is a number between 0 and 31.    |
| ascii_pipe_lanen_tx_data  | Symbol data on transmitted on PIPE lane <i>n</i> , where <i>n</i> 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.                                            |

# 13 Memory Model Utility

---

## 13.1 Overview

The Memory Model is a utility used throughout the VIP products offered by Synopsys. The memory model provides a mechanism to manage data, store data structures, and pass arguments in a Verilog environment. The combination of the VIP memory model and the design methodology employed by Synopsys provides many of the benefits of higher level, abstract test bench languages in a Verilog language environment.

The memory model (`svc_mem.v`) is instantiated in the top level of the user test bench. A product-specific Verilog define, ``XXXSVC_MEM_PATH`, where `XXX` is the product name, is assigned a value of that represents the Verilog hierarchy in which the model is instantiated. This define is understood by the VIP products offered by Synopsys when referencing utilities of the memory model.

## 13.2 Memory Model Interface

There are a suite of tasks that may be called to use the memory model. The tasks are described in [Table 13-1](#).

**Table 13-1 Memory Model interface tasks**

| Task Name      | Arguments      | I/O | Purpose                                                                                                                                                                | Description                                                                                                                                                                                                                                                                                                         |
|----------------|----------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AllocateMemory | display_string | I   | The string displayed in the event of an error message (or <code>DisplayMemStat</code> when owner info is dumped). Typically an identifier of where the task is called. | This task allocates a contiguous block of memory. The size argument is in bytes and the <code>mem_ptr</code> is a 4 byte-aligned address. The <code>mem_ptr</code> returned will be page aligned. If the requested buffer cannot be reserved, the value -1 is returned and an error message output to the log file. |
|                | size           | I   | Number of bytes to allocate                                                                                                                                            |                                                                                                                                                                                                                                                                                                                     |
|                | address        | O   | Byte address of the buffer that is allocated                                                                                                                           |                                                                                                                                                                                                                                                                                                                     |

**Table 13-1 Memory Model interface tasks (Continued)**

| Task Name      | Arguments      | I/O | Purpose                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                            |
|----------------|----------------|-----|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FreeMemory     | display_string | I   | The string displayed in the event of an error message. Typically an identifier of where the task is called. | This task will free memory reserved starting at location mem_ptr for length of size bytes. The mem_ptr is a byte address that is 4 byte aligned. An error message will be displayed if the byte address is not 4-byte aligned, the address given has not previously been reserved, or the address given with a size of "0" is not recognized as start of page address. |
|                | address        | I   | Byte address of the start of the buffer to free                                                             |                                                                                                                                                                                                                                                                                                                                                                        |
|                | size           | I   | Number of bytes to free. A value of "0" implies the entire memory page reserved pointed to by address       |                                                                                                                                                                                                                                                                                                                                                                        |
| WriteMemory    | display_string | I   | The string displayed in the event of an error message. Typically an identifier of where the task is called. | This task writes the data specified to the address specified. If the memory has not previously been allocated, an error will be written to the log file. The bytes written will start at the given address and continue for as many bytes supplied in the number of bytes input argument. The number of bytes may range from 1 to 4 bytes.                             |
|                | address        | I   | Byte address to write data                                                                                  |                                                                                                                                                                                                                                                                                                                                                                        |
|                | data           | I   | 32-bit data                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                        |
|                | num_of_bytes   | I   | Number of bytes to write starting at the given byte address                                                 |                                                                                                                                                                                                                                                                                                                                                                        |
| ReadMemory     | display_string | I   | The string displayed in the event of an error message. Typically an identifier of where the task is called  | Returns the 32 bit data starting at the byte address supplied. The memory must already be allocated. If not, an error message will be sent to the log file.                                                                                                                                                                                                            |
|                | address        | I   | Byte address for read data                                                                                  |                                                                                                                                                                                                                                                                                                                                                                        |
|                | data           | O   | 32-bit data                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                        |
| GetMemPageSize | mem_page_size  | O   | Size in bytes                                                                                               | The value of the page size that is being used for memory                                                                                                                                                                                                                                                                                                               |
| IsMemoryEmpty  | result         | O   | 1 = Empty<br>0 = Not Empty                                                                                  | Parses allocated pages. If there is at least one page allocated, returns result of 0, not empty.                                                                                                                                                                                                                                                                       |

**Table 13-1 Memory Model interface tasks (Continued)**

| Task Name      | Arguments      | I/O | Purpose                                    | Description                                                                                                                                                                                                                                                                                                |
|----------------|----------------|-----|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DisplayMemStat | severity_level | I   | The message log level used for the display | If the DISPLAY_MEM_STAT_OWNER_IN parameter (see below) is set, this task will display ownership of the allocated pages, else it displays the current usage map of the 32-bit memory model. A 1 indicates a reserved page; a 0 is a free page. The severity level is used as an input to a \$msglog() call. |
| NumPagesUsed   | num_pages_used | O   | Number of pages currently allocated.       | This task returns the number of pages allocated in memory                                                                                                                                                                                                                                                  |

## 13.3 Memory Size Parameters

There are several parameters used to control the size of the memory. The size of the memory instantiated will directly affect the memory footprint during a simulation. The default values provide a compromise between a reasonable size simulation footprint and offering enough memory for medium to large simulations. For simulations where more memory needed, <Xref>Table 13-2 provides information about setting the appropriate parameters.

**Table 13-2 Memory Model parameters**

| Parameter Name    | Default    | Description                                                                                                                                                                                                                  |
|-------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DISPLAY_NAME      | "svc_mem." | The name that will be displayed in error and statistic message logging. Helps to distinguish the message from another memory model in the case of multiple instantiations.                                                   |
| MEM_SIZE_IN_PAGES | 2048       | The number of pages that in a single memory model. The memory footprint will be approximately the MEM_SIZE_IN_PAGES * PAGE_SIZE_IN_BYTES. Recommend parameter setting:<br>MEM_SIZE_IN_PAGES = Default Value * Number of VIPs |

**Table 13-2 Memory Model parameters (Continued)**

| Parameter Name              | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PAGE_SIZE_IN_BYTES          | 512     | <p>The number of bytes that constitute a page. When using in coordination with a Synopsys VIP, for best memory utilization, set the page size to the block size.</p> <p><b>Note:</b></p> <p>The VIP will calculate which Page size to be allocated (Large or Small) for the incoming requests:</p> <pre>If (tlp_data_length_in_bytes &gt;= PAGE_SIZE_IN_BYTES )     use Large Page else     use Small Page</pre> <p>The PAGE_SIZE_IN_BYTES 512 setting will have VIP use Large Memory Pages for TLPs having length higher value than this. The increase in Page size is to compensate for the multiple VIPs.</p> |
| SMALL_MEM_SIZE_IN_PAGES     | 2048    | <p>The number of ‘small’ pages that in a single memory model. The memory footprint will be approximately the <math>SMALL\_MEM\_SIZE\_IN\_PAGES * SMALL\_PAGE\_SIZE\_IN\_BYTES</math>.</p> <p>Recommend parameter setting:<br/> <math>SMALL\_MEM\_SIZE\_IN\_PAGES = \text{Default Value} * \text{Number of VIPs}</math></p>                                                                                                                                                                                                                                                                                       |
| SMALL_PAGE_SIZE_IN_BYTES    | 32      | The number of bytes that constitute a ‘small’ page. When using in coordination with a Synopsys VIP, for best memory utilization, the page size should be set to optimize memory use based on the required data structures.                                                                                                                                                                                                                                                                                                                                                                                       |
| DISPLAY_MEM_STAT_OWNER_INFO | 0       | If set to 1, the memory will keep track of who allocated the various memory blocks, and when the DisplayMemStat task is called, each owner is printed alongside the amount of memory allocated. If set to 0, the DisplayMemStat task will dump the block usage map.                                                                                                                                                                                                                                                                                                                                              |
| DISPLAY_MEM_STAT_PERIOD     | 000_000 | The time in nanoseconds that the memory model will display statistics to the log file. Statistics include such values as percentage of the memory used, and the current allocation bit map. If this value is zero, statistics will not be sent to the log file.                                                                                                                                                                                                                                                                                                                                                  |

## 13.4 Model Instantiation

The memory model is typically instantiated in the top level of the test bench. The product specific define `XXXSVC_MEM_PATH` is then assigned a value that reflects the location in the hierarchy. See example code fragment below where the module `test_top` is the top-level verilog module of the test environment:

```
`SATAVPC_MEM_PATH test_top.mem0
module test_top;
```



```
svc_mem mem0
.
.
.
endmodule
```



# 14 Message Logging Facility

---

## 14.1 Overview

The VIP message logging facility provides a mechanism for all components in the VIP to use a common logging facility. This provides not only a consistent interface, but also a single log for the outputs of the separate components.

This shared facility allows all modules in the simulation to implicitly make requests to each other. For example, a module can request another module to suppress error message generation when the former is injecting a specific error.

### 14.1.1 Basic Logging Goals

When logging, there are several goals:

- ❖ Display adequate information to the user.
- ❖ Provide a means to count/show various errors that may occur in a standardized way.
- ❖ Allow the user to suppress error messages for cases that are purposely being injected.
- ❖ Avoid using excess resources (either CPU or disk).

To help meet these goals and allow for flexibility to the user, the facility provides for:

- ❖ A means to control the verbosity of displayed log events.
- ❖ A facility to remotely request that a particular log event's level be temporarily suppressed. It can be suppressed for a certain count, and after the expected stimulus has occurred, you can check if the stimulus response causing the message to be suppressed actually occurred (and how many times).
- ❖ Facilities to keep statistics on the logging events. Counters are available at each level of logging, as well as a means to stop the simulation at a particular count threshold.

### 14.1.2 Logging Levels

There are eight levels of logging events. These are divided into three levels of errors, four informative levels and one internal debug level. The logging levels are listed in [Table 14-1](#).

**Table 14-1 Logging event levels**

| Level       | Definition                                                                                                                         |
|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| ERROR       | Problems that will typically require the simulation to stop, i.e. FATAL – due to cascading errors or there is no means to recover. |
| WARNING     | These are serious problems, but the simulation can continue at least for a while.                                                  |
| NOTICE      | A detected problem that should be looked into, but not as serious as WARNING.                                                      |
| INFO        | A general announcement of an informative nature that should normally be logged.                                                    |
| TRANSACTION | Notification of the start or end of a transaction in the VIP.                                                                      |
| FSM / FRAME | Information about state-machine's state change or a full information about packet/frame/FIS to be sent or received.                |
| DWORD       | Details about individual primitives, data words and bytes on the interface.                                                        |
| DEBUG       | Internal VIP debugging information. It can get quite verbose.                                                                      |

Note that levels ERROR, WARNING, and NOTICE are all considered to be errors and should be addressed prior to completion of verification.

## 14.2 Message Logging Utility Routines

Included are several utility routines to log and count messages. The advantages of using these routines over the standard \$display task are:

- ❖ Message output format is standardized.
- ❖ Format controls are centralized – only the C file needs be changed, not the Verilog code.
- ❖ The number of messages for each logging level is counted and can be queried.
- ❖ Simulation can be automatically terminated when a maximum number of messages of a given level are exceeded.
- ❖ Message output can be remotely suppressed by another module to assist in writing directed and error-injecting tests.

The file named Verilog/Util/Msglog/msglog.c contains PLI tasks and functions for logging various levels of messages.

This should be included in a build by either dynamically linking a library that contains the compiled object file named msglog.o, or by explicitly static linking to msglog.o – depending on the particular Verilog simulator in use. See the Verilog/README file for additional information on dynamic and static PLI linking.

The following sections provide a reference for use of the various message logging routines.

### 14.2.1 PLI Task \$msglog

#### Usage

```
$msglog(log_level, [msg_code], format [, args...]);
```

This task is used to display and log messages at a particular log level.

| Task Name | Arguments       | I/O | Description                                                                                    |
|-----------|-----------------|-----|------------------------------------------------------------------------------------------------|
| \$msglog  | log_level (32)  | I   | The requested log level for the message                                                        |
|           | msg_code (32)   | I   | Unique tag to mark this particular \$msglog call for suppression purposes (optional argument). |
|           | format (string) | I   | The format of the message, akin to \$display                                                   |
|           | args (variable) | I   | Optional arguments, akin to \$display                                                          |

The basic output format of the \$msglog output is:

*tttt: LOG\_LEVEL: actual message*

Where *tttt* is the current time tick, *LOG\_LEVEL* is the human-readable log-level and the *actual message* is the format and args of the \$msglog task call. An end-of-line character follows the output line.

## Examples

```
$msglog(LOG_INFO, "The value of the data is %0d", 99);
```

This prints the following:

```
0: INFO: The value of the data is 99
```

Another example, with a message code tag:

```
$msglog(LOG_ERROR, MSG_CODE_XX_YY_SOME_ERR,
        "An error occurred - the actual/expected value was %0d/%0d",
        actual_data_value, expected_data_value)
```

Using the scope that the \$msglog is coded in, and the above MSG\_CODE\_XX\_YY\_SOME\_ERR tag, you can use the \$msglog\_suppress() call to request suppression of this error message. See [PLI Task \\$msglog\\_suppress](#) for details about that task.

### 14.2.1.1 Message Logging Level Parameters

Below are the various log-levels (passed to \$msglog and other tasks) are listed in [Table 14-2](#). Although they are listed as parameters, using a defparam on their values with hard-coded values is not recommended. The numeric values of the parameters may change in future revisions of the code therefore the parameters should be used.

File name: .../Verilog/Util/svc\_util\_parms.v

**Table 14-2 Message logging level parameters**

| Parameter Name          | Description           |
|-------------------------|-----------------------|
| LOG_ERROR<br>LOG_ERR    | Fatal logging level   |
| LOG_WARNING<br>LOG_WARN | Warning logging level |
| LOG_NOTICE<br>LOG_NOTE  | Notice logging level  |

**Table 14-2 Message logging level parameters (Continued)**

| Parameter Name | Description                               |
|----------------|-------------------------------------------|
| LOG_INFO       | Informational logging level               |
| LOG_TRANSACT   | Transaction logging level                 |
| LOG_FSM        | State-Machine and FIS/Frame logging level |
| LOG_FIS        |                                           |
| LOG_FRAME      |                                           |
| LOG_DWORD      | Dword logging level                       |
| LOG_DEBUG      | Debug logging level                       |
| LOG_DBG        |                                           |
| LOG_NUM_LEVELS | Number of logging levels.                 |

Note that some of the log levels have different names for the same level (for example, LOG\_ERROR and LOG\_ERR). This is to allow multiple, often similar names to be used interchangeably, or to reflect that different protocols have different names for similar layers.

Note that while the various log level names (for example, LOG\_INFO) and message code names (for example MSG\_CODE\_\*) are generally fixed and should not change from release to release, their *values* are implementation specific. Avoid hard-coding values for these arguments.

#### 14.2.1.2 Message Code Parameters

A message code is a 32-bit number used to uniquely tag a call to \$msglog. This tag can be used to identify the specific \$msglog call for use in message suppression. To organize these message codes, within each directory are typically files of the form *product\_namesvc\_layer\_msgcodes.v*" (for example, satasvc\_transport\_msgcodes.v). These files contain all the message codes for that layer.

A message code parameter is used as the optional second parameter of the \$msglog PLI task call and has the general form:

MSGCODE\_PRODUCT-NAMESVC\_LAYER\_UNIQUE-NAME

#### Example

MSGCODE\_SATASVC\_LINK\_SLCC\_OPEN\_TIMEOUT\_NOT\_RECV

As with log levels, the various message codes should be identified by names not by their internal values, which might change.

#### 14.2.2 PLI Task \$msglog\_clear

##### Usage

```
$msglog_clear(log_level);
```

This task is used to clear the counters of messages at the given *log\_level*.

| Task Name      | Arguments (length) | I/O | Description                                      |
|----------------|--------------------|-----|--------------------------------------------------|
| \$msglog_clear | log_level (32)     | I   | The requested log level's counter to be cleared. |

### 14.2.3 PLI Function \$msglog\_count

#### Usage

```
value = $msglog_count(log_level);
```

This function is used to get the current count of messages at *log\_level* and below (for example, \$msglog\_count(2) returns the sum of all message counts of levels 0, 1 and 2.) Often this task is called at the end of a test run to display the count of any errors that may have occurred.

| Task Name      | Arguments (length)     | I/O | Description                                              |
|----------------|------------------------|-----|----------------------------------------------------------|
| \$msglog_count | log_level (32)         | I   | The requested log level's counter to be cleared.         |
|                | RETURNS:<br>count (32) | O   | The count of all messages logged at log_level and below. |

#### Example

To count the number of message log events at log levels LOG\_ERROR, LOG\_WARNING and LOG\_NOTICE:

```
count = $msglog_count(LOG_NOTICE);
```

To count the number of message log events only at log level LOG\_WARNING:

```
count = $msglog_count(LOG_WARNING) - $msglog_count(LOG_ERROR);
```

### 14.2.4 PLI Task \$msglog\_exit\_threshold

Usage:

```
$msglog_exit_threshold(log_level, count);
```

This task is used to set the count-threshold of \$msglog displays at the given log level which will cause the simulation to exit.

| Task Name               | Arguments (length) | I/O | Description                                                              |
|-------------------------|--------------------|-----|--------------------------------------------------------------------------|
| \$msglog_exit_threshold | log_level (32)     | I   | The log level associated with the given count.                           |
|                         | count (32)         | I   | The count (at <i>log_level</i> ) that will cause the simulation to exit. |

#### Usage example

To cause the simulation to exit after either 1 ERROR, 5 WARNINGS or 10 NOTICES, whichever comes first:

```
$msglog_exit_threshold(LOG_ERROR, 1);
$msglog_exit_threshold(LOG_WARNING, 5);
$msglog_exit_threshold(LOG_NOTICE, 10);
```

### 14.2.5 PLI Task \$msglog\_level

#### Usage:

```
$msglog_level(log_level [, prev_log_level]);
```

This task is used to set the log level at which messages are displayed. If the optional parameter `prev_log_level` is provided, it will be filled in with the previously set logging level. This controls how verbose the logging is.

| Task Name      | Arguments (length)  | I/O | Description                                                |
|----------------|---------------------|-----|------------------------------------------------------------|
| \$msglog_level | log_level (32)      | I   | The log level at (and below) which messages are displayed. |
|                | prev_log_level (32) | O   | The previous log level (optional task argument).           |

#### Example

```
integer prev_level;
$msglog_level(LOG_NOTICE, prev_level);
// set new log level, save previous
```

### 14.2.6 PLI Function \$msglog\_level\_get

#### Usage

```
log_level = $msglog_level_get(0);
```

This task returns the current log level at which messages are being displayed.

| Task Name          | Arguments(length)      | I/O | Description                                                        |
|--------------------|------------------------|-----|--------------------------------------------------------------------|
| \$msglog_level_get | Unused but required    | I   | Function requires argument – typically pass 0. (Value is ignored.) |
|                    | RETURNS:<br>count (32) | O   | The current log level at (and below) which messages are displayed. |

As with other tasks and functions dealing with message logging levels, ignore the level's value but compare it with existing manifest constants (for example, `LOG_INFO`) instead. Relative values, however, can be assumed. That is, a lower numerical value can be assumed to be a more critical logging level.

#### Example

```
integer cur_log_level;
iur_log_level = $msglog_level_get(0);
if (cur_log_level <= LOG_WARNING)
begin
    // something bad occurred... either LOG_ERROR or
    // LOG_WARNING
end
```

## 14.2.7 PLI Task \$msglog\_suppress

### Usage

```
$msglog_suppress(scope, msg_code, count, options);
```

This task allows you to temporarily suppress the output of a specific call to \$msglog. Often used for directed testing where an error is being injected, but the associated error message should not be displayed.

| Task Name         | Arguments (length) | I/O | Description                                                            |
|-------------------|--------------------|-----|------------------------------------------------------------------------|
| \$msglog_suppress | scope (string)     | I   | String containing scope(s) to match, wildcards allowed.                |
|                   | msg_code (32)      | I   | Specific \$msglog call to suppress.                                    |
|                   | count (32)         | I   | Number of times to suppress the \$msglog call. Zero implies “forever”. |
|                   | options (32)       | I   | Reserved for future, set to 0.                                         |

The \$msglog calls throughout the VIP contain the optional suppression tags if those calls are logging at level LOG\_NOTICE, LOG\_WARNING, or LOG\_ERROR. The msglog codes are kept a parameter file within the director where the VIP source file is kept (so for example, if an VIP Link Layer task has been instrumented with suppression tags, those tags’ parameters will be listed in the file named .../LinkLayer/xxxsvc\_linklayer\_msgcodes.v.) This file must be included in any file from which message suppression is being done.

The scope string must match exactly, but the following wildcards are allowed:

- \* (asterisk) – matches any character, including no characters
- ? (question mark) – matches any single character

Be sure that the call to either \$msglog\_unsuppress or \$msglog\_get\_suppression\_count use the same scope string as was provided to the call to \$msglog\_suppress.

[Example 14-1](#) shows how you could use the message suppression in a situation where there is a stimulus and a responder to that stimulus. The stimulus will be injecting an error to the responder. Rather than handling the expected error message, the stimulus will request that it be suppressed.

After the stimulus has been sent and it is expected that the responder has handled it, the message log suppression is then removed from the responder and the count is checked to verify that the expected suppression did occur.

### Example 14-1

```
// This module is instantiated as top.host0.xport0.xx_yy0
module xx_yy(...);
  `include "Transport/satasvc_transport_msgcodes.v"
  // msg_codes here (example)
  task checker;
    begin
      ...
      if ... // some error condition
        begin
          ...
          $msglog(LOG_ERROR, MSG_CODE_XX_YY_SOME_ERR,
```

```
        "error message") ;

    ...
end
...
end
endtask
endmodule

module stimulus(...);
`include "Transport/satasvc_transport_msgcodes.v"
// msg_codes here (example)
task stim;
integer options = 0;
integer expected_err_count = 1;
integer actual_err_count;
begin
...
// suppress the error
$msglogSuppress("*.host0.xport0.xx_yy0",      //scope
MSG_CODE_XX_YY_SOME_ERR,                      //msg_code
1, 0);                                         //count, options

// Request the stimulus that will cause error
...
// After enough time/events have passed that the
// error should have occurred, remove the
// suppression:
$msglogUnsuppress("*.host0.xport0.xx_yy0",
MSG_CODE_XX_YY_SOME_ERR, actual_err_count);
if (expected_err_count != actual_err_count)
begin
$msglog(LOG_NOTE, "...expected %0d errors,
but actually got %0d", expected_err_count,
actual_err_count);
end
...
end
endtask
endmodule
```

The output of the above suppressed error message would look like:

```
12300: SUPPRESSED_0: error message
```

The error level has been replaced by SUPPRESSED\_0 where the 0 indicates the level of the message that was being suppressed.

Note in the task `stim` in the above code fragment that the `$msglogSuppress` was called with a count of 1. This means that if the `$msglog` call that is being suppressed is called more than once, only the first one will be suppressed (and the actual suppression count that will be returned by `$msglogUnsuppress` will be a maximum value of 1).

## 14.2.8 PLI Task \$msglog\_unsuppress

### Usage

```
$msglog_unsuppress(scope, msg_code, actual_count);
```

This task is used after the expected suppression(s) by \$msglog\_suppress have completed. It returns to the caller the number of suppressions that occurred.

| Task Name           | Arguments (length) | I/O | Description                                                                                                                                                        |
|---------------------|--------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$msglog_unsuppress | scope (string)     | I   | String containing scope(s) to match, wildcards allowed. This must match the scope string passed to \$msglog_suppress <i>exactly</i> .                              |
|                     | msg_code (32)      | I   | Specific \$msglog call to unsuppress.                                                                                                                              |
|                     | count (32)         | O   | Number of times the \$msglog call was actually suppressed. When either the scope and/or msg_code do not match any existing suppression, it will be returned as -1. |

See [PLI Task \\$msglog\\_suppress](#) for an example.

## 14.2.9 PLI Task \$msglog\_get\_suppression\_count

### Usage

```
$msglog_get_suppression_count(scope, msg_code, count);
```

This task is used to count the number of suppressions that have occurred for the given scope/code \$msglog statement. This can be used to determine whether the suppressed error message has occurred yet and how many times.

| Task Name                      | Arguments (length) | I/O | Description                                                |
|--------------------------------|--------------------|-----|------------------------------------------------------------|
| \$msglog_get_suppression_count | scope (string)     | I   | String containing scope(s) to match, wildcards allowed.    |
|                                | msg_code(32)       | I   | Specific \$msglog call to count suppressions of.           |
|                                | count (32)         | O   | Number of times the \$msglog call was actually suppressed. |

To get the current suppression count of a requested suppression:

```
integer count;
$msglog_get_suppression_count(
    "top.host0.xport0.xxx0", // in
    MSGCODE_XXX0_SOME_SPECIFIC_CODE, // in
    count // out
);
if (count < 0)
begin
    $msglog(LOG_NOTE, "Could not find suppression for
        scope=%0s/code=%0d",

```

```

    "top.host0.xport0.xxx0",
    end
else $msglog(LOG_INFO, "The count for the given
    suppression was %0d", count);

```

### 14.2.10 PLI Task \$msglog\_control

#### Usage

```
$msglog_control (request, parameter, args);
```

This task is used for general purpose control of the Message Logging subsystem.

| Task Name        | Arguments (length) | I/O | Description                                                                                          |
|------------------|--------------------|-----|------------------------------------------------------------------------------------------------------|
| \$msglog_control | command (32)       | I   | Command request to the Message Logging subsystem. See <a href="#">Table 14-3</a> for valid commands. |
|                  | parameter (32)     | I   | Detailed per-command parameters. See below for per-command parameters. Set to 0 if unused.           |
|                  | args (32)          | I   | Additional arguments required by the specified command. See below.                                   |

Supported \$msglog\_control commands are listed in [Table 14-3](#).

**Table 14-3 msg\_log control commands**

| Command                                                                                                                                                           | Parameter (length)            | Arguments                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------|
| <b>MSGLOG_CONTROL_SET_DISPLAY</b>                                                                                                                                 |                               |                                                                                                                      |
| Used to display debug information regarding the \$msglog commands, in particular for helping to determine message codes and scope to use for message suppression. | 0 (not used for this command) | MSGLOG_DISPLAY_SCOPE_ENABLED<br>If set, show scopes only of suppressible msglog calls (those with a message code)    |
|                                                                                                                                                                   |                               | MSGLOG_DISPLAY_SCOPE_SHOW_SCOPE<br>If set, show scopes only of suppressible msglog calls (those with a message code) |

**Table 14-3 msg\_log control commands (Continued)**

| Command                                                                                                                                                                    | Parameter<br>(length)                                                                           | Arguments                                                                                                                                                  |                                                                                                                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                            |                                                                                                 | MSGLOG_DISPLAY_SCOPE_SHOW_SUPPRESSABLE<br><br>If this bit is set, show scopes only of suppressible \$msglog calls (those with a message code).             | MSGLOG_DISPLAY_SCOPE_SHOW_AT_START<br><br>If this bit is set, show only dump of scopes at startup. (Only works at compile time.) |
| <b>MSGLOG_CONTROL_SET_LOG_COUNT_VARIABLE</b>                                                                                                                               |                                                                                                 |                                                                                                                                                            |                                                                                                                                  |
| Associate a variable in Verilog with a msglog counter – when \$msglog updates its internal count for a given log-level, the associated variable is simultaneously updated. | log_level (32)<br><br>This is the LOG_xxx log level that will be counted by the count variable. | Scope (string)<br><br>Points to a string that contains the scope to an integer counter variable. Currently a full-scope is required (e.g. "top.err_count") |                                                                                                                                  |
| <b>MSGLOG_CONTROL_SET_LOG_FILE</b>                                                                                                                                         |                                                                                                 |                                                                                                                                                            |                                                                                                                                  |
| Cause the simulation to write VIP logging to a user-specified log file.                                                                                                    | 0 (not used)                                                                                    | Filename (string)<br><br>String containing the full or relative path to the log file. Default is simulator and/or command line dependent.                  |                                                                                                                                  |

**Table 14-3 msg\_log control commands (Continued)**

| Command                                                                                                                                                                                                                           | Parameter<br>(length) | Arguments                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSGLOG_CONTROL_SET_TRANSACTION_LOG_FILE:<br><br>Cause the simulation to write VIP transaction logging to a user-specified log file.<br><br>Note that this task is only useful for those protocols that support a transaction log. |                       | Filename (string)<br><br>This is the string that contains the full or relative path to the transaction log file or "" to disable the log. By default the transaction logger is disabled. |
| MSGLOG_CONTROL_SET_SYMBOL_LOG_FILE<br><br>Set the file to be used for symbol logging.                                                                                                                                             |                       | Filename (string)<br><br>This string contains the full or relative path to the symbol log file. Setting it to "" disables the log.                                                       |

#### 14.2.10.1 MSGLOG\_CONTROL\_SET\_DISPLAY Example

This call will cause suppressed \$msglog calls to show their called scope and message code. This is commonly used to setup appropriate calls to the \$msglog\_suppress task.

```
module top;
  initial
  begin
    $msglog_control(MSGLOG_CONTROL_SET_DISPLAY,
      0,
      (MSGLOG_DISPLAY_SCOPE_ENABLED
       MSGLOG_DISPLAY_SCOPE_SHOW_SUPPRESSABLE
       MSGLOG_DISPLAY_MSG_CODE)
    );
  end
endmodule
```

#### 14.2.10.2 MSGLOG\_CONTROL\_SET\_LOG\_COUNT\_VARIABLE Example

To associate LOG\_WARNING counter updates with a variable named my\_warning\_count:

```
module top;
  integer my_warning_count;
  initial
  begin
    $msglog_control(MSGLOG_CONTROL_SET_LOG_COUNT_VARIABLE,
      LOG_WARN,      //Log level
      "top.my_warning_count");//Full scope
                           //to variable
  end
endmodule
```

#### 14.2.10.3 MSGLOG\_CONTROL\_SET\_LOG\_FILE Example

To redirect VIP logging to a new file named my\_log\_file in the “output” directory:

```
module top;
  reg [64*8-1:0] msglog_file;
  initial
    begin
      msglog_file = "output/my_log_file";
      $msglog_control(MSGLOG_CONTROL_SET_LOG_FILE, 0,
                      msglog_file);
    end
endmodule
```

#### 14.2.10.4 MSGLOG\_CONTROL\_SET\_TRANSACTION\_LOG\_FILE Example

To redirect VIP transaction logging to a new file named transaction\_log in the /tmp directory after the simulation has run for 10,000 ticks, then shut it off after 500,000 more ticks have elapsed.

```
module top;
  reg [64*8-1:0] msglog_transaction_file;
  //Large enough string to hold filename
  initial
  begin
    #10_000; //Do not start logging transactions until
              //10_000 ticks have gone by
    msglog_transaction_file = "/tmp/transaction_log";
    $msglog_control(
      MSGLOG_CONTROL_SET_TRANSACTION_LOG_FILE,
      0,
      msglog_transaction_file
    );
    #500_000; //Let the sim run for 500_000 more ticks
              //then shut off transaction logging
    msglog_transaction_file = ""; //Empty string will
                                //close the transaction log
    $msglog_control(
      MSGLOG_CONTROL_SET_TRANSACTION_LOG_FILE,
      0,
      msglog_transaction_file
    );
  end
endmodule
```

#### 14.2.10.5 MSGLOG\_CONTROL\_SET\_SYMBOL\_LOG\_FILE Example

The following example shows how to

- ❖ Start symbol logging at time 0
- ❖ Specify a non-default symbol file name
- ❖ Stop symbol logging after 50,000 ticks
- ❖ Restart it after another 50,000 ticks.

```
module top;
  ...

```

```
reg [64*8-1:0] msglog_symbol_file; //Large enough string to hold filename
defparam top.<instance_path>.port0.p10.ENABLE_SYMBOL_LOG = 1;

initial
begin
    msglog_symbol_file = "/tmp/symbol_log";
    // Specify the log file name
    $msglog_control( MSGLOG_CONTROL_SET_SYMBOL_LOG_FILE, 0, msglog_symbol_file );
    #50_000;
    // Disable logging
    $msglog_control( MSGLOG_CONTROL_SET_SYMBOL_LOG_FILE, 0, "" );
    #50_000;
    // Re-enable logging
    $msglog_control( MSGLOG_CONTROL_SET_SYMBOL_LOG_FILE, 0, msglog_symbol_file );
end
endmodule
```

# 15 Controlling SVC from C Testbenches

## 15.1 Overview

SVC can be used with testbenches written in C by controlling them through the DPI and VPI programming interfaces. Calling tasks and functions in the SVC is accomplished with the DPI. Section 15.2 describes how to compile the SVC for use with the DPI. Setting and retrieving the values of variables in the SVC is done using the VPI. This chapter does not cover the writing of complete VPI applications. However, an example is presented in section 15.4 as one possible use case.

## 15.2 DPI Exports

The public tasks and function in SVC have been exported through the SystemVerilog DPI. This makes it easier to integrate the IP with testbenches written in C or with other simulators. For more information about the SystemVerilog DPI, refer to the "IEEE Standard For SystemVerilog (1800-2005)" or the documentation for your SystemVerilog simulator.

### 15.2.1 Compiling the DPI Exports

The DPI export statements are conditionally compiled in the code and they must be enabled before they can be used. Define the macro EXPERTIO\_SVC\_DPI\_EXPORT to include the export statements in the SVC modules. Note that the modules are normally written to be compliant with Verilog `95.

Enabling the DPI exports introduces SystemVerilog features into the code. Consequently, the SVC modules must be compiled with SystemVerilog features enabled in the simulator. Some tools use the file name extension to determine if a file is written in Verilog (.v) or SystemVerilog (.sv). The modules usually have a .v extension so it may be necessary to use a command line argument to explicitly tell these tools to compile with SystemVerilog extensions. To avoid name collisions in the C namespace, SVC uses a naming convention to uniquely identify tasks with the same name which are exported from different scopes. Each exported task or function is renamed according to this template:

```
Expertio_<Product Name>_<Layer Name>_<Module Abbreviation>_<Task Name>
```

The actual name of any task or function can be determined by locating it in the Verilog module and looking at the export declaration macro immediately before its definition. For example:

```
`EXPERTIO_DPI_EXPORT_TASK(Expertio_Pciesvc_AppLayer_Requester_StartApp,  
StartApp )  
task StartApp;
```

...

For this task, the function name which should be called from C is `Expertio_Pciesvc_AppLayer_Requester_StartApp`.

### 15.2.2 Using Exported Tasks in C

A program written in C calling a SystemVerilog exported task is semantically equivalent to making hierarchically cross module reference. Therefore, the C program must change its context, or scope, to be the scope where the exported task is defined. The simulator vendor is required by the SystemVerilog standard to provide a function called `svSetScope()` for changing the DPI scope. It takes one argument which is a handle to instance of the module containing the exported task. Getting the scope handle is best done using another vendor supplied function, `svGetScopeFromName()`. The `svGetScopeFromName()` takes a string argument which is the fully qualified instance name of the module and returns a scope handle. This example demonstrates the use of both of these functions.

```
svScope scope_handle;

scope_handle = svGetScopeFromName( "top.instance0.requester0" );
svSetScope( scope_handle );
Expertio_Pciesvc_AppLayer_Requester_StartApp();
```

### 15.3 Notes About System Stability

You must take into consideration the following important notes on system stability when introducing custom C code into a simulation:

- ❖ Memory leaks and bad pointers can cause simulator crashes.
  - ❖ SystemVerilog requires that any DPI imported task/function which calls an exported task/function be declared with the “context” keyword. Failure to do so could lead to unstable behavior in the simulator.
  - ❖ Any C function which is imported in SystemVerilog and also calls a DPI exported task/function must be declared as context.
- ```
import "DPI-C" context task my_c_function();
```
- ❖ Simulators are not thread safe. In general, users should not write a program which spawns off another thread or process and makes DPI or VPI accesses while the simulator is running.

These routines should only be used when invoked by a DPI imported procedure which is called by the simulator or a user defined system task, system function or VPI callback.

### 15.4 VPI Access to SVC Variables

This sample of C code shows how a VPI application might access SVC variables. Functions `SetVariable()` and `GetVariable()` locate a variable in the module hierarchy and set or retrieve its value. Both take a string argument which is the fully qualified hierarchical name of the variable. Integer types and reg vectors up to 32 bits wide can be accessed.

`GetHandleToTopLevelModule` is a helper function which returns a handle to the correct top level module. `GetAndCheckVarHandle` is a helper function which returns a handle to the SVC variable. Some checks are performed to ensure that the value read or write operation succeeds. You may use this code as a starting point and customize it for your application.

### 15.4.1 Sample VPI Access Routines

```
#include <string.h>
#include "vpi_user.h"

static vpiHandle
GetHandleToTopLevelModule( const char const* module_to_find );

static vpiHandle
GetAndCheckVarHandle( char* var_path_name, PLI_INT32* p_var_type );

PLI_INT32
GetVariable( char* var_path_name )
{
    vpiHandle var_handle;
    PLI_INT32 var_type;
    s_vpi_value var_value;
    s_vpi_vecval var_vecval;
    PLI_INT32 value;

    var_handle = GetAndCheckVarHandle( var_path_name, &var_type );

    var_value.value.vector = &var_vecval;
    vpi_get_value( var_handle, &var_value );
    if ( var_value.format == vpiIntVal ) value = var_value.value.integer;
    else if ( var_value.format == vpiVectorVal )
    {
        if ( var_value.value.vector->bval != 0 )
        {
            vpi_printf( "ERROR: GetVariable(): %s contains X or Z values.", var_path_name );
        }
        else value = var_value.value.vector->aval;
    }
    return value;
}

void
SetVariable( char* var_path_name, PLI_INT32 value )
{
    vpiHandle var_handle;
    s_vpi_value var_value;
    s_vpi_vecval var_vecval;
    PLI_INT32 var_type;
    PLI_INT32 vector_size;
    var_handle = GetAndCheckVarHandle( var_path_name, &var_type );
    if ( var_type == vpiIntegerVar )
    {
        var_value.format = vpiVectorVal;
        var_value.value.integer = value;
    }
    else if ( (var_type == vpiReg) || (var_type == vpiRegBit) )
    {
        var_vecval.aval = value;
        var_vecval.bval = 0;
        var_value.format = vpiVectorVal;
        var_value.value.vector = &var_vecval;
    }
    vpi_put_value( var_handle, &var_value, NULL, vpiNoDelay );
}
```

```

vpiHandle
GetAndCheckVarHandle( char* var_path_name, PLI_INT32* p_var_type )
{
    char* top_module_name;
    vpiHandle top_module_handle;
    char* var_sub_name;
    vpiHandle var_handle;
    top_module_name = strtok( var_path_name, "." );
    top_module_handle = GetHandleToTopLevelModule( top_module_name );
    if ( top_module_handle == NULL )
    {
        vpi_printf( "ERROR: Could not find a top level module named \"%s\"\n",
                    top_module_name );
    }
    var_sub_name = strchr( var_path_name, '.' ) + 1;
    var_handle = vpi_handle_by_name( var_sub_name, NULL );
    if ( var_handle == NULL )
    {
        vpi_printf(
            "ERROR: Could not find a variable named \"%s\" in scope \"%s\"\n",
            top_module_name,
            var_sub_name
        );
    }
    *p_var_type = vpi_get( vpiType, var_handle );
    if ( *p_var_type == vpiIntegerVar ) {} // OK.
    else if ( (*p_var_type == vpiReg) || (*p_var_type == vpiRegBit) )
    {
        if ( vpi_get( vpiSize, var_handle ) > 32 )
        {
            vpi_printf( "ERROR: %s is wider than 32 bits. SetVariable()/GetVariable()\n"
                        "cannot access this value", var_path_name );
        }
    }
    else
    {
        vpi_printf(
            "ERROR: SetVariable() cannot set a value on object of type %d at %s",
            *p_var_type,
            var_path_name
        );
    }
}

static vpiHandle
GetHandleToTopLevelModule( const char const* module_to_find )
{
    vpiHandle tops_itor;
    vpiHandle handle;
    char* module_name;
    if ( module_to_find == NULL ) return NULL;
    tops_itor = vpi_iterate( vpiModule, NULL );
    while ( ( handle = vpi_scan( tops_itor ) ) != NULL )
    {
        module_name = vpi_get_str( vpiName, handle );
        if ( strcmp( module_name, module_to_find ) == 0 ) break;
    }
    return handle;
}

```



}



# A Media Module

---

The SVC Media module is a Verilog module that provides a disk (or other media) backing store. It efficiently uses memory to avoid the problems encountered with sparse storage situations, as are frequently encountered in a large disk drive.

The SVC Media Builder is a module that allows the user of the VC VIP for PCI Express to create disk image files that are pre-loadable to the media on a device or host. It is designed to be used as a standalone simulation to generate the media content file.

A medium is described by its ID number, type, and has a fixed block size. It consists of a set of one or more addressing fields that are used in the case of a disk medium to represent one or more LUNs and LBAs.

## A.1 Media Module `svc_media`

The `svc_media` module provides a facility to hold the data for an initiator (host) or device. You first create the medium by calling `RegisterId`, or `LoadMedia` if you have a media content file. Once the medium is created, you use calls to the `WriteMedia` and `ReadMedia` tasks to put data to and get data from the medium.

### A.1.1 Media Module Tasks

Tasks used to access the instantiated media are described in [Table A-1](#).

**Table A-1 Tasks used to access instantiated media**

| <b>Task Name</b> | <b>Arguments (length)</b> | <b>I/O</b> | <b>Argument Description</b>                                                                                                                                         | <b>Task Description</b>                                                                                                                                      |
|------------------|---------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegisterId       | media_id (64)             | I          | The media ID of this media                                                                                                                                          | This task registers the particular media ID. Once a media is registered, one then uses the media ID as a 'handle' to access it via the Read and Write tasks. |
|                  | block_size (32)           | I          | The block size of this media.                                                                                                                                       |                                                                                                                                                              |
|                  | num_luns (32)             | I          | Number of LUNs in this media.                                                                                                                                       |                                                                                                                                                              |
|                  | media_type (8)            |            | The media type of this media (for example, disk).<br>The file <code>svc_media_parms.v</code> contains the various <code>MEDIA_TYPE_</code> values.                  |                                                                                                                                                              |
|                  | status (32)               | O          | Returned status for the result of this task call.<br><br>The file <code>svc_media_parms.v</code> contains the various <code>STATUS_</code> result parameter values. |                                                                                                                                                              |
| LoadMedia        | filename (640)            | I          | The filename of the media content file.                                                                                                                             | This task requests the media load the given file. This will also implicitly call RegisterId with the parameters found in the media content file.             |
|                  | status (32)               | O          | Returned status for the result of the LoadMedia. The <code>svc_media_parms.v</code> file contains the various <code>STATUS_</code> result parameter values.         |                                                                                                                                                              |

**Table A-1 Tasks used to access instantiated media (Continued)**

| <b>Task Name</b> | <b>Arguments (length)</b> | <b>I/O</b> | <b>Argument Description</b>                                                                                                              | <b>Task Description</b>                                                                                                                                                                 |
|------------------|---------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ReadMedia        | media_id (64)             | I          | The media ID of this media                                                                                                               | This task reads the media and returns one data word.<br><br>If it hasn't been registered, it will call RegisterId with the DEFAULT_BLOCK_SIZE, DEFAULT_NUM_LUNS and DEFAULT_MEDIA_TYPE. |
|                  | media_type(8)             | I          | The media type of this media                                                                                                             |                                                                                                                                                                                         |
|                  | lun (64)                  | I          | The LUN address. Not used (set to 0) when addressing a BUFFER media                                                                      |                                                                                                                                                                                         |
|                  | lba (64)                  | I          | The LBA to read from. Overload LBA with the unique BUFFER Id when accessing a BUFFER.                                                    |                                                                                                                                                                                         |
|                  | offset(32)                | I          | The byte offset to read from.                                                                                                            |                                                                                                                                                                                         |
|                  | data (32)                 | O          | The data word from the above ID/LUN/LBA/OFFSET tuple.                                                                                    |                                                                                                                                                                                         |
|                  | found                     | O          | Returns true if the data at the address is valid, else the data will be returned as 'X's.                                                |                                                                                                                                                                                         |
|                  | status                    | O          | Returned status for the result of this task call.<br><br>The file svc_media_parms.v contains the various STATUS_result parameter values. |                                                                                                                                                                                         |

**Table A-1 Tasks used to access instantiated media (Continued)**

| <b>Task Name</b>  | <b>Arguments (length)</b> | <b>I/O</b> | <b>Argument Description</b>                                                                                                                                           | <b>Task Description</b>                                                                                                                                                                                                                                                             |
|-------------------|---------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WriteMedia        | media_id (64)             | I          | The media ID of this media                                                                                                                                            | This task writes (at most) one data word to the media.<br><br>If it hasn't been registered, it will call RegisterId with the DEFAULT_BLOCK_SIZE, DEFAULT_NUM_LUNS                                                                                                                   |
|                   | media_type(8)             | I          | The media type of this media                                                                                                                                          |                                                                                                                                                                                                                                                                                     |
|                   | lun (64)                  | I          | The LUN. When accessing a BUFFER media, this field is not used (set to 0).                                                                                            |                                                                                                                                                                                                                                                                                     |
|                   | lba (64)                  | I          | The LBA. When addressing a BUFFER media, this field is overloaded with the buffer id.                                                                                 |                                                                                                                                                                                                                                                                                     |
|                   | offset(32)                | I          | The byte offset to write to.                                                                                                                                          |                                                                                                                                                                                                                                                                                     |
|                   | data (32)                 | I          | The data word from the above ID/LUN/LBA/OFFSET tuple.                                                                                                                 |                                                                                                                                                                                                                                                                                     |
|                   | num_of_bytes (32)         |            | The number of bytes in <i>data</i> that are valid.                                                                                                                    |                                                                                                                                                                                                                                                                                     |
|                   | found                     | O          | Returns TRUE if this address being written-to has been previously written, else it will return FALSE if it is a write to a previously untouched section of the media. |                                                                                                                                                                                                                                                                                     |
| CountValidSectors | media_id (64)             | I          | The media ID of this media                                                                                                                                            | Returns a count of the number of (contiguous) sectors in this ID/LUN/LBA                                                                                                                                                                                                            |
|                   | media_type(8)             | I          | The media type of this media.                                                                                                                                         |                                                                                                                                                                                                                                                                                     |
|                   | lun (64)                  | I          | The LUN to count.                                                                                                                                                     |                                                                                                                                                                                                                                                                                     |
|                   | lba (64)                  | I          | The LBA to count.                                                                                                                                                     |                                                                                                                                                                                                                                                                                     |
|                   | count (32)                | O          | The returned sector count.                                                                                                                                            |                                                                                                                                                                                                                                                                                     |
| InvalidateMedia   | media_id (64)             | I          | The media ID to reference                                                                                                                                             | Invalidate the LBAs of a given media. This task is used by the user to reset all LUNs / LBAs in the referenced media to an INVALID state. Typically used if the target DUT has been reset in the middle of the sim. The media will remain registers, but the content will be empty. |
|                   | media_type(8)             | I          | The media type of this media.                                                                                                                                         |                                                                                                                                                                                                                                                                                     |
|                   | status                    | O          | Returned status for the result of this task call.<br><br>The file svc_media_parms.v contains the various STATUS_result parameter values.                              |                                                                                                                                                                                                                                                                                     |
| DisplayInfo       | severity_level (31)       | I          | Debug level to display the info.                                                                                                                                      | Dump the contents of the media.                                                                                                                                                                                                                                                     |

### A.1.2 Media Module Parameters

The various parameters define the behavior of the instantiated media are listed in [Table A-2](#). Note that there are two ‘partitions’ defined. The first partition (partition 0) is used to define block-based random access media such as disk drives. The second partition (partition 1) is typically used to define block-based sequential access storage media.

Note that the DEFAULT\_BLOCK\_SIZE can never be larger than the BLOCK\_SIZE\_LIMIT.

**Table A-2 Parameters used to define instantiated media behavior**

| Parameter Name                   | Settable VAR?* | Default                                                                                         | Description                                                                                                                                                                                                                                        |
|----------------------------------|----------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PARTITION0_MAX_NUM_UNIQUE_BLOCKS | No             | 2048                                                                                            | The number of pages in partition 0 of this media device.                                                                                                                                                                                           |
| PARTITION0_BLOCK_SIZE_LIMIT      | No             | 528                                                                                             | The maximum number of bytes in a block for partition 0.                                                                                                                                                                                            |
| PARTITION1_MAX_NUM_UNIQUE_BLOCKS | No             | 0                                                                                               | The number of pages in partition 1 of this media device.                                                                                                                                                                                           |
| PARTITION1_BLOCK_SIZE_LIMIT      | No             | 2048                                                                                            | The maximum number of bytes in a block for partition 1.                                                                                                                                                                                            |
| PARTITION2_MAX_NUM_UNIQUE_BLOCKS | No             | 4                                                                                               | The number of pages in partition 2 of this media device. This is primarily used for storing buffer data. A block represents a unique buffer id in this usage.                                                                                      |
| PARTITION2_BLOCK_SIZE_LIMIT      | No             | 8192                                                                                            | The maximum number of bytes in a block for partition 2. This partition is primarily used to store buffer information (i.e., access through Read/Write Buffer SCSI commands). In the case of a buffer, the entire block is used as the buffer size. |
| INVALID_DATA_WORD                | Yes            | 32'hx                                                                                           | Value returned when reading uninitialized data.                                                                                                                                                                                                    |
| MAX_NUM_MEDIA_ID                 | No             | 128                                                                                             | The maximum number of total media IDs available for use.                                                                                                                                                                                           |
| DEFAULT_BLOCK_SIZE               | No             | 512                                                                                             | Default block size to create when a media content file is not used to specify this.                                                                                                                                                                |
| DEFAULT_NUM_LUNS                 | No             | 32                                                                                              | Default number of LUNs to create per media when a media content file is not used to specify this.                                                                                                                                                  |
| DEFAULT_MEDIA_TYPE               | No             | MEDIA_TYPE_DISK<br>The file<br>svc_media_parms.v<br>contains the various<br>MEDIA_TYPE_ values. | Default media type to create when a media content file is not used to specify this.                                                                                                                                                                |
| LOAD_MEDIA_FILENAME_LIST_LEN     | Yes            | 16 * 257                                                                                        | Space reserved for filename list – 16 filenames of 257 (256 + delimiter) bytes each.                                                                                                                                                               |
| LOAD_MEDIA_FILENAME_LIST         | Yes            | " "                                                                                             | List of DELIMETER separate filenames, total list length (including delimiters) must be < LOAD_MEDIA_FILENAME_LIST_LEN long.                                                                                                                        |

**Table A-2 Parameters used to define instantiated media behavior (Continued)**

| Parameter Name                | Settable VAR?* | Default      | Description                                                                                                                                                               |
|-------------------------------|----------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LOAD_MEDIA_FILENAME_DELIMETER | Yes            | “ “ (space)  | The separator between the filenames in the LOAD_MEDIA_FILENAME_LIST list. Default is a single space.                                                                      |
| DISPLAY_NAME                  | No             | “svc_media.” | The name that will be displayed in error and statistic message logging. Helps to distinguish the message from another media model in the case of multiple instantiations. |

\*Settable VAR marked Yes implies the Parameter Name is also assigned to a Verilog signal in the module. The signal name is the same as the parameter name appended with “\_VAR”. This is useful if using higher level tools to set the parameters of the VIP. If marked No, only the parameter exists in the Verilog module.

## A.2 Media Builder (module: svc\_media\_builder)

This module is used standalone to create media files that are loadable by the VIP. Here are the steps of its use:

1. Instantiate the svc\_media\_builder module.
2. Set parameters (or \_VARs) to control the various options of the media you want to create.
3. Call the BuildMedia() task to generate the file.

Note that these steps are separate from the simulation run for the VIP. The disk media file is created prior to running the VIP simulation

### A.2.1 Media Builder Parameters

The parameters listed in [Table A-3](#) are used to control the basic behavior of the SVC Media Builder. Note that most of the parameters also have a corresponding *parameter\_VAR* version that is a Verilog reg, allowing it to be modified after instantiation. See [“Media Builder Usage Example”](#) for details.

**Table A-3 Media Builder module parameters**

| Parameter Name    | Type    | Default | Description                                                                             |
|-------------------|---------|---------|-----------------------------------------------------------------------------------------|
| MEDIA_ID          | Integer | 0       | The unique Media ID for this media. Each created media needs to have a unique media ID. |
| MEDIA_TYPE        | String  | “DISK”  | The particular Media Type for this media – valid types are “DISK” or “BUFFER”           |
| BLOCK_SIZE        | Integer | 512     | This media’s block size.                                                                |
| LUN_LIST          | String  | “0”     | List of LUNs created for this media. Comma separated.                                   |
| MIN_LUN_SIZE      | Integer | 1       | Minimum per-LUN length, in blocks.                                                      |
| MAX_LUN_SIZE      | Integer | 1       | Maximum per-LUN length, in blocks.                                                      |
| STARTING_LBA_LIST | String  | “0”     | List of starting LBAs. Comma separated.                                                 |
| MIN_CONSEC_BLOCKS | Integer | 1       | Minimum consecutive blocks written after each starting LBA.                             |

**Table A-3 Media Builder module parameters (Continued)**

| Parameter Name    | Type    | Default                 | Description                                                                                                                                                                                                                      |
|-------------------|---------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAX_CONSEC_BLOCKS | Integer | 1                       | Maximum consecutive blocks written after each starting LBA. This value is constrained by the above STARTING_LBA_LIST; if the length would cause overrun from one LBA into another, the first will be truncated (with a message). |
| USE_INCR_DATA     | Boolean | 1                       | Media data generated will be incrementing words.                                                                                                                                                                                 |
| USE_RAND_DATA     | Boolean | 0                       | Media data generated is random words.                                                                                                                                                                                            |
| USE_MEDIA_ID_DATA | Boolean | 0                       | Put Media ID in byte 3 of data (can be combined w/ USE_INCR_ or RAND_DATA)                                                                                                                                                       |
| USE_LBA_DATA      | Boolean | 0                       | Put LBA in byte 2 of data (can be combined w/ USE_INCR_ or RAND_DATA)                                                                                                                                                            |
| USE_LUN_DATA      | Boolean | 0                       | Put LUN in byte 1 of data (can be combined w/ USE_INCR_ or RAND_DATA)                                                                                                                                                            |
| USE_OFFSET_DATA   | Boolean | 0                       | Put Offset in byte 0 of data (can be combined w/ USE_INCR_ or RAND_DATA)                                                                                                                                                         |
| FILENAME          | String  | “svc_media_builder.out” | Filename to write the disk image.                                                                                                                                                                                                |
| DISPLAY_NAME      | String  | “svc_media.”            | The name that will be displayed in error and statistic message logging. Helps to distinguish the message from another memory model in the case of multiple instantiations.                                                       |

## A.3 Media Initialization Content Data File

The data file to load the media consists of the parameters to describe the data loaded on the disk, as well as where it is actually loaded. The individual parameters are listed in [Table A-4](#). The format is described below, followed by a usage example.

**Table A-4 Media initialization data file parameters**

| Keyword Name | Parameter Values | Description                                                                                                                                                                              |
|--------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MediaID      | 64-bit numeric   | The (unique) media identifier for this particular media. When a new media is defined, it must have a corresponding BlockSize (below). If not provided, defaults to previously set value. |
| MediaType    | String           | The specific type of the media. Must be provided immediately after <b>MediaID</b> .<br>Valid values are: “DISK” and “BUFFER”.                                                            |
| BlockSize    | 32-bit numeric   | Sets the Block Size of the media identified by <b>MediaID</b> (in bytes). Must be provided immediately after <b>MediaType</b> .                                                          |
| LUN          | 64-bit numeric   | Logical Unit Number. Must be provided after <b>BlockSize</b> . If not provided, defaults to previously set value.                                                                        |
| LBA          | 64-bit numeric   | Logical Block Address. Must be provided after <b>LUN</b> . If not provided, defaults to previously set value.                                                                            |

**Table A-4 Media initialization data file parameters (Continued)**

| <b>Keyword Name</b> | <b>Parameter Values</b>                                                              | <b>Description</b>                                                                                                                           |
|---------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| DataOffset          | 0 - (BlockSize-1)                                                                    | Data offset into LBA in bytes. Causes data to be written at this offset. Must be provided after <b>LBA</b> . If not provided, defaults to 0. |
| DataLength          | 32-bit numeric                                                                       | Length of data to load, in bytes. Must be provided after the <b>LBA</b> .                                                                    |
| Data                | Space separated list of 32-bit values. Considered decimal unless prefixed with "0x". | This is the actual data to be written to the media. Each value is a 32-bit dword; the number of these must match DataLength.                 |

### A.3.1 Media Initialization Data File Format

The media initialization data file consists of parameters that describe both the location of the data, as well as the actual data.

Each parameter is of the form "keyword = value". Any spaces between the keyword and value are ignored. The keyword and the value can be on the same line or on different lines. Multiple "keyword=value" pairs may be entered on one line, with one or more spaces between the "keyword=value" pairs.

All the keywords are strings (for example, "MEDIAID"). Case is ignored, so MediaID and mediaid are treated identically.

The particular parameters are somewhat hierarchical in that there are some that are dependent on others (for example, you must first provide the DataOffset and DataLength before providing the Data.) Not all the parameters are required in all cases: When practical, they will default from the previous values specified. For example, when writing multiple LBAs, the LUN will default to the previously set value.

Verilog-style comments are allowed in the data file. They can be of block style, delimited by /\* and \*/, or line style:

```
/*
 * This is a block comment, and is used across
 * multiple lines.
 */
// This line-style comment extends to the end of the line
```

Comments are not allowed between keywords and their values.

Values are interpreted as 32 or 64-bit wide decimal (0, 1, 2...) or, if a leading 0x is provided, as hexadecimal (0xabcd1234).

### A.3.2 Media Builder Usage Example

The example below shows how to use the svc\_media\_builder module to create a disk image.

This example demonstrates the two ways to setup the media builder parameters, using defparam to set parameters at compile time, and using the \_VAR variables to set the disk parameters at runtime. For each method, a call to builder0.BuildMedia() creates the file.

```
module build_media; // user defined module
    svc_media_builder builder0();
    // instantiate the media builder
    // By default we create one LUN
    // Create this LUN of random length between 1-200 blocks
```

```

defparam builder0.MIN_LUN_SIZE = 1;
defparam builder0.MAX_LUN_SIZE = 200;
// for this LUN, start data creation at the following LBAs
defparam builder0.STARTING_LBA_LIST =
    "10,20,30,400,500,600,700,800,900";
// Each LBA will have a random length 1-100 blocks (constrained by
// start list)
defparam builder0.MIN_CONSEC_BLOCKS = 1;
defparam builder0.MAX_CONSEC_BLOCKS = 100;
// Write disk data file out to this filename:
defparam builder0.FILENAME = "test_media_disk1.out";
initial
begin
    #1; // wait for any initialization
    // Call Build Disk to build an image
    builder0.BuildMedia;
    // Now build another disk with ID=2 - note use of _VAR
    // variables - we can modify these after instantiation, unlike
    // the defparam statement:
    builder0.FILENAME_VAR = "test_media_disk2.out";
    builder0.MEDIA_ID_VAR = 2;
    // Create 3 LUNs:
    builder0.LUN_LIST_VAR = "0,1,2";
    // of length [10-100] blocks each...
    builder0.MIN_LUN_SIZE_VAR = 10;
    builder0.MAX_LUN_SIZE_VAR = 100;
    // Our list of starting LBAs, each of length [1-100] blocks
    builder0.STARTING_LBA_LIST_VAR = "1,2,4,8,16,32,64,128,256";
    builder0.MIN_CONSEC_BLOCKS_VAR = 1;
    builder0.MAX_CONSEC_BLOCKS_VAR = 100;
    // build it:
    builder0.BuildMedia;
end
endmodule

```

### A.3.2.1 Sample Content File

Below is a sample media data file that demonstrates usage of all the keywords and constructs in the example above.

```

/* Sample Media Data File */
/* Block Comment. You can put it before or after parameter=value
sections, but do not try to do something like
"parameter = 'block comment' 1234".
*/
MediaID=0x42      // Unique identifier
MediaType=Disk    // This media is a 'disk'
BlockSize=512     // This is fixed for a given Media ID
LUNCount=1        // Number of LUNs to be defined
LUN= 1            // The first LUN
LBA = 0
DataOffset = 0
DataLength = 512
//
// Note that the first line of data below is decimal,

```

```
// the rest are hex
//  
Data=  
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15  
0x42010010 0x42010011 0x42010012 0x42010013 0x42010014 0x42010015 0x42010016 0x42010017  
0x42010018 0x42010019 0x4201001a 0x4201001b 0x4201001c 0x4201001d 0x4201001e 0x4201001f  
0x42010020 0x42010021 0x42010022 0x42010023 0x42010024 0x42010025 0x42010026 0x42010027  
0x42010028 0x42010029 0x4201002a 0x4201002b 0x4201002c 0x4201002d 0x4201002e 0x4201002f  
0x42010030 0x42010031 0x42010032 0x42010033 0x42010034 0x42010035 0x42010036 0x42010037  
0x42010038 0x42010039 0x4201003a 0x4201003b 0x4201003c 0x4201003d 0x4201003e 0x4201003f  
0x42010040 0x42010041 0x42010042 0x42010043 0x42010044 0x42010045 0x42010046 0x42010047  
0x42010048 0x42010049 0x4201004a 0x4201004b 0x4201004c 0x4201004d 0x4201004e 0x4201004f  
0x42010050 0x42010051 0x42010052 0x42010053 0x42010054 0x42010055 0x42010056 0x42010057  
0x42010058 0x42010059 0x4201005a 0x4201005b 0x4201005c 0x4201005d 0x4201005e 0x4201005f  
0x42010060 0x42010061 0x42010062 0x42010063 0x42010064 0x42010065 0x42010066 0x42010067  
0x42010068 0x42010069 0x4201006a 0x4201006b 0x4201006c 0x4201006d 0x4201006e 0x4201006f  
0x42010070 0x42010071 0x42010072 0x42010073 0x42010074 0x42010075 0x42010076 0x42010077  
0x42010078 0x42010079 0x4201007a 0x4201007b 0x4201007c 0x4201007d 0x4201007e 0x4201007f  
LUN= 1  
LBA = 1  
  
// First word  
DataOffset = 0  
DataLength = 1  
Data= 0x0          // Least significant byte in dword  
DataOffset = 1    // NOTE: We do not enforce offset+length is on a  
                  // block boundary.  
DataLength = 1  
Data= 0x1  
DataOffset = 2  
DataLength = 1  
Data= 0x1  
DataOffset = 3  
DataLength = 1  
Data= 0x42      // Most significant byte in dword  
  
// Second word  
DataOffset = 4  
DataLength = 2  
Data= 0x0101  
  
// Remainder of second, and start of third word - note implicit data  
// offset  
DataLength = 3  
Data= 0x024201  
DataLength = 3  
Data = 0x420101  
DataLength = 492  
Data=  
0x42010103 0x42010104 0x42010105 0x42010106 0x42010107 0x42010108 0x42010109 0x4201010a  
0x4201010b 0x4201010c 0x4201010d 0x4201010e 0x4201010f  
0x42010110 0x42010111 0x42010112 0x42010113 0x42010114 0x42010115 0x42010116 0x42010117  
0x42010118 0x42010119 0x4201011a 0x4201011b 0x4201011c 0x4201011d 0x4201011e 0x4201011f
```

```
0x42010120 0x42010121 0x42010122 0x42010123 0x42010124 0x42010125 0x42010126 0x42010127
0x42010128 0x42010129 0x4201012a 0x4201012b 0x4201012c 0x4201012d 0x4201012e 0x4201012f
0x42010130 0x42010131 0x42010132 0x42010133 0x42010134 0x42010135 0x42010136 0x42010137
0x42010138 0x42010139 0x4201013a 0x4201013b 0x4201013c 0x4201013d 0x4201013e 0x4201013f
0x42010140 0x42010141 0x42010142 0x42010143 0x42010144 0x42010145 0x42010146 0x42010147
0x42010148 0x42010149 0x4201014a 0x4201014b 0x4201014c 0x4201014d 0x4201014e 0x4201014f
0x42010150 0x42010151 0x42010152 0x42010153 0x42010154 0x42010155 0x42010156 0x42010157
0x42010158 0x42010159 0x4201015a 0x4201015b 0x4201015c 0x4201015d 0x4201015e 0x4201015f
0x42010160 0x42010161 0x42010162 0x42010163 0x42010164 0x42010165 0x42010166 0x42010167
0x42010168 0x42010169 0x4201016a 0x4201016b 0x4201016c 0x4201016d 0x4201016e 0x4201016f
0x42010170 0x42010171 0x42010172 0x42010173 0x42010174 0x42010175 0x42010176 0x42010177
0x42010178 0x42010179 0x4201017a 0x4201017b 0x4201017c 0x4201017d
DataLength = 8
Data = 0x4201017e 0x4201017f
// Comments: you can put them before or after parameter=value
// sections, but do not try to do something like:
// "KEYWORD" // comment that will not work correctly
// 1234".
//
LUN= 1 // MediaID, MediaType and BlockSize are already set, no need
// to specify
LBA = 2
DataOffset = 0
DataLength = 512
Data=
0x42010200 0x42010201 0x42010202 0x42010203 0x42010204 0x42010205 0x42010206 0x42010207
0x42010208 0x42010209 0x4201020a 0x4201020b 0x4201020c 0x4201020d 0x4201020e 0x4201020f
0x42010210 0x42010211 0x42010212 0x42010213 0x42010214 0x42010215 0x42010216 0x42010217
0x42010218 0x42010219 0x4201021a 0x4201021b 0x4201021c 0x4201021d 0x4201021e 0x4201021f
0x42010220 0x42010221 0x42010222 0x42010223 0x42010224 0x42010225 0x42010226 0x42010227
0x42010228 0x42010229 0x4201022a 0x4201022b 0x4201022c 0x4201022d 0x4201022e 0x4201022f
0x42010230 0x42010231 0x42010232 0x42010233 0x42010234 0x42010235 0x42010236 0x42010237
0x42010238 0x42010239 0x4201023a 0x4201023b 0x4201023c 0x4201023d 0x4201023e 0x4201023f
0x42010240 0x42010241 0x42010242 0x42010243 0x42010244 0x42010245 0x42010246 0x42010247
0x42010248 0x42010249 0x4201024a 0x4201024b 0x4201024c 0x4201024d 0x4201024e 0x4201024f
0x42010250 0x42010251 0x42010252 0x42010253 0x42010254 0x42010255 0x42010256 0x42010257
0x42010258 0x42010259 0x4201025a 0x4201025b 0x4201025c 0x4201025d 0x4201025e 0x4201025f
0x42010260 0x42010261 0x42010262 0x42010263 0x42010264 0x42010265 0x42010266 0x42010267
0x42010268 0x42010269 0x4201026a 0x4201026b 0x4201026c 0x4201026d 0x4201026e 0x4201026f
0x42010270 0x42010271 0x42010272 0x42010273 0x42010274 0x42010275 0x42010276 0x42010277
0x42010278 0x42010279 0x4201027a 0x4201027b 0x4201027c 0x4201027d 0x4201027e 0x4201027f
/* EOF */
```



# B Protocol Checks

---

A number of automatic protocol checks are built into the PCIe VIP, to test for compliance with the PCIe specification. The following tables list the protocol checks, with a short description each check and the version of the PCIe specification in which each check is specified.

- ❖ Phy Layer protocol checks are listed in [Table B-1](#).
- ❖ Data Layer protocol checks are listed in [Table B-2](#).
- ❖ Application Layer protocol checks are listed in [Table B-3](#).

**Table B-1 Phy Layer protocol compliance checks**

| Protocol Check Name and Description                                                                                | Spec Version |
|--------------------------------------------------------------------------------------------------------------------|--------------|
| MSGCODE_PCIE_SVC_PHY_EXCESS_LATENCY_DIFF<br><br>RxDeskewLanes - Excessive latency differential between lanes.      | All          |
| MSGCODE_PCIE_SVC_PHY_MISMATCHED_DATA_RATES<br><br>This lane's data rate identifier does not match previous lane's. | >=2.1        |
| MSGCODE_PCIE_SVC_PHY_DETECT QUIET_TIMEOUT<br><br>Timeout in state LTSSM_DETECT QUIET.                              | All          |
| MSGCODE_PCIE_SVC_PHY_DETECT ACTIVE_TIMEOUT<br><br>Timeout in state LTSSM_DETECT ACTIVE.                            | All          |
| MSGCODE_PCIE_SVC_PHY_POLLING ACTIVE_TIMEOUT<br><br>Timeout in state LTSSM_POLLING ACTIVE.                          | All          |
| MSGCODE_PCIE_SVC_PHY_POLLING CONFIGURATION_TIMEOUT<br><br>Timeout in state LTSSM_POLLING CONFIGURATION             | All          |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION LINKWIDTH START TIMEOUT                                                         | All          |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                                                       | <b>Spec Version</b> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Timeout in state LTSSM_CONFIGURATION_LINKWIDTH_START                                                                                                                                             |                     |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_LINKWIDTH_ACCEPT_TIMEOUT<br>Timeout in state LTSSM_CONFIGURATION_LINKWIDTH_ACCEPT                                                                             | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_LANENUM_ACCEPT_TIMEOUT<br>Timeout in state LTSSM_CONFIGURATION_LANENUM_ACCEPT                                                                                 | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_LANENUM_WAIT_TIMEOUT<br>Timeout in state LTSSM_CONFIGURATION_LANENUM_WAIT                                                                                     | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_COMPLETE_TIMEOUT<br>Timeout in state LTSSM_CONFIGURATION_COMPLETE                                                                                             | >=2.1               |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_IDLE_TIMEOUT<br>Timeout in state LTSSM_CONFIGURATION_IDLE                                                                                                     | <=2.1               |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRLOCK_TIMEOUT<br>Timeout in state LTSSM_RECOVERY_RCVRLOCK                                                                                                       | All                 |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRCFG_TIMEOUT<br>Timeout in state LTSSM_RECOVERY_RCVRCFG                                                                                                         | All                 |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_IDLE_TIMEOUT<br>Timeout in state LTSSM_RECOVERY_IDLE                                                                                                               | All                 |
| MSGCODE_PCIE_SVC_PHY_WRONG_LINK_WIDTH<br>Negotiated link width does not match expected link width.                                                                                               | All                 |
| MSGCODE_PCIE_SVC_PHY_RESERVED_SPEED_BIT0<br>SetSupportedSpeeds task sets rate bits in Tx TS OS. rate[0] is reserved but may be set using this task.<br>Msg issued to prevent unintended results. | All                 |
| MSGCODE_PCIE_SVC_PHY_MAX_RX_SKP_INTERVAL<br>ReceivePhy: Exceeded maximum interval before receiving a skp ordered set.                                                                            | All                 |
| MSGCODE_PCIE_SVC_PHY_DATA_OUTSIDE_PACKET<br>Received data outside of packet instead of logical idle.                                                                                             | All                 |
| MSGCODE_PCIE_SVC_PHY_BAD_LINK_NUMBER_POLLING_ACTIVE<br>LTSSM: Incoming training sets have link number set to non-PAD value.                                                                      | All                 |
| MSGCODE_PCIE_SVC_PHY_BAD_LANE_NUMBER_POLLING_ACTIVE<br>. LTSSM: Incoming training sets have lane number set to non-PAD value                                                                     | All                 |
| MSGCODE_PCIE_SVC_PHY_ELASTIC_BUFFER_OVERFLOW<br>Elastic buffer has overflowed.                                                                                                                   | All                 |
| MSGCODE_PCIE_SVC_PHY_ELASTIC_BUFFER_UNDERFLOW                                                                                                                                                    | All                 |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                | <b>Spec Version</b> |
|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Elastic buffer has underflowed                                                                                                            |                     |
| MSGCODE_PCIE_SVC_PHY_BAD_LANE_SKEW<br><br>RxDeskewLanes: Lane skew has exceeded the maximum allowed lane skew.                            | >=2.1               |
| MSGCODE_PCIE_SVC_PHY_TOO_MANY_SKP_SETS<br><br>“Received skip ordered sets on a lane, but expected to receive at fewer skip ordered sets.” | All                 |
| MSGCODE_PCIE_SVC_PHY_TOO_FEW_SKP_SETS<br><br>“Received skip ordered sets on a lane, but expected to receive at more skip ordered sets.”   | All                 |
| MSGCODE_PCIE_SVC_PHY_COMMA_IN_PACKET<br><br>Received unexpected K28.5 character in middle of a packet.                                    | All                 |
| MSGCODE_PCIE_SVC_PHY_CONTROL_CHAR_IN_PACKET<br><br>Received unexpected control character in middle of a packet.                           | All                 |
| MSGCODE_PCIE_SVC_PHY_INFER_ELEC_IDLE_SKIP<br><br>Electrical idle has been inferred on all lanes due to lack of SKP ordered sets.          | >=2.1               |
| MSGCODE_PCIE_SVC_PHY_UNEXPECTED_POLARITY_CHANGE<br><br>Detected rx_polarity go high but SVC hasn't inverted polarity.                     | All                 |
| MSGCODE_PCIE_SVC_PHY_SPEED_CHANGE_NOT_IN_P0P1<br><br>Detected speed change while in powerdown is in state other than P0 or P1.            | All                 |
| MSGCODE_PCIE_SVC_PHY_UNEXPECTED_PHYSTATUS<br><br>Detected phystatus unexpectedly asserted.                                                | All                 |
| MSGCODE_PCIE_SVC_PHY_PHYSTATUS_TIMEOUT<br><br>Timeout waiting for phystatus acknowledgement.                                              | All                 |
| MSGCODE_PCIE_SVC_PHY_VALID_SIGNAL_IN_P1<br><br>Detected a valid signal when attached device is supposed to be in P1 state.                | All                 |
| MSGCODE_PCIE_SVC_PHY_VALID_SIGNAL_DURING_SPEED_CHANGE<br><br>Detected valid signal on one or more lanes during a rate change.             | All                 |
| MSGCODE_PCIE_SVC_PHY_TXDETRX_NOT_IN_P1<br><br>Receiver detect requested when powerdown not in P1 state.                                   | All                 |
| MSGCODE_PCIE_SVC_PHY_DISABLED_TIMEOUT_NO_EIOS<br><br>Timeout in this state. No EIOS was detected.                                         | All                 |
| MSGCODE_PCIE_SVC_PHY_TXDETECTRX_DEASSERTED_BEFORE_PHYSTATUS<br><br>Detected txdetectrx deasserted before phy_status acknowledgement.      | All                 |
| MSGCODE_PCIE_SVC_PHY_SKP_INSERTED_NOT_ON_COMMA                                                                                            | All                 |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                             | <b>Spec Version</b> |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| SKP inserted status received on pipe interface. Data was not K28.5 (Comma).                                                                                            |                     |
| MSGCODE_PCIE_SVC_PHY_SKP_DELETED_NOT_ON_COMMA<br><br>SKP deleted status received on pipe interface. Data was not K28.5 (Comma).                                        | All                 |
| MSGCODE_PCIE_SVC_PHY_NO_LOOPBACK_PATTERN_DETECTED<br><br>Did not detect transmitted loopback pattern on this lane before exiting loopback.                             | All                 |
| MSGCODE_PCIE_SVC_PHY_POLLING_COMPLIANCE_BAD_COMPLIANCE_RECEIVE<br><br>Lane does not support 2.5GT/s. All lanes must advertise support for 2.5GT/s in compliance.       | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_START_NO_EEOS<br><br>LTSSM: Exceeded EEOS interval of 32 without receiving an EEOS.                                              | >=2.0               |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_ACCEPT_UNEXPECTED_TS2<br><br>LTSSM: Received unexpected TS2 training set.                                                        | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_ACCEPT_UNEXPECTED_EIOS<br><br>LTSSM: Received unexpected EIOS.                                                                   | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_ACCEPT_UNEXPECTED_FTS<br><br>LTSSM: Received unexpected FTS.                                                                     | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_ACCEPT_BAD_LINK_NUM<br><br>LTSSM: Detected incoming TS1 sets with link number set to value other than what SVC is configured to. | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_ACCEPT_LANE_NUM_NOT_PAD<br><br>LTSSM: Incoming TS1 sets have lane number set to non-PAD.                                         | All                 |
| MSGCODE_PCIE_SVC_PHY_CONFIG_LINKWIDTH_ACCEPT_BAD_LANENUM<br><br>LTSSM: Incoming TS1 sets have lane number set to wrong value.                                          | All                 |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRLOCK_NO_EEOS<br><br>LTSSM: Exceeded EEOS interval of 32 without receiving an EEOS in this state.                                     | >=2.0               |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_SPEED_ELECTRICAL_IDLE_WITH_NO_EIOS<br><br>LTSSM: Electrical idle detected on this lane without preceding EIOS.                           | All                 |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_SPEED_INFERRRED_ELECTRICAL_IDLE<br><br>LTSSM: Inferred electrical idle on this lane.                                                     | All                 |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRCFG_NO_EEOS<br><br>LTSSM: Exceeded EEOS interval of 32 without receiving an EEOS.                                                    | >=2.0               |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRCFG_INFERRRED_ELECTRICAL_IDLE<br><br>LTSSM: Inferred electrical idle on this lane.                                                   | All                 |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRCFG_BAD_LANE_SKEW                                                                                                                    | All                 |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| Protocol Check Name and Description                                                                                                                          | Spec Version |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| LTSSM: TIMEOUT in this state - Unable to deskew lanes.                                                                                                       |              |
| MSGCODE_PCIE_SVC_PHY_HOT_RESET_NO_TS1_ACKNOWLEDGEMENT<br><br>LTSSM: Hot Reset timer expired without receiving ts1 hot reset handshake.                       | All          |
| MSGCODE_PCIE_SVC_PHY_RX_N_FTS_TIMEOUT<br><br>“N_FTS timeout, SKP OS not received after N_FTS ordered sets.”                                                  | All          |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_COMPLETE_MISMATCHED_N_FTS<br><br>LTSSM: This lane's N_FTS value does not equal previous lane's.                           | >=2.1        |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRCFG_MISMATCHED_N_FTS<br><br>LTSSM: This lane's N_FTS value does not equal previous lane's.                                 | All          |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_COMPLETE_BAD_LANE_SKEW<br><br>LTSSM: Unable to deskew lanes.                                                              | >=2.1        |
| MSGCODE_PCIE_SVC_PHY_LOOPBACK_ACTIVE_MISSING_EIOS<br><br>Detected electrical idle on this lane without first detecting EIOS.                                 | All          |
| MSGCODE_PCIE_SVC_PHY_LOS_FTS_TIMEOUT<br><br>LTSSM: N_FTS timeout on receiver in L0s.                                                                         | All          |
| MSGCODE_PCIE_SVC_PHY_L0_SIGNAL_LOSS<br><br>Electrical idle detected on all lanes without first detecting EIOS.                                               | All          |
| MSGCODE_PCIE_SVC_PHY_CONFIGURATION_COMPLETE_SUPPORTED_SPEEDS_CHANGE<br><br>Detected change of supported_speeds field. This field must not change in state.   | All          |
| MSGCODE_PCIE_SVC_PHY_RECOVERY_RCVRCFG_SUPPORTED_SPEEDS_CHANGE<br><br>Detected change of supported_speeds field. This field must not change in state.         | >=2.1        |
| MSGCODE_PCIE_SVC_PHY_BAD_SPEED_CHANGE_REQUEST<br><br>Speed change was requested but SVC did not advertise support for speeds greater than 2.5GT/s.           | All          |
| MSGCODE_PCIE_SVC_PHY_LOOPBACK_ENTRY_NO_COMPLIANCE_TIMEOUT<br><br>Timeout in this state. No TS1 was detected with loopback enable set.                        | All          |
| MSGCODE_PCIE_SVC_PHY_LOS_BAD_RX_FTS_COUNT<br><br>Lane's FTS transmit count did not equal expected count before exiting LOS.                                  | All          |
| MSGCODE_PCIE_SVC_PHY_VALID_SIGNAL_DURING_PO_POWERDOWN_CHANGE<br><br>Detected valid signal on one or more lanes before SVC has acknowledged transition to P0. | All          |
| MSGCODE_PCIE_SVC_PHY_WRONG_PIPE_CLK_FREQ<br><br>Pipe clock period does not match expected period.                                                            | All          |
| MSGCODE_PCIE_SVC_PHY_LANE_REVERSAL_DETECTED                                                                                                                  | All          |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                                 | <b>Spec Version</b> |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| SVC has detected a lane reversal. Swapping lane assignments.                                                                                                               |                     |
| MSGCODE_PCIEPHY_MISMATCHED_LINK_UPCONFIGURE_BIT<br><br>This lane's link upconfigure bit does not match previous lane's.                                                    | >=2.1               |
| MSGCODE_PCIEPHY_CONFIG_NON_PAD_LINK_LANE_NUM_FOR_NON_LINK_LANE<br><br>LINK/LANE not PAD for lanes >= this lane. This lane is no longer part of the link.                   | All                 |
| MSGCODE_PCIEPHY_CONFIG_NON_PAD_LINK_LANE_NUM_FOR_REVERSED_NON_LINK_LANE<br><br>LINK/LANE not PAD for reversed lanes <= this lane. This lane is no longer part of the link. | All                 |
| MSGCODE_PCIEPHY_RX_START_BLOCK_GEN1_GEN2<br><br>Detected rx_start_block != 0 asserted at speed less than 8G.                                                               | >=3.0               |
| MSGCODE_PCIEPHY_RX_SYNC_HEADER_GEN1_GEN2<br><br>Detected rx_sync_header != 0 at speed less than 8G.                                                                        | >=3.0               |
| MSGCODE_PCIEPHY_RX_DATAK_GEN3<br><br>Detected nonzero value on pipe signal rx_datak at 8G.                                                                                 | >=3.0               |
| MSGCODE_PCIEPHY_8G_RATE_PIPE2<br><br>Rate set to 8G with the pipe spec version set to 2. Please check your configuration.                                                  | >=3.0               |
| MSGCODE_PCIEPHY_BLOCK_ALIGN_CONTROL_GEN1_GEN2<br><br>Detected block_align_control asserted at speed other than 8G.                                                         | >=3.0               |
| MSGCODE_PCIEPHY_RX_STP_TOKEN_BAD_FCRC_GEN3<br><br>Detected bad FCRC on incoming STP token.                                                                                 | >=3.0               |
| MSGCODE_PCIEPHY_RX_STP_TOKEN_BAD_PARITY_GEN3<br><br>Detected bad parity on incoming STP token.                                                                             | >=3.0               |
| MSGCODE_PCIEPHY_RX_SDPTOKEN_BAD_GEN3<br><br>Unexpected data in SDP token.                                                                                                  | >=3.0               |
| MSGCODE_PCIEPHY_RX_TOKEN_MISMATCH_GEN3<br><br>Received token does not map to a recognizable token.                                                                         | >=3.0               |
| MSGCODE_PCIEPHY_RX_NON_IDL_TOKEN_GEN3<br><br>Received non-IDL token outside of packet.                                                                                     | >=3.0               |
| MSGCODE_PCIEPHY_DSP_TS2_EQ_SYM6_BIT7_MUST_BE_1_IN_RCVRCFG<br><br>"rx EQ TS2 symbol6, bit 7 should be 1 for Downstream port in Recovery.RcvrCfg @ 2.5G/5G."                 | >=3.0               |
| MSGCODE_PCIEPHY_USP_TS2_SYM6_MUST_BE_45_NOT_EQ_IN_RCVRY<br><br>rx EQ TS2 symbol6 should be x45 for Upstream port in Recovery @ 2.5G/5G.                                    | >=3.0               |
| MSGCODE_PCIEPHY_RX_INVALID_BLOCK_SIZE_GEN3                                                                                                                                 | >=3.0               |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                                               | <b>Spec Version</b> |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| CheckBlockSize: block size not 16.                                                                                                                                                       |                     |
| MSGCODE_PCIE_SVC_PHY_DUT_ASSERTED_CLKREQ_L1_2_ENTRY<br><br>“LTSSM: CLKREQ# asserted by DUT. SVC is in L1_2_ENTRY, not L1_2_IDLE.”                                                        | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_EQUALIZATION_BYPASSSED<br><br>This lane bypassed Equalization. Received TS2 in this state @ 8G when equalization_complete == 0.                                     | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_EQUALIZATION_PHASE_2_NOT_ENABLED<br><br>This lane executed Equalization Phase despite setting of ENABLE_EQUALIZATION_PHASE_VAR.                                     | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_L0S_TOO_MANY_FTS_BETWEEN_EEOS<br><br>Received more than 32 FTS without detecting an EEOS on this lane.                                                              | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_L0S_TOO_FEW_FTS_BETWEEN_EEOS<br><br>Received less than 32 FTS without detecting an EEOS on this lane.                                                               | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_UNEXPECTED_COEFFICIENTS_VALID<br><br>PIPE signal get_local_preset_coefficients asserted unexpectedly.                                                               | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_COEFFICIENTS_VALID_ASSERTED_TOO_LONG<br><br>PIPE signal local_tx_coefficients_valid asserted for more than 1 clk cycle.                                             | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_RXEQEVAL_DEASSERTED_EARLY<br><br>PIPE signal RxEqEval deasserted before the evaluation was signaled complete.                                                       | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_GET_LOCAL_PRESET_COEFFICIENTS_TIMEOUT<br><br>Timeout for get local preset coefficient request.                                                                      | >=3.0               |
| MSGCODE_PCIE_SVC_SERDES_NEW_MIN_SEEN<br><br>New min half bit period seen - SERDES unlocked.                                                                                              | All                 |
| MSGCODE_PCIE_SVC_SERDES_CLK_SLOWDOWN<br><br>“Violation of 5 same bits period seen or New larger bit seen, but not at least 2x old bit - clock has likely slowed down - SERDES unlocked.” | All                 |
| MSGCODE_PCIE_SVC_SERDES_BYTE_UNLOCK<br><br>“Lost valid signal level on receiver, PLL (clock) recovery reset.”                                                                            | All                 |
| MSGCODE_PCIE_SVC_SERDES_PLL_UNLOCK<br><br>“Lost valid signal level on receiver, PLL (clock) recovery reset.”                                                                             | All                 |
| MSGCODE_PCIE_SVC_SERDES_LOSS_OF_BYTE_SYNC<br><br>“Comma character detected in other than byte 0, bit 0. SERDES unlocked.”                                                                | All                 |
| MSGCODE_PCIE_SVC_ENDEC_ILLEGAL_ENCODING<br><br>“Encoder: Kcode requested, but no legal encoding found!”                                                                                  | All                 |
| MSGCODE_PCIE_SVC_ENDEC_ILLEGAL_DECODE                                                                                                                                                    | All                 |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                             | <b>Spec Version</b> |
|----------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Decoder: Illegal decode received!                                                                                                      |                     |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_N_FTS<br><br>Detected illegal control character in N_FTS field of TS1.                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_POLARITY_INVERSION<br><br>Lane polarity inversion detected on incoming TS1 ordered set.           | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_OVERSIZE_EIOS<br><br>Detected oversize EIOS.                                                      | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_UNDERSIZE_EIOS<br><br>Detected undersize EIOS.                                                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_OVERSIZE_FTS<br><br>Detected oversize FTS.                                                        | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_UNDERSIZE_FTS<br><br>Detected undersize FTS.                                                      | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_OVERSIZE_SKIP<br><br>Detected oversize SKP.                                                       | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_UNDERSIZE_SKIP<br><br>Detected undersize SKP.                                                     | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_LINKNUM<br><br>Detected illegal control character in Linknum field of TS1.                | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_LANENUM<br><br>Detected illegal control character in Lanenum field of TS1.                | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_DATA_RATE<br><br>Detected illegal control character in Data Rate Identifier field of TS1. | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_TRAINING_CTRL<br><br>Detected illegal control character in Training Control field of TS1. | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_LINKNUM<br><br>Detected illegal control character in Linknum field of TS2.                | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_LANENUM<br><br>Detected illegal control character in Lanenum field of TS2.                | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_N_FTS<br><br>Detected illegal control character in N_FTS field of TS2.                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_DATA_RATE                                                                                 | All                 |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                              | <b>Spec Version</b> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Detected illegal control character in Data Rate Identifier field of TS2.                                                                                |                     |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_TRAINING_CTRL<br><br>Detected illegal control character in Training Control field of TS2.                  | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_UNEXPECTED_COMMAS<br><br>Received K28.5 (Comma) in ordered set.                                                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_ORDERED_SET<br><br>Received bad ordered set.                                                                   | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_SKP_INSERT_STATUS<br><br>Received SKP insert status on non-SKP ordered set.                                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_LINK_PAD_LANE_NON_PAD<br><br>Received TS1 with PAD link number and non-PAD lane number.                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_LINK_PAD_LANE_NON_PAD<br><br>Received TS2 with PAD link number and non-PAD lane number.                    | All                 |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_SKIP_SIZE_8G<br><br>“Invalid SKP ordered set length. Valid lengths are 8,12,16,20 and 24.”                     | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS1_SYMBOL_14_15_DC_BALANCE_REDUCE_ONES<br><br>“Expected TS1 symbols 14 and 15 = {8'h20, 8'h08} for dc balance.”   | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS1_SYMBOL_14_15_DC_BALANCE_REDUCE_ZEROES<br><br>“Expected TS1 symbols 14 and 15 = {8'hdf, 8'hf7} for dc balance.” | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS1_SYMBOL_15_DC_BALANCE_REDUCE_ONES<br><br>Expected TS1 symbol 15 = 8'h08 for dc balance.                         | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS1_SYMBOL_15_DC_BALANCE_REDUCE_ZEROES<br><br>Expected TS1 symbol 15 = 8'hf7 for dc balance.                       | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_SYMBOL_15_DC_BALANCE_BYTE14<br><br>Expected TS1 symbol 14 = 8'h4a for dc balance.                          | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_IDENTIFIER_BYTE14<br><br>Bad TS1 identifier on byte 14.                                                    | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS1_IDENTIFIER_BYTE15<br><br>Bad TS1 identifier on byte 15.                                                    | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS2_SYMBOL_14_15_DC_BALANCE_REDUCE_ONES                                                                            | >=3.0               |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                         | <b>Spec Version</b> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| “Expected TS2 symbols 14 and 15 = {8'h20, 8'h08} for dc balance.”                                                                                                  |                     |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS2_SYMBOL_14_15_DC_BALANCE_REDUCE_Z_ER0ES<br><br>“Expected TS2 symbols 14 and 15 = {8'hdf, 8'hf7} for dc balance.”           | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS2_SYMBOL_15_DC_BALANCE_REDUCE_ONES<br><br>Expected TS2 symbol 15 = 8'h08 for dc balance.                                    | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_TS2_SYMBOL_15_DC_BALANCE_REDUCE_ZERO_ES<br><br>Expected TS2 symbol 15 = 8'hf7 for dc balance.                                 | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_SYMBOL_15_DC_BALANCE_BYTE14<br><br>Expected TS2 symbol 14 = 8'h45 for dc balance.                                     | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_IDENTIFIER_BYTE14<br><br>Bad TS2 identifier on byte 14.                                                               | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_TS2_IDENTIFIER_BYTE15<br><br>Bad TS2 identifier on byte 15.                                                               | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_INVALID_BLOCK<br><br>Received invalid ordered set block.                                                                      | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_EIOS_5G_2_NOT_RECEIVED<br><br>SVC Did not receive 2 back to back EIOS from DUT at 5G. Only received 1 EIOS.                   | >=2.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_SKP_8G_SCRAMBLER_VALUE<br><br>The LFSR value contained in the SKP ordered set does not match the receive scrambler value. | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_SKP_8G_PARITY<br><br>SKIP ordered set parity does not match expected value.                                               | >=3.0               |
| MSGCODE_PCIE_SVC_PCS_INVALID_SYNC_HEADER<br><br>ReceivePMA: Invalid sync hdr detected.                                                                             | >=3.0               |
| MSGCODE_PCIE_SVC_PCS_SKP_END_NOT_DETECTED<br><br>SKP-END was not detected before byte 20.                                                                          | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_RX_SKP_NOT_ALL_LANES_8G<br><br>Detected 8G SKP on at least 1 lane but not all.                                                                | >=3.0               |
| MSGCODE_PCIE_SVC_PHY_RX_SKP_LEN_ALL_LANES_8G<br><br>Detected 8G SKPs with different lengths.                                                                       | >=3.0               |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_SKP_MISSING_END_8G                                                                                                            | >=3.0               |

**Table B-1 Phy Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                    | <b>Spec Version</b> |
|-------------------------------------------------------------------------------------------------------------------------------|---------------------|
| "Received SKP did not have SKP End indication on byte 4, 8, 12, 16 or 20."                                                    |                     |
| MSGCODE_PCIE_SVC_ORDERED_SET_CHECKER_BAD_SKP_8G<br><br>Received start of next training set before previous SKP has completed. | >=3.0               |

**Table B-2 Data Layer protocol compliance checks**

| <b>Protocol Check Name and Description</b>                                                                                             | <b>Spec Version</b> |
|----------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| MSGCODE_PCIE_SVC_DL_RECEIVE_TLP_LCRC<br><br>ProcessReceivedTLP: Received TLP with bad LCRC                                             | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVE_ILLEGAL_SEQ_NUM<br><br>ProcessReceivedTLP: Received TLP with invalid sequence number.                      | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVE_NULLIFIED_TLP<br><br>ProcessReceivedTLP: Received nullified TLP.                                           | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVE_NULLIFIED_TLP_LCRC<br><br>ProcessReceivedTLP: Received TLP with EDB delimiter and non inverted or bad LCRC | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVE_DUPLICATE_SEQ_NUM<br><br>ProcessReceivedTLP: Received duplicate TLP.                                       | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVE_DLLP_CRC<br><br>ProcessReceivedDLLP: Received DLLP crc error.                                              | All                 |
| MSGCODE_PCIE_SVC_DL_REPLAY_TIMER_TIMEOUT<br><br>UpdateReplayTimer: Replay timer timed out.                                             | All                 |
| MSGCODE_PCIE_SVC_DL_REPLAY_LATE_TIMEOUT<br><br>CheckAttachedTimers: Replay received late.                                              | All                 |
| MSGCODE_PCIE_SVC_DL_REPLAY_EARLY_TIMEOUT<br><br>"ProcessReceivedDLLP: Retry rcvd too early, attached replay timeout "                  | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_ACK_EXP_REPLY_TIMEOUT<br><br>"ProcessReceivedDLLP: EI - Rcvd ACK, replay timeout was expected."           | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_NAK_EXP_REPLY_TIMEOUT<br><br>ProcessReceivedDLLP: EI - Received NAK when a replay timeout was expected.   | All                 |
| MSGCODE_PCIE_SVC_DL_RETRY_BUFFER_FULL_BYTES<br><br>GetNextTLP: Retry buffer full. consumed bytes > MAX_NUM_RETRY_BUFFER_DWORDS.        | All                 |
| MSGCODE_PCIE_SVC_DL_RETRY_BUFFER_FULL_PKTS<br><br>GetNextTLP: Retry buffer full. Num Pkts exceeded MAX_NUM_RETRY_BUFFER_PKTS.          | All                 |

**Table B-2 Data Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                                                       | <b>Spec Version</b> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| MSGCODE_PCIE_SVC_DL_RECEIVED_DUPLICATE_ACK<br><br>ProcessReceivedDLLP: Received duplicate ACK.                                                                                                   | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_UNEXPECTED_NAK<br><br>ProcessReceivedDLLP: Received Unexpected NAK.                                                                                                 | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_UNEXPECTED_NAK_ACK<br><br>ProcessReceivedDLLP: Received unexpected NAK which ACK'd some packets.                                                                    | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_NAK_DURING_REPLAY<br><br>"ProcessReceivedDLLP: EI - Received NAK as expected, but replay already in progress."                                                      | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_MULT_NAK_DURING_REPLAY<br><br>"ProcessReceivedDLLP: Received more NAK during replay, expected 1."                                                                   | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_ACK_EXP_NAK<br><br>ProcessReceivedDLLP: Received ACK when NAK expected.                                                                                             | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_ACK_PROTOCOL_VIOL<br><br>"ProcessReceivedDLLP: Rcvd ACK with wrong sequence number, protocol violation (((next_transmit_seq - 1) - acknak_seq_num) % 4096) > 2048." | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_ACK_SEQ_NUM_NOT_FOUND<br><br>PurgeRetryBuffer: Retry buffer is empty. seq num not found in retry buffer.                                                            | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_NAK_PROTOCOL_VIOL<br><br>ProcessReceivedDLLP: Received NAK with protocol violation (((next_transmit_seq - 1) - acknak_seq_num) % 4096) > 2048).                     | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_NAK_EXP_ACK<br><br>PurgeRetryBuffer: EI - Purged packet from retry buffer. NAK not received as expected.                                                            | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVED_NAK_WRONG_SEQ_NUM<br><br>ProcessReceivedDLLP: Received NAK for wrong TLP. Packet was not sent with EI.                                                              | All                 |
| MSGCODE_PCIE_SVC_DL_ACKNAK_LATENCY_EARLY_TIMEOUT<br><br>ProcessReceivedDLLP: ACK rcvd early.                                                                                                     | All                 |
| MSGCODE_PCIE_SVC_DL_ACKNAK_LATENCY_LATE_TIMEOUT<br><br>CheckAttachedTimers: ACK/NAK received late.                                                                                               | All                 |
| MSGCODE_PCIE_SVC_DL_UPDATEFC_CREDIT_TIMEOUT<br><br>TransmitPhy: No VC/FC type Update credits were received within period specified.                                                              | All                 |
| MSGCODE_PCIE_SVC_DL_INITFC_CREDIT_TIMEOUT<br><br>TransmitPhy: All 3 VC InitFC credit types were not received within specified period.                                                            | All                 |
| MSGCODE_PCIE_SVC_DL_RECEIVE_TLP_BEFORE_INITFC1<br><br>ReceiveTLP: Received TLP on VC before all 3 InitFC1s(P/NP/CPL). FC_INIT is not yet finished.                                               | All                 |

**Table B-2 Data Layer protocol compliance checks (Continued)**

| Protocol Check Name and Description                                                                                                        | Spec Version |
|--------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| MSGCODE_PCIE SVC_DL RECEIVE_TLP BEFORE_INITFC2<br><br>ReceiveTLP: Received TLP on VC before InitFC2. An InitFC2 is recommended before TLP. | All          |
| MSGCODE_PCIE SVC_DL RECEIVED_DLLP_UNKNOWN_TYPE<br><br>ProcessReceivedDLLP: Received DLLP with unknown type.                                | All          |
| MSGCODE_PCIE SVC_DL ACK_NAK_RSVD_FIELD_NON_ZERO<br><br>CheckDLLPRsvdFields: Received Ack/Nak DLLP with reserved field.                     | All          |
| MSGCODE_PCIE SVC_DL_FC_RSVD_FIELD_NON_ZERO<br><br>CheckDLLPRsvdFields: Received InitFC with reserved field != 0.                           | All          |
| MSGCODE_PCIE SVC_DL_PM_RSVD_FIELD_NON_ZERO<br><br>CheckDLLPRsvdFields: Received PM DLLP with reserved field !=0.                           | All          |
| MSGCODE_PCIE SVC_DL_RETRY_WRONG_EI_CODE<br><br>PurgeRetryBuffer: EI - Retry Buffer packet has wrong EI_CODE.                               | All          |
| MSGCODE_PCIE SVC_DL_RETRY_WRONG_SEQ_NUM<br><br>ProcessReceivedTLP: EI - Expected retry but received retry with wrong seq num.              | All          |
| MSGCODE_PCIE SVC_DL_IDLE_STARTED_WRONG_LANE<br><br>ReceivePhy: Idle started on wrong lane.Not implemented.                                 | All          |
| MSGCODE_PCIE SVC_DL_IDLE_RECEIVED_IN_MIDDLE_OF_PACKET<br><br>ReceivePhy: Received IDLE in middle of a packet.                              | All          |
| MSGCODE_PCIE SVC_DL_2_STP_RECEIVED_IN_1_SYMBOL_TIME<br><br>"ReceivePhy: Received 2 STPs per symbol time, 2nd tlp started wrong lane.""     | All          |
| MSGCODE_PCIE SVC_DL_STP_RECEIVED_MISSING_END_EDB<br><br>ReceivePhy: Received STP before previous packet's END/EDB.                         | All          |
| MSGCODE_PCIE SVC_DL_STP_NOT_ON_LANE0_AFTER_IDLE<br><br>ReceivePhy: Received TLP not aligned to lane 0.                                     | All          |
| MSGCODE_PCIE SVC_DL_STP_WRONG_LANE<br><br>ReceivePhy: Received STP on lane which is not modulo 4.                                          | All          |
| MSGCODE_PCIE SVC_DL_2_SDP_RECEIVED_IN_1_SYMBOL_TIME<br><br>ReceivePhy: Received 2 SDPs per symbol time.                                    | All          |
| MSGCODE_PCIE SVC_DL_SDP_RECEIVED_MISSING_END_EDB<br><br>ReceivePhy: Received SDP before previous packet's END/EDB.                         | All          |
| MSGCODE_PCIE SVC_DL_SDP_NOT_ON_LANE0_AFTER_IDLE<br><br>ReceivePhy: Received DLLP SDP on lane other than 0. Expected SDP on lane 0.         | All          |
| MSGCODE_PCIE SVC_DL_SDP_WRONG_LANE                                                                                                         | All          |

**Table B-2 Data Layer protocol compliance checks (Continued)**

| Protocol Check Name and Description                                                                                                           | Spec Version |
|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| ReceivePhy: Received SDP on lane which is not modulo 4.                                                                                       |              |
| MSGCODE_PCIE_SVC_DL_PACKET_EXCEEDED_CONTAINER_SIZE<br>ReceivePhy: Packet exceeded SVC container size.                                         | All          |
| MSGCODE_PCIE_SVC_DL_DATA_RECEIVED_OUTSIDE_PACKET<br>ReceivePhy: Data received outside packet.                                                 | All          |
| MSGCODE_PCIE_SVC_DL_DLLP_SIZE_NOT_8_BYTES<br>ReceivePhy: Received DLLP with length which is not 8 bytes.                                      | All          |
| MSGCODE_PCIE_SVC_DL_END_WRONG_LANE<br>ReceivePhy: Received END in wrong lane.                                                                 | All          |
| MSGCODE_PCIE_SVC_DL_END_OUTSIDE_PACKET<br>ReceivePhy: Received END outside packet.                                                            | All          |
| MSGCODE_PCIE_SVC_DL_NULLIFIED_DLLP RECEIVED<br>ReceivePhy: Received nullified DLLP. This is illegal in PCIE.                                  | All          |
| MSGCODE_PCIE_SVC_DL_EDB_WRONG_LANE<br>ReceivePhy: Received EDB on wrong.                                                                      | All          |
| MSGCODE_PCIE_SVC_DL_EDB_OUTSIDE_PACKET<br>ReceivePhy: Received EDB outside packet.                                                            | All          |
| MSGCODE_PCIE_SVC_DL_DLLP_EXCEEDED_8_BYTES<br>ReceivePhy: DLLP exceeded 8 bytes.                                                               | All          |
| MSGCODE_PCIE_SVC_DL_EDB_OUTSIDE_PACKET_8G<br>ReceivePhy: Received errant EDB token on wrong lane or LCRC from previous nullified TLP was bad. | >=3.0        |
| MSGCODE_PCIE_SVC_DL_EDB_TOKEN_MISSING_8G<br>ReceivePhy: Expected to Receive Phy EDB indication on particular lane.                            | >=3.0        |
| MSGCODE_PCIE_SVC_DL RECEIVED_TLP_FIFO_FULL<br>ProcessReceivedTLP: TLP receive fifo full.                                                      | All          |
| MSGCODE_PCIE_SVC_DL RECEIVED_DLLP_FIFO_FULL<br>ProcessReceivedDLLP: DLLP received fifo full. Packet will not be queued.                       | All          |
| MSGCODE_PCIE_SVC_DL_SENT_DLLP_FIFO_FULL<br>QueueSentDLLP: Sent DLLP fifo full. Packet will not be placed on the sent packet queue.            | All          |
| MSGCODE_PCIE_SVC_DL_CREDIT_SENT_VC_UNINITIALIZED<br>TransmitCredits: Attempting to send credit on uninitialized VC.                           | All          |
| MSGCODE_PCIE_SVC_DL_CREDIT_DUPL_INIT                                                                                                          | All          |

**Table B-2 Data Layer protocol compliance checks (Continued)**

| Protocol Check Name and Description                                                                                                                          | Spec Version |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| TransmitCredits: Init credit already received for VC/fc type.                                                                                                |              |
| MSGCODE_PCIE SVC_DL RECEIVED_PM_ENTER_L1_DOWNSTREAM<br>"ProcessReceivedDLLP: PM_ENTER_L1 DLLP can only flow upstream, toward root complex."                  | All          |
| MSGCODE_PCIE SVC_DL RECEIVED_PM_ENTER_L23_DOWNSTREAM<br>"ProcessReceivedDLLP: PM_ENTER_L23 DLLP can only flow upstream, toward root complex."                | All          |
| MSGCODE_PCIE SVC_DL RECEIVED_PM_ASPM_REQUEST_L1_DOWNSTREAM<br>"ProcessReceivedDLLP: PM_ACTIVE_STATE_REQUEST_L1 can only flow upstream, toward root complex." | All          |
| MSGCODE_PCIE SVC_DL RECEIVED_PM_REQUEST_ACK_UPSTREAM<br>"ProcessReceivedDLLP: PM_REQUEST_ACK can only flow downstream, away from root complex."              | All          |
| MSGCODE_PCIE SVC_DL RECEIVED_PM_IPG<br>ProcessReceivedDLLP: PM_ENTER_L1 DLLP received with IPG > 4.                                                          | All          |
| MSGCODE_PCIE SVC_DL ASPM_L0S_TIMEOUT<br>CheckL0sIdle: ASPM L0s. Phy did not report TX L0s status before timeout occurred.                                    | All          |
| MSGCODE_PCIE SVC_DL ASPM_L1_HANDSHAKE_TIMEOUT<br>ASPMHandshakeSm: ASPM L1 Handshake timeout. SVC Phy not in L1 before timeout occurred.                      | All          |
| MSGCODE_PCIE SVC_DL ASPM_L1_1_HANDSHAKE_TIMEOUT<br>ASPMHandshakeSm: ASPM L1_1 Handshake timeout. SVC Phy not in L1_1 before timeout occurred.                | All          |
| MSGCODE_PCIE SVC_DL ASPM_L1_2_HANDSHAKE_TIMEOUT<br>ASPMHandshakeSm: ASPM L1_2 Handshake timeout. SVC Phy not in L1_2 before timeout occurred.                | All          |
| MSGCODE_PCIE SVC_DL PM_L1_HANDSHAKE_TIMEOUT<br>PMHandshakeSm: PM L1 Handshake timeout. SVC Phy not in L1 before timeout occurred.                            | All          |
| MSGCODE_PCIE SVC_DL PM_L1_1_HANDSHAKE_TIMEOUT<br>PMHandshakeSm: PM L1_1 Handshake timeout. SVC Phy not in L1_1 before timeout occurred.                      | All          |
| MSGCODE_PCIE SVC_DL PM_L1_2_HANDSHAKE_TIMEOUT<br>PMHandshakeSm: PM L1_2 Handshake timeout. SVC Phy not in L1_2 before timeout occurred.                      | All          |
| MSGCODE_PCIE SVC_DL PM_L23_HANDSHAKE_TIMEOUT<br>PMHandshakeSm: PM L23 Handshake timeout. SVC Phy not in L23 before timeout occurred.                         | All          |

**Table B-3 Application Layer protocol compliance checks**

| <b>Protocol Check Name and Description</b>                                                                                                                     | <b>Spec Version</b> |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| MSGCODE_PCIE_SVC_APPL_TARGET_INVALID_ID<br><br>ReceivePacket: Bad appl_id received by application.                                                             | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNSUPPORTED_REQ<br><br>ReceivePacket: Received TLP with unsupported type field.                                                   | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNSUPPORTED_MEM_REQ<br><br>HandleMemReq: Received unsupported memory request. SVC will return UR.                                 | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNINITIALIZED_MEM_DATA<br><br>HandleMemReq: MemRd accessed uninitialized memory data.                                             | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_HDR_WORD_SIZE_MISMATCH<br><br>"HandleMemReq: Request has 4 dwords, but addr[63:32] == 0. Request is not a 64-bit memory request." | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_DEPRECATED_CFG_REQ<br><br>HandleCfgReq: Received unsupported (deprecated) Cfg request.                                            | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_CFG_TC<br><br>HandleCfgReq: Received CFG with Illegal Traffic Class - expected 0.                                         | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_CFG_DATA_LEN<br><br>HandleCfgReq: Received CFG with illegal data length - expected 1.                                     | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_CFG_AT<br><br>HandleCfgReq: Received CFG with AT != 2'b00.                                                                | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_CFG_LAST_BE<br><br>HandleCfgReq: Received CFG with last DW byte enable != 0.                                              | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_IO_TC<br><br>HandleIOReq: Received IO with illegal Traffic Class - expected 0.                                            | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_IO_DATA_LEN<br><br>HandleIOReq: Received IO with illegal data length - expected 1.                                        | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_IO_AT<br><br>HandleIOReq: Received IO with AT != 2'b00.                                                                   | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_IO_LAST_BE<br><br>HandleIOReq: Received IO with unexpected last DW byte enable != 0.                                      | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNSUPPORTED_VENDOR0_MSG<br><br>"HandleMsgReq: Received unsupported Vendor Defined 0 message, this is a UR."                       | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNKNOWN_MSG_CODE<br><br>HandleMsgReq: Received MSG with unknown message code.                                                     | All                 |

**Table B-3 Application Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                                    | <b>Spec Version</b> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| MSGCODE_PCIE_SVC_APPL_TARGET_NONZERO_LAST_BE<br><br>ByteEnableCheck: Last DW Byte Enable != 0 for length=1.                                                                   | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ZERO_FIRST_BE<br><br>ByteEnableCheck: 1st DW Byte Enable == 0 for length > 1.                                                                    | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ZERO_LAST_BE<br><br>ByteEnableCheck: Last DW Byte Enable == 0 for length > 1.                                                                    | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_BAD_FIRST_BE_NCB_NQA<br><br>ByteEnableCheck: Bad first DW Byte Enable - non-contiguous bits -- non-QW-aligned.                                   | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_BAD_FIRST_BE_NCN_NQA<br><br>ByteEnableCheck: Bad first DW Byte Enable - non-contiguous with next dword -- non-QW-aligned.                        | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_BAD_LAST_BE_NCB_NQA<br><br>ByteEnableCheck: Bad last DW Byte Enable - non-contiguous bits -- non-QW-aligned.                                     | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_BAD_LAST_BE_NCP_NQA<br><br>ByteEnableCheck: Bad last DW Byte Enable - non-contiguous with prev dword -- non-QW-aligned.                          | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_BAD_FIRST_BE_NCB<br><br>ByteEnableCheck: Bad first DW Byte Enable - non-contiguous bits.                                                         | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_BAD_LAST_BE_NCB<br><br>ByteEnableCheck: Bad last DW Byte Enable - non-contiguous bits.                                                           | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_POISON_CFG_REQ<br><br>HandleCfgReq: Received CFG with Poison bit set. SVC will return UR.                                                        | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_INVALID_64_BIT_ADDR<br><br>HandleMemReq: Received Unsupported 64-bit read request. SVC will return Completer Abort status                        | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_POISON_IO_REQ<br><br>HandleCfgReq: Received IOWr with Poison bit set. SVC will return UR.                                                        | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_MSG_DATA_LEN<br><br>HandleMsgReq: Received MSG with reserved data length field !=0.                                                      | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_MSG_INTX_ON_DOWNSTREAM_PORT<br><br>HandleMsgReq: Received INTx on downstream port.                                                               | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_MSG_AT<br><br>HandleMsgReq: Recevied MSG TLP with AT != 2'b00.                                                                           | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_ILLEGAL_MSG_RSVD_HDR<br><br>"HandleMsgReq: Reserved vendor defined msg has routing by addr (illegal) [2.2.8.6], hdr[2] == 0, or<br>hdr[2] == 0." | All                 |

**Table B-3 Application Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                                          | <b>Spec Version</b> |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| MSGCODE_PCIE_SVC_APPL_TARGET_UNEXPECTED_TYPE_1_CFG<br><br>HandleCfgReq: Received unexpected Type 1 Cfg request. SVC will return UR.                                                 | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNSUPPORTED_ATOMIC_OP_REQ<br><br>HandleMemReq: Received illegal atomic-op request. Atomic Ops not supported in PCIE version < 2.1. Svc will return UR. | <=2.0               |
| MSGCODE_PCIE_SVC_APPL_TARGET_CFG_INVALID_FUNC_NUM<br><br>HandleCfgReq: Received CfgRd with Invalid Function Number. SVC will return UR.                                             | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_CFG_INTERNAL_PROBLEM<br><br>HandleCfgReq: Received CfgRd with invalid function. Was SetCompleterID(0x%0x) set for this target? (returning CA)          | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNSUPPORTED_VENDOR1_MSG<br><br>HandleMsgReq: Received unsupported Vendor Defined 1 message.                                                            | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_POISON_MEM_WR<br><br>HandleMemReq: Poison bit set on received MemWr. SVC will return UR.                                                               | All                 |
| MSGCODE_PCIE_SVC_APPL_TARGET_UNSUPPORTED_PREFIX<br><br>Unsupported TLP prefix type received. Discarding malformed TLP.                                                              | >=2.1               |
| MSGCODE_PCIE_SVC_APPL_TARGET_MAX_SUPPORTED_PREFIX<br><br>TLP contains too many end-end TLP prefixes.                                                                                | >=2.1               |
| MSGCODE_PCIE_SVC_APPL_DRIVER_COMMAND_TIMEOUT<br><br>CheckForCommandTimeout: Request with a particular tag has timed out.                                                            | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_INVALID_MEM_DATA<br><br>CheckReceivedData: Data uninitialized at shadow addr.                                                                          | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_DATA_MISMATCH<br><br>CheckReceivedData: Data mismatch at shadow addr.                                                                                  | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_LOW_BYTE_COUNT<br><br>Byte count field is less than expected value. Discarding completion.                                                             | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_HIGH_BYTE_COUNT<br><br>Byte count field is greater than expected value. Discarding completion.                                                         | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_MISSING_GOOD_STATUS<br><br>ProcessReceivedPacket: Received completion with unexpected status.                                                          | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_UNEXPECTED_GOOD_STATUS<br><br>"ProcessReceivedPacket: Received completion status of GOOD, but expected status other than GOOD."                        | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_BAD_RECLEN<br><br>CheckReceivedData: TLP received length != expected length in bytes                                                                   | All                 |

**Table B-3 Application Layer protocol compliance checks (Continued)**

| <b>Protocol Check Name and Description</b>                                                                                                                     | <b>Spec Version</b> |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| MSGCODE_PCIE_SVC_APPL_DRIVER_SPURIOUS_CPL<br><br>Spurious completion received.                                                                                 | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_MISMATCHED_CPL_ATTR<br><br>Completion attr does not match request attr. Discarding completion                                     | All                 |
| MSGCODE_PCIE_SVC_APPL_DRIVER_MISMATCHED_CPL_TC<br><br>Completion TC does not match request TC. Discarding completion                                           | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_UNINITIALIZED_MEM_DATA<br><br>CheckReceivedData: Data uninitialized at shadow addr.                                            | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_DATA_MISMATCH<br><br>CheckReceivedData: Data mismatch at shadow addr.                                                          | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_BAD_RECV_LEN<br><br>CheckReceivedData: Bad received length != expected length in bytes.                                        | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_BAD_RECV_BYTE_CNT<br><br>HandleMemCpl: Received byte_cnt != expected byte_cnt.                                                 | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_COMMAND_TIMEOUT<br><br>ReceivePacket: Request has timed out waiting for Cpl.                                                   | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_SPURIUS_CPL<br><br>HandleMemCpl: Spurious Cpl packet received. Potentially late Cpl for timed-out request.                     | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_TIMEOUT_BEYOND_RETRY_COUNT<br><br>"ReceivePacket: Timed out request, retry_count is beyond max retry count - failing request." | All                 |
| MSGCODE_PCIE_SVC_APPL_REQUESTER_TIMEOUT_MISSING_CPL<br><br>MarkTimedOutRequests: Timeouts caused some missing Cpl.                                             | All                 |



# C Implemented ECNs

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

**Table C-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    |



# D SVC to SVT Migration

From N-2017.09 release onwards, the SVC package will be deprecated as a standalone release package and will be available as part of SVT installation.

This chapter describes the steps to migrate from SVC package to use SVT installation.

- ❖ [SVC Verilog to SVT](#)
- ❖ [SVC UVM to SVT](#)

## D.1 SVC Verilog to SVT

The following example illustrates the steps to port the Verilog example (test\_basic) from the SVC install package to SVT install package. The same procedure applies for porting your own tests.

### Step 1: Update the SVC Version

Get the latest version of SVT including the SVC module. Contact the PCIe VIP support team to get the latest compatible release.

### Step 2: Install the SVT Package

Installation steps for SVT package is similar to the SVC flow.

```
% setenv DESIGNWARE_HOME `pwd`  
% vip_PCIE_SVT_<version>.run
```

The following command will install the UVM unified example in your design directory. For more details, see “Installation and Setup” in the *VC Verification IP PCI Express UVM User Guide*.

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -path design_dir -e pcie_svt/  
tb_PCIE_SVT_UVM_unified_vip_sys -svtb  
  
% gmake base_pipe_test USE_SIMULATOR=vcsvlog
```

### Step 3: Preparing for Migration

Create a directory in your SVT area to migrate the selected test.

```
% mkdir $DESIGNWARE_HOME/design_dir/examples/sverilog/pcie_svt/svc2svt  
% cd $DESIGNWARE_HOME/design_dir/examples/sverilog/pcie_svt/svc2svt
```

Copy relevant files from SVC to *svc2svt* (migration directory).

```
% cp <svc install dir>/Example/test_basic.fl .
% cp <svc install dir>/Example/test_basic.sv .
% cp <svc install dir>/Example/config_root2endpoint.v .
```

#### Step 4: Flat Includes

[Table D-1](#) shows the directory structure of SVC and SVT packages. Update your source files (not the VIP included files) to use a flat hierarchy. It is suggested to wrap with the `PCIESVC_FLAT_INCLUDES` define.

**Table D-1 Directory Structure**

| SVC Directory Structure                                                                                                                                                                                                                                                                                                                                                          | SVT Directory Structure                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <install_dir>         --- PCIE         --- Verilog           --- Application_PCIE/           --- Doc/           --- Example/           --- Include/           --- InstantiationModels/           --- LinkLayer/           --- PhyLayer/           --- PhyLayer_8g/           --- PhyLayer_16g/           --- PhyLayer_MPCIE/           --- TransactionLayer/           --- Util/ | \$DESIGNWARE_HOME         --- <design_dir>         --- src           --- verilog           --- vcs           --- mti           --- ncv         --- sverilog           --- vcs           --- mti           --- ncv |

For example, update the *config\_root2endpoint.v* file as shown below:

```
`ifndef PCIESVC_FLAT_INCLUDES
  `include "Util/svc_util_parms.v"
`else
  `include "svc_util_parms.v"
`endif
```

Similarly, update the *test\_basic.sv* file.

```
`ifndef PCIESVC_FLAT_INCLUDES
  `include "Util/svc_util_parms.v"
  `include "Util/svc_util_macros.v"
  `include "Util/svc_util_tasks.v"
  `include "Util/svc_plusarg_tasks.v"
  `include "Application_PCIE/pciesvc_application_parms.v"
  `include "LinkLayer/pciesvc_ll_parms.v"
  `include "LinkLayer/pciesvc_ll_msgcodes.v"
  `include "PhyLayer/pciesvc_phylayer_msgcodes.v"
  `include "Include/pciesvc_parms.v"
  `include "Include/pciesvc_tlp_parms.v"
  `include "Include/pciesvc_tlp_tasks.v"
`else
```

```
`include "svc_util_parms.v"
`include "svc_util_macros.v"
`include "svc_util_tasks.v"
`include "svc_plusarg_tasks.v"
`include "pciesvc_application_parms.v"
`include "pciesvc_ll_parms.v"
`include "pciesvc_ll_msgcodes.v"
`include "pciesvc_phylayer_msgcodes.v"
`include "pciesvc_parms.v"
`include "pciesvc_tlp_parms.v"
`include "pciesvc_tlp_tasks.v"
`endif
```

## Step 5: Update the Compile Script

Update the compile script with the changes that are applicable to your simulator.

For example, VCS simulator is shown for illustration.

- ❖ Flat Includes

The flat includes can be added either as a command-line option or in the *test\_basic.fl*.

```
+define+PCIESVC_FLAT_INCLUDES
```

- ❖ Update the Library Directory

VCS uses the '-y directory' to specify where to look for source files for module definitions.

```
-y ../Application_PCIE
-y ../TransactionLayer
-y ../LinkLayer
-y ../PhyLayer
-y ../Util
-y ../Include
-y ../InstantiationModels
```

These must be converted to the flat includes:

```
-y ${DESIGNWARE_HOME}/design_dir/src/verilog/vcs
-y ${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs
```

- ❖ Update the Include Directory

The *test\_basic.fl* or command-line option will notify VCS to look for files that have been `included:

```
+incdir+${DESIGNWARE_HOME}/design_dir/src/verilog/vcs
+incdir+${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs
```

## Step 6: Compile and Run

For SVC package, you must generate the *msglog.o* for the SVC based message handler. The SVT example includes a *prescript* file that is executed by the examples to compile *msglog.c* and generate *msglog.o* and the *pli.tab* file.

For example,

```
% vcs -sverilog -full64 -debug_acc+pp+dmptf+thread -debug_region=cell+encrypt msglog.o -
P pli.tab \
+define+PCIESVC_MEM_PATH=top.mem0 \
+define+SVC_RANDOM_SEED_SCOPE=top.global_random_seed \
+define+PCIESVC_FLAT_INCLUDES \
+libext+.v+.sv \
+incdir+${DESIGNWARE_HOME}/design_dir/src/verilog/vcs \
```

```
+incdir+${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs \
-y ${DESIGNWARE_HOME}/design_dir/src/verilog/vcs \
-y ${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs \
config_root2endpoint.v \
test_basic.sv \
$DESIGNWARE_HOME/vip/common/latest/C/lib/amd64/VipCommonNtb.so
% simv
```

## D.2 SVC UVM to SVT

The following example illustrates the steps to port the Verilog example (test\_basic) from the SVC install package to SVT install package. The same procedure applies for porting your own tests.

### Step 1: Update the SVC Version

Get the latest version of SVT including the SVC module. Contact the PCIe VIP support team to get the latest compatible release.

### Step 2: Install the SVT Package

Installation steps for SVT package is similar to the SVC flow.

```
% setenv DESIGNWARE_HOME `pwd`  
% vip_PCIE_SVT_<version>.run
```

The following command will install the UVM unified example in your design directory. For more details, see “*Installation and Setup*” in the *VC Verification IP PCI Express UVM User Guide*.

```
% $DESIGNWARE_HOME/bin/dw_vip_setup -path design_dir -e pcie_svt/  
tb_PCIE_SVT_UVM_Unified_VIP_Sys -svtb  
  
% gmake base_pipe_test USE_SIMULATOR=vcsvlog
```

### Step 3: Preparing for Migration

Create a directory in your SVT area to migrate the selected test.

```
% mkdir $DESIGNWARE_HOME/design_dir/examples/sverilog/pcie_svt/svc2svt  
% cd $DESIGNWARE_HOME/design_dir/examples/sverilog/pcie_svt/svc2svt
```

Copy relevant files from SVC to svc2svt (migration directory).

```
% cp <svc install dir>/Example/test_basic_uvm_vcs.f1 .  
% cp <svc install dir>/Example/test_basic_uvm.sv .  
% cp <svc install dir>/Example/uvm_env_root2endpoint.sv .  
% cp <svc install dir>/Example/config_root2endpoint.v .
```

### Step 4: Flat Includes

**Table D-1** shows the directory structure of SVC and SVT packages. Update your source files (not the VIP included files) to use a flat hierarchy. It is suggested to wrap with the PCIESVC\_FLAT\_INCLUDES define.

For example, update the *config\_root2endpoint.v* file as shown below:

```
`ifndef PCIESVC_FLAT_INCLUDES
    `include "Util/svc_util_parms.v"
`else
    `include "svc_util_parms.v"
`endif
```

Similarly, update the *test\_basic.sv* file.

```
`ifndef PCIESVC_FLAT_INCLUDES
`include "Util/svc_util_parms.v"
`else
`include "svc_util_parms.v"
`endif

...
`ifndef PCIESVC_FLAT_INCLUDES
`include "Include/pciesvc_tlp_parms.v"
`else
`include "pciesvc_tlp_parms.v"
`endif

...
`ifndef PCIESVC_FLAT_INCLUDES
`include "Include/pciesvc_tlp_parms.v"
`else
`include "pciesvc_tlp_parms.v"
`endif

...
`ifndef PCIESVC_FLAT_INCLUDES
`include "Include/pciesvc_parms.v"
`include "Include/pciesvc_tlp_parms.v"
`else
`include "pciesvc_parms.v"
`include "pciesvc_tlp_parms.v"
`endif
```

## Step 5: Update the Compile Script

Update the compile script with the changes that are applicable to your simulator.

For example, VCS simulator is shown for illustration.

- ❖ Flat Includes

The flat includes can be added either as a command-line option or in the *test\_basic.fl*.

```
+define+PCIESVC_FLAT_INCLUDES
```

- ❖ Update the Library Directory

VCS uses the '-y directory' to specify where to look for source files for module definitions.

```
-y ../Application_PCIE
-y ../TransactionLayer
-y ../LinkLayer
-y ../PhyLayer
-y ../Util
-y ../Include
-y ../InstantiationModels
```

These must be converted to the flat includes:

```
-y $DESIGNWARE_HOME/design_dir/src/verilog/vcs
-y $DESIGNWARE_HOME/design_dir/src/sverilog/vcs
```

- ❖ Update the Include Directory

The *test\_basic.fl* or command-line option will notify VCS to look for files that have been `included:

```
+incdir+${DESIGNWARE_HOME}/design_dir/src/verilog/vcs
+incdir+${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs
```

## Step 6: Compile and Run

For SVC package, you should generate the *msglog.o* for the SVC based message handler. The SVT example includes a *prescript* file that is executed by the examples to compile *msglog.c* and generate *msglog.o* and the *pli.tab* file.

For example,

```
% vcs -sverilog -full64 -ntb_opts uvm -debug_acc+pp+dmptf+thread -
debug_region=cell+encrypt msglog.o -P pli.tab \
#define+PCIESVC_MEM_PATH=top.mem0 \
#define+SVC_RANDOM_SEED_SCOPE=top.global_random_seed \
#define+PCIESVC_FLAT_INCLUDES \
+libext+.v+.sv \
#define+UVM_DISABLE_AUTO_ITEM_RECORDING \
+define+UVM_PACKER_MAX_BYTES=1500000 \
-timescale=1ns/1fs \
+incdir+${DESIGNWARE_HOME}/design_dir/src/verilog/vcs \
+incdir+${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs \
-y ${DESIGNWARE_HOME}/design_dir/src/verilog/vcs \
-y ${DESIGNWARE_HOME}/design_dir/src/sverilog/vcs \
config_root2endpoint.v \
test_basic_uvm.sv \
$DESIGNWARE_HOME/vip/common/latest/C/lib/amd64/VipCommonNtb.so
% simv
```

# E Reporting Problems

## E.1 Introduction

This chapter outlines the process for working through and reporting 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.

## E.2 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
2. Create a value change dump (VCD) file
3. Generate a log file for the simulation

Providing this information will help ensure accurate diagnosis of the problem.

If the requested information is not sufficient to determine the cause of your issue, the Synopsys Support Center may request a simple testbench demonstrating the issue. This is the most effective way to debug issues, but if an example cannot be provided, Synopsys may request additional information that could include regenerating the log file using different settings.

If your testbench initializes the random seed (see 'srandom()' in the VCS manual) in the host simulator, then a seed that can be used to demonstrate the problem must be included in the testbench or provided as information for executing the testbench.