5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

o0h

04h

08h

och

10h

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAJCAYAAAARml2dAAAAeElEQVQImU3OMQ4BYRRF4c8/Q6ueDaDQKjTTqMxeBPuxBzuQ6KkkCmIJk2hkJCQUnnDam3NyMx9KLDDGEbeEKdZo0McWOewwD7OFPSYJvdDhhQMGCW3UftzRSXh+m0GNR8IJo79hiHOOFZa4oEAXmyxeXFFFcobmDS0YGBHdeNLqAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAJCAYAAAD6reaeAAAATElEQVQImY3KsQ1AUABF0fNFWIDozCBRiAFsILGuCcQoCq3kFxQ/oXC693K5lZhQPNuADQdqyDBiwe7DmpYv/88cHVpUaHAFzOiT8IzKEQeQqbdKOQAAAABJRU5ErkJggg==)

+ + + +

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | | | | | | |  | | | | | | | |  | | | | | | | |  | | | | | | | | |
| 7 |  | 5 | 4 | 3 | 2 |  |  | 7 |  | 5 | 4 | 3 | 2 |  |  | 7 |  | 5 | 4 | 3 | 2 |  |  | 7 |  | 5 | 4 | 3 | 2 | |  |  |
|  | | |  |  | | | | R | R | R | | PASID | | | | | | | | | | | | | | | | | | | | |
|  |  |  | Type | | | | | T 9 | TC | | | T 8 |  | R | | T D | E P | Atr | | R | | Length (0) | | | | | | | | | | |
| Requester ID | | | | | | | | | | | | | | | | Tag | | | | | | | | Message code (0000 0100b) | | | | | | | | |
| Reserved | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |
| Reserved | | | | | | | | | | | | | | | | | | | | | | | | Marker Type (00000b) | | | | |  | W 0 | | R 0 |

Figure 10-17 Stop Marker Message

3

2

A Stop Marker Message is encoded as a Page Request Message that contains a PASID TLP Prefixwith the following exceptions:

• The L,W and R fields contain 1b, 0band 0b respectively.

• The Untranslated Address field and upper bits of the PRG Index field are Reserved.

• The Marker Type field contains 00000b to indicate that this is a Stop Marker Message.

The Execute Requestedand Privileged Mode Requested bits in the PASID TLP Prefixare Reserved.

• The Traffic Class must be 0.

• The Relaxed Orderingattribute bit must be Clear.

• The ID-Based Orderingattribute bit may be Set.

Behavior is undefined if a Stop Marker Message is received and any of the following are true:

• Marker Type not equal to 00000b.

• No PASID TLP Prefixis present.

• The PASID value does not match an outstanding stop request.

• An incomplete Page Request Message for the PASID is outstanding (i.e. for some PRG Index, the most recently received Page Request Message did not have the L bit Set).

**10.4.2 Page Request Group Response Message**

System hardware and/or software communicate with a Function’s page request interface via PRG Response Messages. A PRG Response Message is used by a host to signal the completion of a PRG, or the catastrophic failure of the interface. A single PRG Response Message is issued in response to a PRG, independent of the number of page requests associated with the PRG. There is no mechanism for indicating a partial request completion or partial request failure. If any of the pages associated with a given PRG cannot be satisfied, then the request is considered to have failed and the reason for the failure is supplied in the PRG Response Message. The host has no obligation to partially satisfy a multi-page request. If one of the requested pages cannot be made resident, then the entire request can, but need not, be discarded. That is,

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

the residence of pages that share a PRG with a failed page request, but that are not associated with the failure, is indeterminate from the Function’s perspective.

There are four possible Page Request failures:

1. The requested page is not a valid Untranslated Address.

2. PASID TLP Prefixsupport exists, the Page Request has a PASID TLP Prefix, and either PASID TLP Prefixusage is not enabled for this request, the PASID value is not valid, or the Execute Requested bit is Set when R is Clear.171

3. The requested page does not have the requested access attributes (including Execute permission and/or Privileged Mode access when the Page Request has a PASID TLP Prefix).

4. The system is, for an unspecified reason, unable to respond to the request. This response is terminal (the host may no longer respond to any page requests and may not supply any further replies to the Function until the Function’s page request interface has been reset). For example, a request that violates a Function’s assigned request limit or overflows the RC’s buffering capability may cause this type of failure.

A Function’s response to Page Request failure cases 1, 2, and 3 above is implementation dependent. The failure is not necessarily persistent, that is, a failed request may, in some instances succeed if re-issued. The range of possibilities precludes the precise specification of a generalized failure behavior, though on a per Function basis, the response to a failure will be an implementation dependent behavior.

All responses are sent to their associated Functions via PRG Response Messages. A Function must be capable of sinking multiple consecutive messages without losing any information. To avoid deadlock, a Function must able to process PRG Response Messages for all of the Function's outstanding Page Request Messages without depending on the Function

sending or receiving any other TLP.172 A PRG Response Message is an ID routed PCIe message. The only Page Request Interface specific fields in this message are the Response Code and PRG. All other fields are standard PCIe message

fields. (Note: these messages are routed based on the ID in bytes 8 and 9; with bytes 4 and 5 containing the host’s RID.)

Receipt of a PRG Response Message that contains a PRG Index that is not currently outstanding at a Functionshall result in the UPRGI flag in the [Page Request Extended Capability](#bookmark2) being Set and in the issuance of an Unexpected Response (UR) by the Function containing the [Page Request Extended Capability](#bookmark3). With the exception of setting the UPRGI flag, a

Function treats receipt of an unexpected PRG Index in exactly the same manner that it treats receipt of a standard PCIe read completion for which there is no outstanding request.

00h

04h

08h

0Ch

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| +0 | | | | | | +1 | | | | | | | +2 | | | | | | | | +3 | | |
| 7 6 5 4 | | | | |  |  |  | | --- | --- | --- | | 3 | 2 | 1 | | 0 | 7 6 | | |  |  | | --- | --- | | 5 | 4 3 2 1 | | | | | 0 | 7 6 5 | | | |  |  | | --- | --- | | 4 3 | 2 1 | | | | | 0 | 7 | |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 |
| 0 | 0 | 1 | Type  (10010) | | | T 9 | TC | | T 8 | Attr | R | | T D | E P | Attr | | R | Length (0) | | | | | |
| Requestor ID | | | | | | | | | | | | | Tag | | | | | | | | Message Code (0000 0101b) | | |
| Destination Device ID | | | | | | | | | | | | | Response Code | | | | Reserved | | Page Request Group Index | | | | |
| Reserved | | | | | | | | | | | | | | | | | | | | | | | |

A-0738A

Figure 10-18 PRG Response Message

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

171. Behavior when PASID TLP Prefixsupport does not exist is defined in Section 6.20.1 .

172. For example, processing a PRG Response Message that causes the Function to send a TLP Upstream must not block processing of subsequent downstream TLPs even if the Upstream TLP is delayed by flow control.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Table 10-6 PRG Response Message Data Fields

|  |  |
| --- | --- |
| Field | Meaning |
| Page  Request  Group Index | **Page Request Group Index** - This field contains a Function supplied index to which the RC is responding. A given PRG Index will receive exactly one response per instance of PRG (with the possible exception of a Response Failure). |
| Response Code | **Response Code** - This field contains the response type of the associated PRG. The encodings are presented in [Section 10.4.2.1 .](#bookmark4) |

[**10.4.2.1**](10.4.2.1) **Response Code Field**

The values and meaning for the Response Code field are listed in [Table 10-7 .](#bookmark4)

Table 10-7 Response Codes

|  |  |  |
| --- | --- | --- |
| Value | Status | Meaning |
| 0000b | Success | All pages within the associated PRG were successfully made resident. |
| 0001b | Invalid Request | One or more pages within the associated PRG do not exist or requests access privilege(s) that cannot be granted. Unless the page mapping associated with the Function is altered, re-issuance of the associated request will never result in success. |
| 1110b:0010b | Unused | Unused Response Code values. A Function receiving such a message shall process it as if the message contained a Response Code of Response Failure. |
| 1111b | Response Failure | One or more pages within the associated request group have encountered/caused a catastrophic error. This response disables the Page Request Interface at the Function. Any pending page requests for other PRGs will be satisfied at the convenience of the host. The Functionshall ignore any subsequent PRG  Response Messages, pending re-enablement of the Page Request Interface. |

[**10.4.2.2**](10.4.2.2) **PASID TLP Prefix Usage on PRG Responses**

If a Page Request has a PASID TLP Prefix, the corresponding PRG Response Message may optionally contain one as well. If the [PRG Response PASID Required](#bookmark5) bit is Clear, PRG Response Messages do not have a PASID TLP Prefix.

If the [PRG Response PASID Required](#bookmark6) bit is Set, PRG Response Messages have a PASID TLP Prefixif the Page Request also had one. The Function is permitted to use the PASID value from the prefix in conjunction with the PRG Index to match requests and responses.

In PASIDTLP Prefixes attached to PRG Response Messages, the Execute Requestedand Privileged Mode Requested bits are Reserved and the PASID value is copied from the PASID value of the Page Request.

**10.5 ATS Configuration**

**10.5.1 ATS Extended Capability**

Each Function that supports ATS (capable of generating Translation Requests) must have the ATS Extended Capability structure in its extended configuration space. It is permitted to be implemented by Endpoints or Root Complex

Integrated Endpoints.

31 20 19 16

|  |
| --- |
| 1h |

|  |
| --- |
| Next Capability Offset |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

[Figure 10-19](#bookmark8)details allocation of the register fields in the ATS Extended Capability structure.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31  30  29  28  27  26  25  24 | | 23  22  21  20  19  18  17  16 | | 15  14  13  12  11  10  9  8 | 7  6  5  4  3  2  1  0 |
| PCI Express Extended Capability Header | | | | | |
|  | ATS Control Register | |  | ATS Capability Register | |

Figure 10-19 [ATS Extended Capability](#bookmark7)Structure

Byte Offset +000h

+004h

[**10.5.1.1**](10.5.1.1) **ATSExtended Capability Header (Offset 00h)**

[Figure 10-20](#bookmark10)details allocation of the register fields in the[ATS Extended Capability Header;](#bookmark9)[Table 10-8 pro](#bookmark11)vides the respective field definitions.

|  |
| --- |
| 15 0 |
| 000Fh |

PCI Express Extended Capability ID Capability Version

Figure 10-20 ATSExtended Capability Header Table 10-8 ATSExtended Capability Header

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 15:0 | **PCI Express Extended Capability ID** - Indicates the ATS Extended Capability structure. This field must return a Capability ID of "000Fh" indicating that this is an ATS Extended Capability structure. | RO |
| 19:16 | **Capability Version** - This field is a PCI-SIG defined version number that indicates the version of the Capability structure present.  Must be "1h" for this version of the specification. | RO |
| 31:20 | **Next Capability Offset** - The offset to the next PCI Extended Capability structure or 000h if no other items exist in the linked list of capabilities. | RO |

[**10.5.1.2**](10.5.1.2) **ATS Capability Register (Offset 04h)**

[Figure 10-21](#bookmark13)details the allocation of register fields of an[ATS Capability Register;](#bookmark12)[Table 10-9 pro](#bookmark14)vides the respective bit definitions.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

15 8 7 6 5 4 0

|  |
| --- |
| RsvdP |

Invalidate Queue Depth

Page Aligned Request

Global Invalidate Supported Relaxed Ordering Supported

Figure 10-21 ATS Capability Register (Offset 04h) Table 10-9 ATS Capability Register (Offset 04h)

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 4:0 | **Invalidate Queue Depth** - The number of Invalidate Requests that the Function can accept before putting backpressure on the Upstream connection. If 0 0000b, the Function can accept 32 Invalidate Requests. | RO |
| 5 | **Page Aligned Request** - If Set, indicates the Untranslated Address is always aligned to a 4096 byte  boundary. Setting this field is recommended. This field permits software to distinguish between  implementations compatible with this specification and those compatible with an earlier version of this specification in which a Requester was permitted to supply anything in bits [11:2]. | RO |
| 6 | **Global Invalidate Supported**- If Set, the Function supports Invalidation Requests that have the Global Invalidate bit Set. If Clear, the Function ignores the Global Invalidate bit in all Invalidate Requests (see Section 10.3.8).  This bit is 0b if the Function does not support thePASID TLP Prefix. | RO |
| 7 | **Relaxed Ordering Supported**- If Set, indicates this Function is permitted to Set the RO bit in Translation Requests when Enable Relaxed Ordering bit is Set. | RO |

[**10.5.1.3**](10.5.1.3) **ATS Control Register (Offset 06h)**

[Figure 10-22](#bookmark15)details the allocation of register fields of an[ATS Control Register;](#bookmark15)[Table 10-10 pro](#bookmark16)vides the respective bit definitions.

|  |
| --- |
| 4 0 |
|  |

15

|  |
| --- |
|  |

|  |
| --- |
| 14 5 |
| RsvdP |

Smallest Translation Unit (STU) Enable (E)

Figure 10-22 ATS Control Register

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Table 10-10 ATS Control Register

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 4:0 | **Smallest Translation Unit (STU)** - This value indicates to the Function the minimum number of  4096-byte blocks that is indicated in a Translation Completions or Invalidate Requests. This is a power of 2 multiplier and the number of blocks is 2STU. A value of 0 0000b indicates one block and a value of 1  1111b indicates 231 blocks (or 8 TB total)  Default value is 0 0000b. | RW |
| 15 | **Enable (E)** - When Set, the Function is enabled to cache translations.  Behavior is undefined if this bit is Set and the value of thePASID Enable,Execute Permission Enable, or Privileged Mode Enable bits are changed.  Default value is 0b. | RW |

**10.5.2 Page Request Extended Capability Structure**

A [Page Request Extended Capability](#bookmark17)Structure is used to configure the Page Request Interface mechanism. A

Multi-Function Endpoint or Root Complex Integrated Endpoint Device may implement a Page Request Interface and the associated capability on any Function within the Device. For SR-IOV, a single Page Request Interface is permitted for the PF and is shared between the PF and the associated VFs. The PF implements this capability and the VFs do not. Every Page Request Interface mechanism operates independently.

Note: For SR-IOV, even though the Page Request Interface is shared between PFs and VFs, it sends the requesting

Function’s ID (PF or VF) in the Requester ID field of the Page Request Message and expects the requesting Function’s ID in the Destination Device ID field of the resulting PRG Response Message.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 31  30  29  28  27  26  25  24 | 23  22  21  20  19  18  17  16 | | 15  14  13  12  11  10  9  8 | | 7  6  5  4  3  2  1  0 |
| PCI Express Extended Capability Header | | | | | |
| Page Request Status Register | | | Page Request Control Register | | |
| Outstanding Page Request Capacity | | | | | |
|  | | Outstanding Page Request Allocation | |  | |

Figure 10-23 [Page Request Extended Capability](#bookmark17)Structure

Byte Offset

+000h +004h +008h +00Ch

[**10.5.2.1**](10.5.2.1) **Page Request Extended Capability Header (Offset 00h)**

[Figure 10-24](#bookmark19)details allocation of the register fields in the[Page Request Extended Capability Header;](#bookmark18)[Table 10-11](#bookmark20) provides the respective field definitions.

31 20 19 16

|  |
| --- |
| 1h |

|  |
| --- |
| Next Capability Offset |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |
| --- |
| 15 0 |
| 0013h |

PCI Express Extended Capability ID Capability Version

Figure 10-24 Page Request Extended Capability Header Table 10-11 Page Request Extended Capability Header

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 15:0 | **PCI Express Extended Capability ID** - Indicates that the associated extended capability structure is a Page Request Extended Capability. This field must return a Capability ID of "0013h". | RO |
| 19:16 | **Capability Version** - This field is a PCI-SIG defined version number that indicates the version of the Capability structure present.  Must be "1h" for this version of the specification. | RO |
| 31:20 | **Next Capability Offset** - The offset to the next PCI Extended Capability structure or 000h if no other items exist in the linked list of capabilities. | RO |

[**10.5.2.2**](10.5.2.2) **Page Request Control Register (Offset 04h)**

[Figure 10-25](#bookmark21)details allocation of the register fields in the[Page Request Control Register;](#bookmark21)[Table 10-12 pro](#bookmark22)vides the respective field definitions.

|  |  |  |  |
| --- | --- | --- | --- |
| 15 2 | 1 | | 0 |
| RsvdP |  |  | |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAARCAYAAADQWvz5AAAA1klEQVQ4jb3TMUoDQRQG4G+DphNs7VSwsEgbCyGkSqln8BqC5BWiB7A3jZUHyEmEpAghYCGkSiWICBbu4oJjdgTJ3828Nx9vYKYA4Rgz4d1fEzp4apXLS0yFC2E7EzgRxhhjr6gVehhiH9d4SE4Yugh0cIN74a1INKbBL2BYArcVUB37CaXBZxymgGboG7zCOU5TQJXWb4VaJlisQ3KhrORAH6yfZsMJbWGnqS3namcY/QeUlY1Cr1g2NTW/bAgHaNd25uX/2xVWsJUFcYej2rqPFwzwCJ9eBjLl83vwYQAAAABJRU5ErkJggg==)Enable (E) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABcAAAACCAYAAACzMUeIAAAAXklEQVQImV3LIQ6CcBjG4ccJYzPJRmAEC9lbkK1kbvJdg2w2exWz2UNQ/sxvvOW3Pdt7Eibc/fcWPsIDY/KX8BVmDMmfwk9YcE2+VmhxS3gp7Q7elPYHr0uH8tl33gDuVQtuApf4EAAAAABJRU5ErkJggg==) Reset (R)

Figure 10-25 Page Request Control Register Table 10-12 Page Request Control Register

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 0 | **Enable (E)** - This field, when set, indicates that the Page Request Interface is allowed to make page  requests. If this field is Clear, the Page Request Interface is not allowed to issue page requests. If both  this field and the Stopped field are Clear, then the Page Request Interface will not issue new page  requests, but has outstanding page requests that have been transmitted or are queued for transmission. When the Page Request Interface is transitioned from not-Enabled to Enabled, its status flags (Stopped, Response Failure, and Unexpected Response flags) are cleared. Enabling a Page Request Interface that  has not successfully Stopped has indeterminate results. Default value is 0b. | RW |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 1 | **Reset (R)** - When the Enable field is clear, or is being cleared in the same register update that sets this  field, writing a 1b to this field, clears the associated implementation dependent page request credit  counter and pending request state for the associated Page Request Interface. No action is initiated if this field is written to 0b or if this field is written with any value while the Enable field is Set. Reads of this  field return 0b | RW |

[**10.5.2.3**](10.5.2.3) **Page Request Status Register (Offset 06h)**

[Figure 10-26](#bookmark23)details allocation of the register fields in the Page Request Error Register;[Table 10-13](#bookmark24)provides the respective field definitions.

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| 15 | 14 9 | 8 | 7 2 | 1 | 0 |
|  | RsvdZ |  | RsvdZ |  |  |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAMCAYAAABfnvydAAAAYUlEQVQYlY3QsQ2DAAwF0UdEQ02fOcgEkF0QM3gVdmEDxAzZARoKKGhiuPLrJJ9MaIXOH15o8MmElFuhxIjiTkwIvTBkJ+qs5VHklonF2fG+bJvwEyqs5TlOF2HB1/HdeQdu7w0ZxOuVJQAAAABJRU5ErkJggg==) Response Failure (RF)

Unexpected Page Request Group Index (UPRGI)

Stopped (S)

PRG Response PASID Required

Figure 10-26 Page Request Status Register Table 10-13 Page Request Status Register

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 0 | **Response Failure (RF)** - This field, when Set, indicates that the Function has received a PRG Response Message indicating a Response Failure. The Function expects no further responses from the host (any received are ignored). This field is Set by the Function and Cleared when a one is written to the field. For SR-IOV, this field is Set in the PF if any associated Function (PF or VF) receives a PRG Response  Message indicating Response Failure.  Default value is 0b. | RW1C |
| 1 | **Unexpected Page Request Group Index (UPRGI)** - This field, when Set, indicates that the Function has received a PRG Response Message containing a PRG index that has no matching request. This field is Set by the Function and cleared when a one is written to the field.  For SR-IOV, this field is Set in the PF if any associated Function (PF or VF) receives a PRG Response Message that does has no matching request.  Default value is 0b. | RW1C |
| 8 | **Stopped (S)** - When this field is Set, the associated page request interface has stopped issuing additional page requests and that all previously issued Page Requests have completed. When this field is Clear the associated page request interface either has not stopped or has stopped issuing new Page Requests but has outstanding Page Requests. This field is only meaningful if Enable is Clear. If Enable is Set, this field is undefined.  When the Enable field is Cleared, after having been previously Set, the interface transitions to the  stopping state and Clears this field. After all page requests currently outstanding at the Function(s) have | RO |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
|  | completed, this field is Set and the interface enters the disabled state. If there were no outstanding page requests, this field may be Set immediately when Enable is Cleared. Resetting the interface will cause an immediate transition to the disabled state. While in the stopping state, receipt of a Response Failure  message will result in the immediate transition to the disabled state (Setting this field).  For SR-IOV, this field is Set only when all associated Functions (PF and VFs) have stopped issuing page requests.  Default value is 1b. |  |
| 15 | **PRG Response PASID Required**- If Set, the Function expects a PASID TLP Prefixon PRG Response  Messages when the corresponding Page Requests had a PASID TLP Prefix. If Clear, the Function does not expectPASID TLP Prefixes on any PRG Response Message.  Function behavior is undefined if this bit is Clear and the Function receives a PRG Response Message with a PASID TLP Prefix.  Function behavior is undefined if this bit is Set and the Function receives a PRG Response Message with no PASID TLP Prefixwhen the corresponding Page Requests had a PASID TLP Prefix.  This bit is RsvdZif the Function does not support thePASID TLP Prefix. | RO |

[**10.5.2.4**](10.5.2.4) **Outstanding Page Request Capacity (Offset 08h)**

This register contains the number of outstanding page request messages the associated Page Request Interface

physically supports. This is the upper limit on the number of pages that can be usefully allocated to the Page Request Interface.

This register is Read Only.

[**10.5.2.5**](10.5.2.5) **Outstanding Page Request Allocation (Offset 0Ch)**

This register contains the number of outstanding page request messages the associated Page Request Interface is allowed to issue (have outstanding at any given instance).

The number of PRGs a Page Request Interface has outstanding is less than or equal to the number of request messages it has issued. For example, if system software allocates 1000 messages to a Page Request Interface then a single PRG could use all 1000 of the possible requests. Conversely, at one request per PRG the Page Request Interface would run out of

PRG indices (of which there are only 512) before it consumes all its page request credits. A Page Request Interface must pre-allocate its request availability for any given PRG, that is, all the requests required by a given PRG must be available before any of the requests may be issued.

This register is Read/Write. Behavior is undefined if this register is changed while the Enable flag is set. Behavior is undefined if this register is written with a value larger than[Outstanding Page Request Capacity.](#bookmark25) Default value is 0.

When PASID TLP Prefixis supported, the Request Allocation remains associated with the Function and is shared across the Function as well as all PASIDs of the Function.

Stopping a PASID does not affect any allocation used by that PASID. The system should continue to respond with PRG Response Messages in order to return Page Request and PRG Index resources to the Function (see [Section 10.4.2.1)](#bookmark4).

Stop Marker Messages consume buffering but are not included in this allocation (see Section 10.4.1.2.1). Systems should provide additional buffering for Stop Marker Messages and should limit the number of outstanding Stop Marker

Messages to avoid overrunning this additional buffering.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Isochronous Applications**

**A.1 Introduction**

**A.**

The design goal of isochronous mechanisms in PCI Express is to ensure that isochronous traffic receives its allocated bandwidth over a relevant time period while also preventing starvation of other non-isochronous traffic.

Furthermore, there may exist data traffic that requires a level of service falling in between what is required for bulk data traffic and isochronous data traffic. This type of traffic can be supported through the use of Port arbitration within

Switches, the use of TC labels [1:7], and optional additional VC resources. Policies for assignment of TC labels and VC resources that are not isochronous-focused are outside the scope of the PCI Express specification.

Two paradigms of PCI Express communication are supported by the PCI Express isochronous mechanisms:

Endpoint-to-Root-Complex communication model and peer-to-peer (Endpoint-to-Endpoint) communication model. In the Endpoint-to-Root-Complex communication model, the primary isochronous traffic is memory read and write

requests to the Root Complex and read completions from the Root Complex.[Figure A-1](#bookmark26)shows an example of a simple system with both communication models. In the figure, devices A, B, called Requesters, are PCI Express Endpoints

capable of issuing isochronous request transactions, while device C and Root Complex, called Completers, are capable of being the targets of isochronous request transactions. An Endpoint-to-Root-Complex communication is established

between device A and the Root Complex, and a peer-to-peer communication is established between device B and device C. In the rest of this section, Requester and Completer will be used to make reference to PCI Express elements involved in transactions. The specific aspects of each communication model will be called out explicitly.

|  |
| --- |
| Root Complex (Completer) |

Read Completions

|  |
| --- |
|  |

Switch

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABcAAAAXCAYAAADgKtSgAAAA8klEQVRIia3Qv4rCQBDH8TmrK5IHsJrBgYB/oqBeo6WClU9hIeKjXHlvoVZ2nnjNNfoW6RVSqUWKsQqIxGU3s7969vOFBbAcI30y0tT2HgCgYgsHYbgHgG09ipbe8BweDAf9/d8BgiD8dgkY4U4r/l/M5/csy0REJEkS+er2bqpAEZxPFTDBqoANXCrgAjsFysBWAQ1sDPiA3wYYacZIcjmfVXC+zWotjCSMVAVG+mg3mj+T0fiapqkKPh2PEtcb16jG4+evUQcKYR8BI6wJWMFlAk6wS6AUbBNQwaaAF7go8Lvb+YNfA4wkXuHnACNFLm8etNY2yuO7MxYAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABcAAAAXCAYAAADgKtSgAAABMUlEQVRIia3RP0vDQBzG8acKQkiii1AE4Q4O/FOrDq0gDiq+Ct+Bu04afAWKc9s3EN+B1MnN3WInC2p0SjJITEWH/JyyiEnvT575+HyPO0BhgvF5lfPTCnALwNNCvZ6EcXxfGS4Yb1mWdXfqnc0MHga7s477JRuYCDdXVpPbfp+IiN6CgLbbW+PG0vJxpXA+40ARbBwQjLfLYO2ALKwcUIWlA7rwxIApXBgQjC8Kxuna943gfMFrQIJxEowfTgF4t237qtfpjuM4lvr0ohERet3Oj+O6QwA3+e1rG421y4O9/TSKIq0bZ1lG5573vdlcfxSMz/19d+1AKWwSkIJ1AkqwSkALlgkYwWWBSuB/A2GoBNdkA7ZtX6RpeuK47vAzSXZGL88fleB5AMARAF8GBoBf3VoRCpudh70AAAAASUVORK5CYII=)Read/Write Requests

Write Requests

Write

Requests

|  |
| --- |
| Device C (Completer) |

|  |
| --- |
| Device B (Requester) |

|  |
| --- |
| Device A  (Requester) |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEIAAAABCAYAAABqmHgqAAAAkklEQVQYlV3NsQ2BcRCG8ccEJPR3cgMoDWABIgZgAaUFSNQSBhBDsMAXtYLqkrtQWoBK8xV/35XPL3mvZaI94Mn/TTzjbKIz4Niwjmd8TPQAzIteecYIwEQfgBa28Yy1ifaBe2Nv5BmViS6AfdG/ntGu907AtLCLZ4xrewHdwlaesTPRAXBt/Bp6xs1El8C26O8fK94vR50QbQ0AAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAAHCAYAAADebrddAAAAnklEQVQYlYXQsUoDQRSF4S/sknqYKt0OTGXlAwj6DBaW9nnFdUNArEUULFdmi4BgkaRIkcakWSGokFvec/7DPbfKTbqLIVhvN1/OTI0p3nOTVujwgEU/lD/wBHKTHnF9sj/gdQQ7PPVD2VcQQ/jG7a+QGa5wj5sYwsckN6nCMy5PzJ9jaovu56Qac1xgOYot3vqhHP4r+ILYD2V37htH/s8sutA3ugsAAAAASUVORK5CYII=) Isochronous traffic flow

OM14288

Figure A-1 An Example Showing Endpoint-to-Root-Complex and Peer-to-Peer Communication Models

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Guaranteed bandwidth and deterministic latency require end-to-end configuration of fabric resources. If isochronous

traffic is intermixed with non-isochronous traffic, it may not be possible to provide any guarantees/determinism as

required by the application usage model. It is recommended that system software configure and assign fabric resources such that traffic intermix either does not occur or is such that the application usage model guarantees can be met. This can be accomplished by assigning dedicated VC resources and corresponding TC labels to the isochronous traffic flow(s) on a given path within the fabric.

Note that there may be one or more isochronous traffic flows per VC/TC label and it is up to system software to insure that the aggregation of these flows does not exceed the requisite bandwidth and latency requirements.

It is also possible for a fabric to support multiple isochronous traffic flows separated across multiple VC (agiven flow cannot span multiple VC/TC labels).

In general, as long as the device can meet the isochronous bandwidth and latency requirements, there is nothing to preclude a single VC device from supporting isochronous traffic if multiple TC labels are supported to delineate such traffic from non-isochronous traffic within the fabric.

**A.2 Isochronous Contract and Contract Parameters**

In order to support isochronous data transfer with guaranteed bandwidth and deterministic latency, an isochronous

contract must be established between a Requester/Completer pair and the PCI Express fabric. This contract must enforce both resource reservation and traffic regulation. Without such a contract, two basic problems, over-subscription and

congestion, may occur as illustrated in [Figure A-2 .](#bookmark27) When interconnect bandwidth resources are over-subscribed, the increased latency may cause failure of isochronous service and starvation of non-isochronous services. Traffic

congestion occurs when flow control credits are not returned possibly due to a higher than expected/provisioned packet injection rate. This may cause excessive service latencies for both isochronous traffic and non-isochronous traffic.

Isochronous Requests:

Isochronous Requests:

Time

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAALCAYAAACprHcmAAAAtUlEQVQYlY3RPUoDURiF4WeuCUIWoOUMjJYWcRdiEbIBsTKNrSuxE0k2ICS9m1D7C/dCSLDVzh9iEZUxxZi3/d4PzuEUGtRltYsBDvGCacxp/nMvGuIAN9hr/H/iFpcxp4/Ot3iCO3T8ZQcj9HBW1GVV4BFH2jkO6G8hwnnYyNjGfsDzlvIy4ME6839MQsxphSu8tYjjmNNTgJjTPYZYbEjvuMYFjVGgLqsuTnGAV8xiTr+dvgDZwitu3hvM+wAAAABJRU5ErkJggg==)Over-subscription (few remaining periods available for non-isochronous traffic)

Time

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAsAAAALCAYAAACprHcmAAAAuElEQVQYlY3RPUoDURQG0DMvBFs7MQRmYLQeK3dgpZDGDegK7FxLrIT0ojYuI4X1g/cKIbGJP6UGLZLAaBHma79z4XJvoZW6rPo4wyE+cB9zmm36ogVPcYNBa/4LY1zFnJa9NTzBA3b9TQ/HGC7e3x6LuqwKTNHYnibgqAOEi4C9DhD2A1474nmw2ve5A74NMacfXON7C5zEnKYBYk5POMf8H1pa3fmS1lOgLqsdjHCAT9zFnF42/S87Wi6Sjfe++QAAAABJRU5ErkJggg==) Congestion (too many isochronous requests in a given time window)

OM14289A

Figure A-2 Two Basic Bandwidth Resourcing Problems: Over-Subscription and Congestion

The isochronous transfer mechanism in this specification addresses these problems with traffic regulation including

admission control and service discipline. Under a software managed admission control, a Requester must not issue

isochronous transactions unless the required isochronous bandwidth and resource have been allocated. Specifically, the isochronous bandwidth is given by the following formula:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,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)

Equation A-1 Isochronous Bandwidth

The formula defines allocated bandwidth (BW) as a function of specified number (N) of transactions of a specified

payload size (Y) within a specified time period (T). Another important parameter in the isochronous contract is latency. Based on the contract, isochronous transactions are completed within a specified latency (L). Once a Requester/

Completer pair is admitted for isochronous communication, the bandwidth and latency are guaranteed to the Requester (a PCI Express Endpoint) by the Completer (Root Complex for Endpoint-to-Root-Complex communication and another PCI Express Endpoint for peer-to-peer communication) and by the PCI Express fabric components (Switches).

Specific service disciplines must be implemented by isochronous-capable PCI Express components. The service

disciplines are imposed to PCI Express Switches and Completers in such a manner that the service of isochronous

requests is subject to a specific service interval (t). This mechanism is used to provide the method of controlling when an isochronous packet injected by a Requester is serviced. Consequently, isochronous traffic is policed in such manner that only packets that can be injected into the fabric in compliance with the isochronous contract are allowed to make

immediate progress and start being serviced by the PCI Express fabric. A non-compliant Requester that tries to inject

more isochronous transactions than what was being allowed by the contract is prevented from doing so by the

flow-control mechanism thereby allowing compliant Requesters to correctly operate independent of non-compliant Requesters.

In the Endpoint-to-Root-Complex model, since the aggregated isochronous traffic is eventually limited by the host memory subsystem's bandwidth capabilities, isochronous read requests, and write requests (and Messages) are

budgeted together. A Requester may divide the isochronous bandwidth between read requests and write requests as appropriate.

**A.2.1 Isochronous Time Period and Isochronous Virtual Timeslot**

The PCI Express isochronous time period (T) is uniformly divided into units of virtual timeslots (t). To provide precise

isochronous bandwidth distribution only one isochronous request packet is allowed per virtual timeslot. The virtual

timeslot supported by a PCI Express component is reported through the Reference Clock field in the Virtual Channel

Capability structure or the Multi-Function Virtual Channel Capability structure. When Reference Clock = 00b, duration of a virtual timeslot t is 100 ns. Duration of isochronous time period T depends on the number of phases of the supported time-based WRR Port arbitration table size. When the time-based WRR Port Arbitration Table size equals to 128,there are 128 virtual timeslots (t) in an isochronous time period,i.e. T = 12.8 μs.

Note that isochronous period T as well as virtual timeslots t do not need to be aligned and synchronized among different PCI Express isochronous devices, i.e., the notion of {T, t} is local to each individual isochronous device.

**A.2.2 Isochronous Payload Size**

The payload size (Y) for isochronous transactions must not exceed Max\_Payload\_Size (seeSection 7.8.4). After

configuration, the Max\_Payload\_Size is set and fixed for each path that supports isochronous service with a value

required to meet isochronous latency. The fixed Max\_Payload\_Size value is used for isochronous bandwidth budgeting regardless of the actual size of data payload associated with isochronous transactions. For isochronous bandwidth

budgeting, we have

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Y = Max\_Payload\_Size

Equation A-2 Isochronous Payload Size

A transaction with partial writes is treated as a normally accounted transaction. A Completer must account for partial writes as part of bandwidth assignment (for worst case servicing time).

**A.2.3 Isochronous Bandwidth Allocation**

Given T, t and Y, the maximum virtual timeslots within a time period is

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFMAAAAtCAYAAADSmlexAAAEOElEQVRoge3baahVVRTA8d8bTJ9J8gzKeg1aURqmlkFQkc0fikIKyQ8l2filiYKgIkOCCCoaNEIiFYmQIkqorGggikqabLD6JL1sgObZtF63D+scPN3ueef6fHeq84fLPfvste9ed509rLX2vV1KhmMcLkZPgdwQljZenc7mCPyBSsHr01Yp2En0YFdMSF4n4E/cmrk3AX3Q2xodO4Yh/JopH4xurMcv1cLdTVLqv0I67d9ttSKdTg9ex2d5AuXIrJ8+TMd7eQKlMetnGsbj7TyB0pj1M1tM9dKYo0C5+YwS3XgVnxcJlRTTh0MNs/lQGrNeDhGRUO56SWnMepmlYPOhNGa9zBEx+Q5tPvNwOXbLqT86qS8poBcf4y+clyOzBj82TaMOZk/8jp/wVI36XnyI15qpVCeRXTNnJuWVmIt9q2QnYarSac0lm888XEzxFbgQZ+HuTP0M7II3m6bdjjMDUwpkfsZLjVbkYZFeGofnRLopyzUinDqy0YrsBPcqPmLY2KjOu5L3XnwgjHkKLsU9YrSmnT+E0zGxUcqMAn0YWyAzJEZnLRbiqBH2XUmn+e5iejwjnt7juB3nYLEw9kyxAbUzW5LXSPkNP4ywbSW9OFU8sYVJuQtrhas0Bv1JR/eNWM3/AenITDefdKeuCJ9ytRj224RR32q2gjvIAhxfIPMlljSi89SYc8Q6knV71gmfcx42JPc2aG/2EUnc4Wjomp9GPq/UqFst1smb/TvyWSwUn41leBKLxBIxkLR5QngB1YwX7tcDSbsl4vw55SJcX9VmftJnWzNZRD7LatSdhq0iW1Id+QziaWwSLskLYqlYLB7ASuFuVXBtpl2v8FU34i7chu+FUVOOSfpdkJT3wje4YgTfr6mkm88FNer6sFkYpHrzGRTJ0oGkPA6f4CuR4idG6bPi0D7LAVXlRWJdnp65tzT5vH7hprVzsIAIH6s3nyxb8JgwZq3N53nbU/lb8RHetz3vV0nKk6vabUrex4plYiDRZb+MTDql78f5uKqO79OxDOLOqntrhYGz3IIvqu4diFXCp1uftBsSQUGWq8UDeWTn1R0V5orlqyatSA4P4EUR508XrtdNYnZkmYBLxIw5Dns3Ucc8zhUGrUkrjHmySPddJny+PD2uE6PyJHyNO5qiXT5jhA+bmzVrhTG/E+cpZ4gN7lgxdbIZrJm4Uhj02+T6bJzZVE2DbtwoPJOpOEyE249i/2rBZrNOKLZK/CxvOW6w3Y/tFTv5y0Jpwu16UKQE+5uoK2GjKThIeCeD4jxoW3LdFgxoj3WwXlYI72aPVivS6fTgHZGmzKU86q2PieKHCMPmJkpj1scs4cq9MZxQacz6mJO8t3sKsiNY459/FKhJOTKL6RZ50sIfXxT986okmC+OkTcn5UkiKisZASeKnGtF5BCWt1adzmeiSMpMyxP4G6vO4eP6BdjwAAAAAElFTkSuQmCC)

Equation A-3 N max

and the maximum specifiable isochronous bandwidth is

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGIAAAAsCAYAAACe920SAAAFdUlEQVR4nO3aZ4wVVRQH8N8WpERDEEsEEiuKioiCmihBA5ZobAmBECNRovGL7YOFoKCxJH4w9hYMCjGiaLAQRazYC3bsUWPEEhUrCuIKiB/OjMzOzttF2PfeLu/9k5d5c8+5M2fuufe0e5vUUU7sjwn4Cb8W0PfGSfi7kkLVIsZiLS4qoPXBu/gC/SspVC1iK7ESHiugXY7VOLKiEtUoGrAQy3LtI7AKN1ZcohrG+WLmj0zue+F1fFg1iWoUI4Uizkrup+AvHFI1iWoUPfEN7sXuWI4rqypRDWMuvsTTeLO6otQ2Tsc/WIHhVZalpnEw1uC6UgyNlZOlpjFEjPXLpRjqiqgMRogV8W61BallNOIlfNsRUx3lRS/shSXtMTXn7k/ETsn/dfhTxMCL8UuOt7eIBr7C/BxtS0wW2eOiHG0QxuGGDj5gc8FgUXN6e0M7NOMTkfV9jx9EeXadCLum5/i3T3gfKnjWmSJcm1lAuwotGypULSId2NmZtkbhaF4T5dwJGdqAhH9u7jk98ZEY7LtytN5Yisc7S+jNBVkfMQw9tM78/sFb1s/wsRlak6gu5mf3cegrHNQWOdrRGIjbN1XwzQ1ZH7GfMENFIdaa5Jr1E03JtSXXdi7mCAfVI0NrEH7jKzy48SKXFUOt95Gl8AeeL6cQ92Ml+uXam3CfUMLgTPuuQgk3ZdpGJ8/YQ5ifRzK0nUUN/tJOlbpzcYuYjO39ylK+bs5ch4kNjGHCH2wtBvsUbCv8w2eZvnnT1CBWw9P4PLnProhJwrzN7vzP6DScj4s74FnbDm2w8IP/FytTRfQXS7InnssxvYej8EGuPW+ahggfcKwY8LXJ8xqFQiZhgXDWXRWrkt/G4hZxYOD/4pX0z5Fi4C4QCUgvbIcxYoavwAm5zkNFeJuGtbeKfCPFfLwgFHF0wnvERghZE0hXROqo3xAhqeS6SAzuYlyvdeKWmqaVQmkTcXaGvibhaRRO+lM8VY6P6ERMxGEd8HyHyzr7xakiRogZ+34Bz0oRSY3LtaemaQVOFacV5mToa4WiBuAYTOsUicuLQTreL+hbrpenGXWpWkgTXtXWth8g9mJPE875ghx9jkgEp+A3sWrqKIFGbCMcdZEiGkQkcaAIYbNIV8QYMUtm5eirRUJ3Ch7Q9kjJJWL2DcfNwpFPTt45EFfgUZxXIFcfMQHuSPpdJupbKU7X9lDX+OSdXRapo75H2MiJOEMcgFoiIqCFBf0OEX6gBdcW0GcKc7caBxXQ01LHFyLaWJS86xJRIpklcpt1uDDTr1lk/x8Kv3W1MIsLcrK1JN8CO4hjj+cUDUBXwRStE5Z0b/VjzMPhJfqNFopYhd0K6Lclz3utRP+lIjQemNz3Ehvsy6wPARvwpNbRGOySu58slL5npu2m5Hn9xEGu+qZ9CSzVeg83PRX3TI7vGqVzj57CtE0Tk+KoDK2fUMQ8/I5RmyxxGdGVNobWKT4V3aJ1hk5k/LNFqX6GCBwatK6d/SpWwjg8IYqQ1cSh2vrR/9CVFLGhGIhnRSCwp/A/lwqTmsWWwtctEWZ0QAVlLMLJQhmF6I6KOFzsnZwlkiuKv2OqWGVj8aMwcdVCD5Eoltwu7Y6K+EWEzseJAtsoseSzZmmYKEBOxc/J/3E4vqKSBqaL6G9n7IOHRTi/Y5apOypiofiw2SK6myEqpssTerOImF4UH02ExneLffJ8mb/c2ElElQ0i6FgjfGFXLn5utrhThPn16kIV0YR3tN1GaIXuaJq6G/qKHct2T/nVFVF+7CtC7TfaY6orovwYkVzfqqoUdZgr9nTaRX1FlB+DrA+tS6KpI4Y6Nhnjxf7+18n91iLTr6PCGCMKkOkWw4wipn8B45IwFG8PGaIAAAAASUVORK5CYII=)

Equation A-4 BWmax

The granularity with which isochronous bandwidth can be allocated is defined as:

![](data:image/png;base64,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)

Equation A-5 BWgranularity

Given T and t at 12.8 μs and 100 ns, respectively, N max is 128. As shown in [Table A-1 ,](#bookmark28) BWmax and BWgranularity are functions of the isochronous payload size Y.

Table A-1 Isochronous Bandwidth Ranges and Granularities

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Y (bytes) | 128 | 256 | 512 | 1024 |
| BW max (MB/s) | 1289 | 2560 | 5120 | 10240 |
| BWgranularity (MB/s) | 10 | 20 | 40 | 80 |

Similar to bandwidth budgeting, isochronous service disciplines including arbitration schemes are based on counting requests (not the sizes of those requests). Therefore, assigning isochronous bandwidth BWlink to a PCI Express Link is equivalent to assigning N link virtual timeslots per isochronous period, where N link is given by

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,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)

Equation A-6 N link

A Switch Port serving as an Egress Port (or anRCRBserving as a “virtual” Egress Port) for an isochronous traffic, the N max virtual timeslots within T are represented by the time-based WRR Port Arbitration Table in the PCI Express Virtual

Channel Capability structure detailed in Section 7.9.1. The table consists of N max entries. An entry in the table

represents one virtual timeslot in the isochronous time period. When a table entry is given a value of PN, it means that the timeslot is assigned to an Ingress Port (in respect to the isochronous traffic targeting the Egress Port) designated by a Port Number of PN. Therefore, N link virtual timeslots are assigned to the Ingress Port when there are N link entries in the table with value of PN. The Egress Port may admit one isochronous request transaction from the Ingress Port for further service only when the table entry reached by the Egress Port's isochronous time ticker (that increments by 1 every t time and wraps around when reaching T) is set to PN. Even if there are outstanding isochronous requests ready in the Ingress Port, they will not be served until next round of time-based WRR arbitration. In this manner, the time-based Port

Arbitration Table serves for both isochronous bandwidth assignment and isochronous traffic regulation.

For an Endpoint serving as a Requester or a Completer, isochronous bandwidth allocation is accomplished through negotiation between system software and device driver, which is outside of the scope of this specification.

**A.2.4 Isochronous Transaction Latency**

Transaction latency is composed of the latency through the PCI Express fabric and the latency contributed by the

Completer. Isochronous transaction latency is defined for each transaction and measured in units of virtual timeslot t.

• The read latency is defined as the round-trip latency. This is the delay from the time when the device submits a memory read request packet to its Transaction Layer (Transmit side) to the time when the corresponding read completion arrives at the device's Transaction Layer (Receive side).

• The write latency is defined as the delay from the time when the Requester posts a memory write request to its PCI Express Transaction Layer (Transmit side) to the time when the data write becomes globally visible within the memory subsystem of the Completer. A write to memory reaches the point of global visibility when all

agents accessing that memory address get the updated data.

When the upper bound and the lower bound of isochronous transaction latency are provided, the size of isochronous

data buffers in a Requester can be determined. For most of common platforms, the minimum isochronous transaction latency is much smaller than the maximum. As a conservative measure, the minimum isochronous transaction latency is assumed to be zero; only guidelines on measuring the maximum isochronous transaction latency are provided here.

For a Requester, the maximum isochronous (read or write) transaction latency (L) can be accounted as the following:

L = L Fabric + LCompleter

Equation A-7 MaxIsochronous Transaction Latency

where L Fabric is the maximum latency of the PCI Express fabric and L Completer is the maximum latency of the Completer.

L Fabric which applies to both read and write transactions, depends on the topology, latency across each PCI Express Link, and the arbitration point in the path between the Requester to the Completer. The latency on a PCI Express Link

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

depends on pipeline delays, width and operational frequency of the Link, transmission of electrical signals across the medium, wake up latency from low power states, and delays caused by Data Link Layer Retry.

A restriction on the PCI Express topology may be imposed for each targeted platform in order to provide a practically meaningful guideline for L Fabric. The values of L Fabric should be reasonable and serve as practical upper limits under normal operating conditions.

The value of L Completer depends on the memory technology, memory configuration, and the arbitration policies in the Completer that comprehend PCI Express isochronous traffic. The target value for L Completer should provide enough

headroom to allow for implementation tradeoffs.

Definitions of read and write transaction latencies for a Completer are different:

• Read transaction latency for the Completer is defined as the delay from the time a memory read transaction is available at the Receiver end of a PCI Express Port in the Completer to the time the corresponding read

completion transaction is posted to the transmission end of the PCI Express Port.

• Write transaction latency is defined as the delay from the time a memory write transaction is available at the Receiver end of a PCI Express Port in the Completer to the time that the transmitted data is globally visible.

All of the isochronous transaction latencies defined above are based on the assumption that the Requester injects

isochronous transactions uniformly. According to an isochronous contract of {N, T, t}, the uniform traffic injection is

defined such that up to N transactions are evenly distributed over the isochronous period T based on a ticker granularity of virtual timeslot t. For a Requester with non-uniform isochronous transaction injection, the Requester is responsible of accounting for any additional delay due to the deviation of its injection pattern from a uniform injection pattern.

**A.2.5 An Example Illustrating Isochronous Parameters**

[Figure A-3](#bookmark29)illustrates the key isochronous parameters using a simplified example with T = 20t and L = 22t. A Requester

has reserved isochronous bandwidth of four transactions per T. The device shares the allocated isochronous

bandwidths for both read requests and write requests. As shown, during one isochronous time period, the Requester

issues two read requests and two write requests. All requests are completed within the designated transaction latency L. Also shown in the figure,there is no time dependency between the service time of write requests and the arrival time of read completions.

·R1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAALCAYAAACzkJeoAAAAfklEQVQYlXXNMQrCYBCE0S+SQisLi4AIM7C1RbAIiFbyGw/jDTydt/EQFjaJrFGnGZa3y0JKyF2eZ3zmGrK+MOQKKED/63ILNP/wPPQp5HqKZegl0L0x5DlwTIuXfHkAFgn7jOO/B/AEdiGvRtwDN8BAC9yBQshVyBsmCXn9AvRqDEPYVObgAAAAAElFTkSuQmCC)W1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAALCAYAAACzkJeoAAAAh0lEQVQYlW2NMQoCQQxF3w64hYiFsI2iCeQGy2KrjWtl6aW848AM1lrY2YjNDkSZ34Tkkf/AxUT3fg8OBOBWhUAPHEx0U4Pj36zCczk0k28BPIAWeAJdzOlTPo8TAFgBg6898ZvRw+K7e28w0S0wAy4xpx1wBdYmumxMtANeMad36TTROdB+AR3/FgX88V45AAAAAElFTkSuQmCC)R2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAALCAYAAACzkJeoAAAAfUlEQVQYlW3MsQrCUAyF4f8WCy46FqcmGCeFjm5drlhfw3fxOQWFroJ7obhcIUrOkhw+OOBiokffKwdL4BYi0APZRFcRnoEFkCMcyr38oIk2QBdimUzl35ro7h99hghHP12Z6AF4AyegBa7A3kTrZKIb4HV/PqbvpomugfkDESUQshoIqIIAAAAASUVORK5CYII=)W2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAA0CAYAAACglemUAAAAK0lEQVQYlWNUllcoYWBg+MnCwMCgycDA8J2JAQpGGUOLwcLAwNDFwMDwFwConQTiEG0DbwAAAABJRU5ErkJggg==) -i t -

T

Requests

Completions v v v v

L W1 W2 R1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAxCAYAAADwWHgnAAAAq0lEQVQYlYXOMUoDQRSA4W+fIYWNk7nALqxXSGvhAUQQSWPh2YIERGxs7FLY2hhSJ4UHMIIgYiE2YWFwE6d6zOPj/VVbNx84DQxRhe3rhoOc0iuedT9t3UxzSsvABPmvCjzivVNVWzfneArc4rhfgQGO8F3wL5wEqn4VuMa6SJ3llBaBi92pD9gUty4xD9yg/Sf1ED/F6hPjPSpwhVWRepdTegmcYdSv7vH2C48aG9TMHo91AAAAAElFTkSuQmCC) R2

OM14290

Figure A-3 A Simplified Example Illustrating PCI Express Isochronous Parameters

**A.3 Isochronous Transaction Rules**

Isochronous transactions follow the same rules as described in Chapter 2 . In order to assist the Completer to meet latency requirements, the following additional rules further illustrate and clarify the proper behavior of isochronous transactions:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• The value in the Length field of requests must never exceed Max\_Payload\_Size.

**A.4 Transaction Ordering**

In general, isochronous transactions follow the ordering rules described in Section 2.4. The following ordering rule further illustrates and clarifies the proper behavior of isochronous transactions:

• There are no ordering guarantees between any isochronous and non-isochronous transactions because the traffic has been segregated into distinct VC resources.

• Isochronous write requests are serviced on any PCI Express Link in strictly the same order as isochronous write requests are posted.

• Switches must allow isochronous posted requests to pass isochronous read completions.

**A.5 Isochronous Data Coherency**

Cache coherency for isochronous transactions is an operating system software and Root Complex hardware issue. PCI Express provides the necessary mechanism to control Root Complex behavior in terms of enforcing hardware cache coherency on a per transaction basis.

For platforms where snoop latency in a Root Complex is either unbounded or can be excessively large, in order to meet tight maximum isochronous transaction latency L Completer, or more precisely L Root\_Complex, all isochronous transactions should have the No SnoopAttribute bit set.

A Root Complex must report the Root Complex's capability to the system software by setting the Reject Snoop

Transactions field in the VC Resource Capability register (for any VC resource capable of supporting isochronous traffic) in its RCRB. Based on whether or not a Root Complex is capable of providing hardware enforced cache coherency for isochronous traffic while still meeting isochronous latency target, system software can then inform the device driver of Endpoints to set or unset theNo SnoopAttribute bit for isochronous transactions.

Note that cache coherency considerations for isochronous traffic do not apply to peer-to-peer communication.

**A.6 Flow Control**

Completers and PCI Express fabric components should implement proper sizing of buffers such that under normal

operating conditions, no backpressure due to flow control should be applied to isochronous traffic injected uniformly by a Requester. For Requesters that are compliant to the isochronous contract, but have bursty injection behavior, Switches and Completers may apply flow control backpressure as long as the admitted isochronous traffic is uniform and

compliant to the isochronous contract. Under abnormal conditions when isochronous traffic jitter becomes significant or when isochronous traffic is oversubscribed due to excessive Data Link Layer Retry, flow control provides a natural mechanism to ensure functional correctness.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**A.7 Considerations for Bandwidth Allocation**

**A.7.1 Isochronous Bandwidth of PCI Express Links**

Isochronous bandwidth budgeting for PCI Express Links can be derived based on Link parameters such as isochronous payload size and the speed and width of the Link.

Isochronous bandwidth allocation for a PCI Express Link should be limited to certain percentage of the maximum

effective Link bandwidth in order to leave sufficient bandwidth for non-isochronous traffic and to account for temporary Link bandwidth reduction due to retries. Link utilization is counted based on the actual cycles consumed on the physical PCI Express Link. The maximum number of virtual slots allowed per Link (N link) depends on the isochronous packet

payload size and the speed and width of the Link.

As isochronous bandwidth allocation on a PCI Express Link is based on number of requests N link per isochronous period. There is no distinction between read requests and write requests in budgeting isochronous bandwidth on a PCI Express Link.

**A.7.2 Isochronous Bandwidth of Endpoints**

For peer-to-peer communication, the device driver is responsible for reporting to system software if the device is capable

of being a Completer for isochronous transactions. In addition, the driver must report the device’s isochronous bandwidth capability. The specifics of the report mechanism are outside the scope of this specification.

**A.7.3 Isochronous Bandwidth of Switches**

Allocation of isochronous bandwidth for a Switch must consider the capacity and utilization of PCI Express Links

associated with the Ingress Port and the Egress Port of the Switch that connect the Requester and the Completer, respectively. The lowest common denominator of the two determines if a requested isochronous bandwidth can be supported.

**A.7.4 Isochronous Bandwidth of Root Complex**

Isochronous bandwidth of Root Complex is reported to the software through its RCRBstructure. Specifically, the Maximum TimeSlots field of the VC Resource Capability register in VC Capability structure indicates the total

isochronous bandwidth shared by the Root Ports associated with the RCRB. Details of the platform budgeting for available isochronous bandwidth within a Root Complex are outside of the scope of this specification.

**A.8 Considerations for PCI Express Components**

**A.8.1 An Endpoint as a Requester**

Before an Endpoint as a Requester can start issuing isochronous request transactions, the following configuration steps must be performed by software:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• Configuration of at least one VC resource capable of supporting isochronous communication and assignment of at least one TC label.

• Enablement of this VC resource.

When the Requester uniformly injects isochronous requests, the Receive Port, either a Switch Port or a Root Port, should issue Flow Control credits back promptly such that no backpressure should be applied to the associated VC. This type of Requester may size its buffer based on the PCI Express fabric latency L Fabric plus the Completer's latency L Completer.

When isochronous transactions are injected non-uniformly, either some transactions experience longer PCI Express fabric delay or the Requester gets back-pressured on the associated VC. This type of Requester must size its buffer to account for the deviation of its injection pattern from uniformity.

**A.8.2 An Endpoint as a Completer**

An Endpoint may serve as a Completer for isochronous peer-to-peer communication. Before an Endpoint starts serving isochronous transactions, system software must identify/configure a VC resource capable of supporting isochronous traffic and assigned a corresponding TC label.

An Endpoint Completer must observe the maximum isochronous transaction latency (L Completer). An Endpoint

Completer does not have to regulate isochronous request traffic if attached to a Switch since Switches implement traffic regulation. However, an Endpoint Completer must size its internal buffer such that no backpressure should be applied to the corresponding VC.

**A.8.3 Switches**

A Switch may have multiple ports capable of supporting isochronous transactions. Before a Switch starts serving isochronous transactions for a Port, the software must perform the following configuration steps:

• Configuration/enablement of at least one VC resource capable of supporting isochronous communication.

• Configuration of the Port as an Ingress Port:

。 Configuration (or reconfiguration if the associated VC of the Egress Port is already enabled) of the time-based WRR Port Arbitration Table of the targeting Egress Port to include N link entries set to the Ingress Port's Port Number. Here N link is the isochronous allocation for the Ingress Port.

。 Enabling the targeting Egress Port to load newly programmed Port Arbitration Table.

• Configuration of the Port as an Egress Port:

。 Configuration of each VC's Port Arbitration Table with number of entries set according to the assigned isochronous bandwidth for all Ingress Ports.

。 Select proper VC Arbitration, e.g., as strict-priority based VC Arbitration.

。 If required, configuration of the Port's VC Arbitration Table with large weights assigned accordingly to each associated VC.

Each VC associated with isochronous traffic may be served as the highest priority in arbitrating for the shared PCI Express Link resource at an Egress Port. This is comprehended by a Switch's internal arbitration scheme.

In addition, a Switch Port may use “just in time” scheduling mechanism to reduce VC arbitration latency. Instead of

pipelining non-isochronous Transport Layer packets to the Data Link Layer of the Egress Port in a manner that Data Link Layer transmit buffer becomes saturated, the Switch Port may hold off scheduling of a new non-isochronous packet to the Data Link Layer as long as it is possible without incurring unnecessary Link idle time.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

When a VC configured to support isochronous traffic is enabled for a Switch Port (ingress) that is connected to a

Requester, the Switch must enforce proper traffic regulation to ensure that isochronous traffic from the Port conforms to this specification. With such enforcement, normal isochronous transactions from compliant Requesters will not be

impacted by ill behavior of any non-compliant Requester.

The above isochronous traffic regulation mechanism only applies to request transactions but not to completion

transactions. When Endpoint-to-Root-Complex and peer-to-peer communications co-exist in a Switch, an Egress Port may mix isochronous write requests and read completions in the same direction. In the case of contention, the Egress

Port must allow write requests to pass read completions to ensure the Switch meets latency requirement for isochronous requests.

**A.8.4 Root Complex**

A Root Complex may have multiple Root Ports capable of supporting isochronous transactions. Before a Root Complex starts serving isochronous transactions for a Root Port, the Port must be configured by software to enable VC to support isochronous traffic using the following configuration steps:

• Configuration of at least one VC resource capable of supporting isochronous communication and assignment of at least one TC label.

• Configuration of the Root Port as an Ingress Port:

。 Configuration (or reconfiguration if the associated VC inRCRBis already enabled) of the time-based WRR Port Arbitration Table of the targeting RCRBto include Nlink entries set to the Ingress Port's Port Number. Here N link is the isochronous allocation for the Port.

。 Enabling the targeting RCRBto load newly programmed Port Arbitration Table.

• Configuration of the Root Port as an Egress Port:

。 If supported, configuration of the Root Port's VC Arbitration Table with large weights assigned to the associated VC.

。 If the Root Complex supports peer-to-peer traffic between Root Ports, configuration of the Root Port's Port Arbitration Table number of entries is set according to the assigned isochronous bandwidth for all Ingress Ports.

A Root Complex must observe the maximum isochronous transaction latency (L Completer or more precisely L Root\_Complex)

that applies to all the Root Ports in the Root Complex. How a Root Complex schedules memory cycles for PCI Express isochronous transactions and other memory transactions is outside of the scope of this specification as long as

L Root\_Complex is met for PCI Express isochronous transactions.

When a VC is enabled to support isochronous traffic for a Root Port, the Root Complex must enforce proper traffic

regulation to ensure that isochronous traffic from the Root Port conforms to this specification. With such enforcement, normal isochronous transactions from compliant Requesters will not be impacted by ill behavior of any non-compliant

Requesters. Isochronous traffic regulation is implemented using the time-based Port Arbitration Table in RCRB. Root Complex may perform the following operations for invalid isochronous transactions:

• Return partial completions for read requests with the value in the Length field exceeding Max\_Payload\_Size.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Symbol Encoding**

**B.**

[Table B-1](#bookmark30)shows the byte-to-Symbol encodings for data characters.[Table B-2](#bookmark31)shows the Symbol encodings for the Special Symbols used for TLP/DLLP Framing and for interface management.

RD- and RD+ refer to the Running Disparity of the Symbol sequence on a per-Lane basis.

Table B-1 8b/10b Data Symbol Codes

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D0.0 | 00 | 000 00000 | 100111 0100 | 011000 1011 |
| D1.0 | 01 | 000 00001 | 011101 0100 | 100010 1011 |
| D2.0 | 02 | 000 00010 | 101101 0100 | 010010 1011 |
| D3.0 | 03 | 000 00011 | 110001 1011 | 110001 0100 |
| D4.0 | 04 | 000 00100 | 110101 0100 | 001010 1011 |
| D5.0 | 05 | 000 00101 | 101001 1011 | 101001 0100 |
| D6.0 | 06 | 000 00110 | 011001 1011 | 011001 0100 |
| D7.0 | 07 | 000 00111 | 111000 1011 | 000111 0100 |
| D8.0 | 08 | 000 01000 | 111001 0100 | 000110 1011 |
| D9.0 | 09 | 000 01001 | 100101 1011 | 100101 0100 |
| D10.0 | 0A | 000 01010 | 010101 1011 | 010101 0100 |
| D11.0 | 0B | 000 01011 | 110100 1011 | 110100 0100 |
| D12.0 | 0C | 000 01100 | 001101 1011 | 001101 0100 |
| D13.0 | 0D | 000 01101 | 101100 1011 | 101100 0100 |
| D14.0 | 0E | 000 01110 | 011100 1011 | 011100 0100 |
| D15.0 | 0F | 000 01111 | 010111 0100 | 101000 1011 |
| D16.0 | 10 | 000 10000 | 011011 0100 | 100100 1011 |
| D17.0 | 11 | 000 10001 | 100011 1011 | 100011 0100 |
| D18.0 | 12 | 000 10010 | 010011 1011 | 010011 0100 |
| D19.0 | 13 | 000 10011 | 110010 1011 | 110010 0100 |
| D20.0 | 14 | 000 10100 | 001011 1011 | 001011 0100 |
| D21.0 | 15 | 000 10101 | 101010 1011 | 101010 0100 |
| D22.0 | 16 | 000 10110 | 011010 1011 | 011010 0100 |
| D23.0 | 17 | 000 10111 | 111010 0100 | 000101 1011 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D24.0 | 18 | 000 11000 | 110011 0100 | 001100 1011 |
| D25.0 | 19 | 000 11001 | 100110 1011 | 100110 0100 |
| D26.0 | 1A | 000 11010 | 010110 1011 | 010110 0100 |
| D27.0 | 1B | 000 11011 | 110110 0100 | 001001 1011 |
| D28.0 | 1C | 000 11100 | 001110 1011 | 001110 0100 |
| D29.0 | 1D | 000 11101 | 101110 0100 | 010001 1011 |
| D30.0 | 1E | 000 11110 | 011110 0100 | 100001 1011 |
| D31.0 | 1F | 000 11111 | 101011 0100 | 010100 1011 |
| D0.1 | 20 | 001 00000 | 100111 1001 | 011000 1001 |
| D1.1 | 21 | 001 00001 | 011101 1001 | 100010 1001 |
| D2.1 | 22 | 001 00010 | 101101 1001 | 010010 1001 |
| D3.1 | 23 | 001 00011 | 110001 1001 | 110001 1001 |
| D4.1 | 24 | 001 00100 | 110101 1001 | 001010 1001 |
| D5.1 | 25 | 001 00101 | 101001 1001 | 101001 1001 |
| D6.1 | 26 | 001 00110 | 011001 1001 | 011001 1001 |
| D7.1 | 27 | 001 00111 | 111000 1001 | 000111 1001 |
| D8.1 | 28 | 001 01000 | 111001 1001 | 000110 1001 |
| D9.1 | 29 | 001 01001 | 100101 1001 | 100101 1001 |
| D10.1 | 2A | 001 01010 | 010101 1001 | 010101 1001 |
| D11.1 | 2B | 001 01011 | 110100 1001 | 110100 1001 |
| D12.1 | 2C | 001 01100 | 001101 1001 | 001101 1001 |
| D13.1 | 2D | 001 01101 | 101100 1001 | 101100 1001 |
| D14.1 | 2E | 001 01110 | 011100 1001 | 011100 1001 |
| D15.1 | 2F | 001 01111 | 010111 1001 | 101000 1001 |
| D16.1 | 30 | 001 10000 | 011011 1001 | 100100 1001 |
| D17.1 | 31 | 001 10001 | 100011 1001 | 100011 1001 |
| D18.1 | 32 | 001 10010 | 010011 1001 | 010011 1001 |
| D19.1 | 33 | 001 10011 | 110010 1001 | 110010 1001 |
| D20.1 | 34 | 001 10100 | 001011 1001 | 001011 1001 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1222

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D21.1 | 35 | 001 10101 | 101010 1001 | 101010 1001 |
| D22.1 | 36 | 001 10110 | 011010 1001 | 011010 1001 |
| D23.1 | 37 | 001 10111 | 111010 1001 | 000101 1001 |
| D24.1 | 38 | 001 11000 | 110011 1001 | 001100 1001 |
| D25.1 | 39 | 001 11001 | 100110 1001 | 100110 1001 |
| D26.1 | 3A | 001 11010 | 010110 1001 | 010110 1001 |
| D27.1 | 3B | 001 11011 | 110110 1001 | 001001 1001 |
| D28.1 | 3C | 001 11100 | 001110 1001 | 001110 1001 |
| D29.1 | 3D | 001 11101 | 101110 1001 | 010001 1001 |
| D30.1 | 3E | 001 11110 | 011110 1001 | 100001 1001 |
| D31.1 | 3F | 001 11111 | 101011 1001 | 010100 1001 |
| D0.2 | 40 | 010 00000 | 100111 0101 | 011000 0101 |
| D1.2 | 41 | 010 00001 | 011101 0101 | 100010 0101 |
| D2.2 | 42 | 010 00010 | 101101 0101 | 010010 0101 |
| D3.2 | 43 | 010 00011 | 110001 0101 | 110001 0101 |
| D4.2 | 44 | 010 00100 | 110101 0101 | 001010 0101 |
| D5.2 | 45 | 010 00101 | 101001 0101 | 101001 0101 |
| D6.2 | 46 | 010 00110 | 011001 0101 | 011001 0101 |
| D7.2 | 47 | 010 00111 | 111000 0101 | 000111 0101 |
| D8.2 | 48 | 010 01000 | 111001 0101 | 000110 0101 |
| D9.2 | 49 | 010 01001 | 100101 0101 | 100101 0101 |
| D10.2 | 4A | 010 01010 | 010101 0101 | 010101 0101 |
| D11.2 | 4B | 010 01011 | 110100 0101 | 110100 0101 |
| D12.2 | 4C | 010 01100 | 001101 0101 | 001101 0101 |
| D13.2 | 4D | 010 01101 | 101100 0101 | 101100 0101 |
| D14.2 | 4E | 010 01110 | 011100 0101 | 011100 0101 |
| D15.2 | 4F | 010 01111 | 010111 0101 | 101000 0101 |
| D16.2 | 50 | 010 10000 | 011011 0101 | 100100 0101 |
| D17.2 | 51 | 010 10001 | 100011 0101 | 100011 0101 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1223

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D18.2 | 52 | 010 10010 | 010011 0101 | 010011 0101 |
| D19.2 | 53 | 010 10011 | 110010 0101 | 110010 0101 |
| D20.2 | 54 | 010 10100 | 001011 0101 | 001011 0101 |
| D21.2 | 55 | 010 10101 | 101010 0101 | 101010 0101 |
| D22.2 | 56 | 010 10110 | 011010 0101 | 011010 0101 |
| D23.2 | 57 | 010 10111 | 111010 0101 | 000101 0101 |
| D24.2 | 58 | 010 11000 | 110011 0101 | 001100 0101 |
| D25.2 | 59 | 010 11001 | 100110 0101 | 100110 0101 |
| D26.2 | 5A | 010 11010 | 010110 0101 | 010110 0101 |
| D27.2 | 5B | 010 11011 | 110110 0101 | 001001 0101 |
| D28.2 | 5C | 010 11100 | 001110 0101 | 001110 0101 |
| D29.2 | 5D | 010 11101 | 101110 0101 | 010001 0101 |
| D30.2 | 5E | 010 11110 | 011110 0101 | 100001 0101 |
| D31.2 | 5F | 010 11111 | 101011 0101 | 010100 0101 |
| D0.3 | 60 | 011 00000 | 100111 0011 | 011000 1100 |
| D1.3 | 61 | 011 00001 | 011101 0011 | 100010 1100 |
| D2.3 | 62 | 011 00010 | 101101 0011 | 010010 1100 |
| D3.3 | 63 | 011 00011 | 110001 1100 | 110001 0011 |
| D4.3 | 64 | 011 00100 | 110101 0011 | 001010 1100 |
| D5.3 | 65 | 011 00101 | 101001 1100 | 101001 0011 |
| D6.3 | 66 | 011 00110 | 011001 1100 | 011001 0011 |
| D7.3 | 67 | 011 00111 | 111000 1100 | 000111 0011 |
| D8.3 | 68 | 011 01000 | 111001 0011 | 000110 1100 |
| D9.3 | 69 | 011 01001 | 100101 1100 | 100101 0011 |
| D10.3 | 6A | 011 01010 | 010101 1100 | 010101 0011 |
| D11.3 | 6B | 011 01011 | 110100 1100 | 110100 0011 |
| D12.3 | 6C | 011 01100 | 001101 1100 | 001101 0011 |
| D13.3 | 6D | 011 01101 | 101100 1100 | 101100 0011 |
| D14.3 | 6E | 011 01110 | 011100 1100 | 011100 0011 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1224

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D15.3 | 6F | 011 01111 | 010111 0011 | 101000 1100 |
| D16.3 | 70 | 011 10000 | 011011 0011 | 100100 1100 |
| D17.3 | 71 | 011 10001 | 100011 1100 | 100011 0011 |
| D18.3 | 72 | 011 10010 | 010011 1100 | 010011 0011 |
| D19.3 | 73 | 011 10011 | 110010 1100 | 110010 0011 |
| D20.3 | 74 | 011 10100 | 001011 1100 | 001011 0011 |
| D21.3 | 75 | 011 10101 | 101010 1100 | 101010 0011 |
| D22.3 | 76 | 011 10110 | 011010 1100 | 011010 0011 |
| D23.3 | 77 | 011 10111 | 111010 0011 | 000101 1100 |
| D24.3 | 78 | 011 11000 | 110011 0011 | 001100 1100 |
| D25.3 | 79 | 011 11001 | 100110 1100 | 100110 0011 |
| D26.3 | 7A | 011 11010 | 010110 1100 | 010110 0011 |
| D27.3 | 7B | 011 11011 | 110110 0011 | 001001 1100 |
| D28.3 | 7C | 011 11100 | 001110 1100 | 001110 0011 |
| D29.3 | 7D | 011 11101 | 101110 0011 | 010001 1100 |
| D30.3 | 7E | 011 11110 | 011110 0011 | 100001 1100 |
| D31.3 | 7F | 011 11111 | 101011 0011 | 010100 1100 |
| D0.4 | 80 | 100 00000 | 100111 0010 | 011000 1101 |
| D1.4 | 81 | 100 00001 | 011101 0010 | 100010 1101 |
| D2.4 | 82 | 100 00010 | 101101 0010 | 010010 1101 |
| D3.4 | 83 | 100 00011 | 110001 1101 | 110001 0010 |
| D4.4 | 84 | 100 00100 | 110101 0010 | 001010 1101 |
| D5.4 | 85 | 100 00101 | 101001 1101 | 101001 0010 |
| D6.4 | 86 | 100 00110 | 011001 1101 | 011001 0010 |
| D7.4 | 87 | 100 00111 | 111000 1101 | 000111 0010 |
| D8.4 | 88 | 100 01000 | 111001 0010 | 000110 1101 |
| D9.4 | 89 | 100 01001 | 100101 1101 | 100101 0010 |
| D10.4 | 8A | 100 01010 | 010101 1101 | 010101 0010 |
| D11.4 | 8B | 100 01011 | 110100 1101 | 110100 0010 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1225

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D12.4 | 8C | 100 01100 | 001101 1101 | 001101 0010 |
| D13.4 | 8D | 100 01101 | 101100 1101 | 101100 0010 |
| D14.4 | 8E | 100 01110 | 011100 1101 | 011100 0010 |
| D15.4 | 8F | 100 01111 | 010111 0010 | 101000 1101 |
| D16.4 | 90 | 100 10000 | 011011 0010 | 100100 1101 |
| D17.4 | 91 | 100 10001 | 100011 1101 | 100011 0010 |
| D18.4 | 92 | 100 10010 | 010011 1101 | 010011 0010 |
| D19.4 | 93 | 100 10011 | 110010 1101 | 110010 0010 |
| D20.4 | 94 | 100 10100 | 001011 1101 | 001011 0010 |
| D21.4 | 95 | 100 10101 | 101010 1101 | 101010 0010 |
| D22.4 | 96 | 100 10110 | 011010 1101 | 011010 0010 |
| D23.4 | 97 | 100 10111 | 111010 0010 | 000101 1101 |
| D24.4 | 98 | 100 11000 | 110011 0010 | 001100 1101 |
| D25.4 | 99 | 100 11001 | 100110 1101 | 100110 0010 |
| D26.4 | 9A | 100 11010 | 010110 1101 | 010110 0010 |
| D27.4 | 9B | 100 11011 | 110110 0010 | 001001 1101 |
| D28.4 | 9C | 100 11100 | 001110 1101 | 001110 0010 |
| D29.4 | 9D | 100 11101 | 101110 0010 | 010001 1101 |
| D30.4 | 9E | 100 11110 | 011110 0010 | 100001 1101 |
| D31.4 | 9F | 100 11111 | 101011 0010 | 010100 1101 |
| D0.5 | A0 | 101 00000 | 100111 1010 | 011000 1010 |
| D1.5 | A1 | 101 00001 | 011101 1010 | 100010 1010 |
| D2.5 | A2 | 101 00010 | 101101 1010 | 010010 1010 |
| D3.5 | A3 | 101 00011 | 110001 1010 | 110001 1010 |
| D4.5 | A4 | 101 00100 | 110101 1010 | 001010 1010 |
| D5.5 | A5 | 101 00101 | 101001 1010 | 101001 1010 |
| D6.5 | A6 | 101 00110 | 011001 1010 | 011001 1010 |
| D7.5 | A7 | 101 00111 | 111000 1010 | 000111 1010 |
| D8.5 | A8 | 101 01000 | 111001 1010 | 000110 1010 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1226

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D9.5 | A9 | 101 01001 | 100101 1010 | 100101 1010 |
| D10.5 | AA | 101 01010 | 010101 1010 | 010101 1010 |
| D11.5 | AB | 101 01011 | 110100 1010 | 110100 1010 |
| D12.5 | AC | 101 01100 | 001101 1010 | 001101 1010 |
| D13.5 | AD | 101 01101 | 101100 1010 | 101100 1010 |
| D14.5 | AE | 101 01110 | 011100 1010 | 011100 1010 |
| D15.5 | AF | 101 01111 | 010111 1010 | 101000 1010 |
| D16.5 | B0 | 101 10000 | 011011 1010 | 100100 1010 |
| D17.5 | B1 | 101 10001 | 100011 1010 | 100011 1010 |
| D18.5 | B2 | 101 10010 | 010011 1010 | 010011 1010 |
| D19.5 | B3 | 101 10011 | 110010 1010 | 110010 1010 |
| D20.5 | B4 | 101 10100 | 001011 1010 | 001011 1010 |
| D21.5 | B5 | 101 10101 | 101010 1010 | 101010 1010 |
| D22.5 | B6 | 101 10110 | 011010 1010 | 011010 1010 |
| D23.5 | B7 | 101 10111 | 111010 1010 | 000101 1010 |
| D24.5 | B8 | 101 11000 | 110011 1010 | 001100 1010 |
| D25.5 | B9 | 101 11001 | 100110 1010 | 100110 1010 |
| D26.5 | BA | 101 11010 | 010110 1010 | 010110 1010 |
| D27.5 | BB | 101 11011 | 110110 1010 | 001001 1010 |
| D28.5 | BC | 101 11100 | 001110 1010 | 001110 1010 |
| D29.5 | BD | 101 11101 | 101110 1010 | 010001 1010 |
| D30.5 | BE | 101 11110 | 011110 1010 | 100001 1010 |
| D31.5 | BF | 101 11111 | 101011 1010 | 010100 1010 |
| D0.6 | C0 | 110 00000 | 100111 0110 | 011000 0110 |
| D1.6 | C1 | 110 00001 | 011101 0110 | 100010 0110 |
| D2.6 | C2 | 110 00010 | 101101 0110 | 010010 0110 |
| D3.6 | C3 | 110 00011 | 110001 0110 | 110001 0110 |
| D4.6 | C4 | 110 00100 | 110101 0110 | 001010 0110 |
| D5.6 | C5 | 110 00101 | 101001 0110 | 101001 0110 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1227

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D6.6 | C6 | 110 00110 | 011001 0110 | 011001 0110 |
| D7.6 | C7 | 110 00111 | 111000 0110 | 000111 0110 |
| D8.6 | C8 | 110 01000 | 111001 0110 | 000110 0110 |
| D9.6 | C9 | 110 01001 | 100101 0110 | 100101 0110 |
| D10.6 | CA | 110 01010 | 010101 0110 | 010101 0110 |
| D11.6 | CB | 110 01011 | 110100 0110 | 110100 0110 |
| D12.6 | CC | 110 01100 | 001101 0110 | 001101 0110 |
| D13.6 | CD | 110 01101 | 101100 0110 | 101100 0110 |
| D14.6 | CE | 110 01110 | 011100 0110 | 011100 0110 |
| D15.6 | CF | 110 01111 | 010111 0110 | 101000 0110 |
| D16.6 | D0 | 110 10000 | 011011 0110 | 100100 0110 |
| D17.6 | D1 | 110 10001 | 100011 0110 | 100011 0110 |
| D18.6 | D2 | 110 10010 | 010011 0110 | 010011 0110 |
| D19.6 | D3 | 110 10011 | 110010 0110 | 110010 0110 |
| D20.6 | D4 | 110 10100 | 001011 0110 | 001011 0110 |
| D21.6 | D5 | 110 10101 | 101010 0110 | 101010 0110 |
| D22.6 | D6 | 110 10110 | 011010 0110 | 011010 0110 |
| D23.6 | D7 | 110 10111 | 111010 0110 | 000101 0110 |
| D24.6 | D8 | 110 11000 | 110011 0110 | 001100 0110 |
| D25.6 | D9 | 110 11001 | 100110 0110 | 100110 0110 |
| D26.6 | DA | 110 11010 | 010110 0110 | 010110 0110 |
| D27.6 | DB | 110 11011 | 110110 0110 | 001001 0110 |
| D28.6 | DC | 110 11100 | 001110 0110 | 001110 0110 |
| D29.6 | DD | 110 11101 | 101110 0110 | 010001 0110 |
| D30.6 | DE | 110 11110 | 011110 0110 | 100001 0110 |
| D31.6 | DF | 110 11111 | 101011 0110 | 010100 0110 |
| D0.7 | E0 | 111 00000 | 100111 0001 | 011000 1110 |
| D1.7 | E1 | 111 00001 | 011101 0001 | 100010 1110 |
| D2.7 | E2 | 111 00010 | 101101 0001 | 010010 1110 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1228

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| D3.7 | E3 | 111 00011 | 110001 1110 | 110001 0001 |
| D4.7 | E4 | 111 00100 | 110101 0001 | 001010 1110 |
| D5.7 | E5 | 111 00101 | 101001 1110 | 101001 0001 |
| D6.7 | E6 | 111 00110 | 011001 1110 | 011001 0001 |
| D7.7 | E7 | 111 00111 | 111000 1110 | 000111 0001 |
| D8.7 | E8 | 111 01000 | 111001 0001 | 000110 1110 |
| D9.7 | E9 | 111 01001 | 100101 1110 | 100101 0001 |
| D10.7 | EA | 111 01010 | 010101 1110 | 010101 0001 |
| D11.7 | EB | 111 01011 | 110100 1110 | 110100 1000 |
| D12.7 | EC | 111 01100 | 001101 1110 | 001101 0001 |
| D13.7 | ED | 111 01101 | 101100 1110 | 101100 1000 |
| D14.7 | EE | 111 01110 | 011100 1110 | 011100 1000 |
| D15.7 | EF | 111 01111 | 010111 0001 | 101000 1110 |
| D16.7 | F0 | 111 10000 | 011011 0001 | 100100 1110 |
| D17.7 | F1 | 111 10001 | 100011 0111 | 100011 0001 |
| D18.7 | F2 | 111 10010 | 010011 0111 | 010011 0001 |
| D19.7 | F3 | 111 10011 | 110010 1110 | 110010 0001 |
| D20.7 | F4 | 111 10100 | 001011 0111 | 001011 0001 |
| D21.7 | F5 | 111 10101 | 101010 1110 | 101010 0001 |
| D22.7 | F6 | 111 10110 | 011010 1110 | 011010 0001 |
| D23.7 | F7 | 111 10111 | 111010 0001 | 000101 1110 |
| D24.7 | F8 | 111 11000 | 110011 0001 | 001100 1110 |
| D25.7 | F9 | 111 11001 | 100110 1110 | 100110 0001 |
| D26.7 | FA | 111 11010 | 010110 1110 | 010110 0001 |
| D27.7 | FB | 111 11011 | 110110 0001 | 001001 1110 |
| D28.7 | FC | 111 11100 | 001110 1110 | 001110 0001 |
| D29.7 | FD | 111 11101 | 101110 0001 | 010001 1110 |
| D30.7 | FE | 111 11110 | 011110 0001 | 100001 1110 |
| D31.7 | FF | 111 11111 | 101011 0001 | 010100 1110 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1229

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Table B-2 8b/10b Special Character Symbol Codes

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Data | Data Byte | Bits | Current RD- | Current RD+ |
| Byte | Value | HGF EDCBA | abcdei fghj | abcdei fghj |
| Name | (hex) | (binary) | (binary) | (binary) |
| K28.0 | 1C | 000 11100 | 001111 0100 | 110000 1011 |
| K28.1 | 3C | 001 11100 | 001111 1001 | 110000 0110 |
| K28.2 | 5C | 010 11100 | 001111 0101 | 110000 1010 |
| K28.3 | 7C | 011 11100 | 001111 0011 | 110000 1100 |
| K28.4 | 9C | 100 11100 | 001111 0010 | 110000 1101 |
| K28.5 | BC | 101 11100 | 001111 1010 | 110000 0101 |
| K28.6 | DC | 110 11100 | 001111 0110 | 110000 1001 |
| K28.7 | FC | 111 11100 | 001111 1000 | 110000 0111 |
| K23.7 | F7 | 111 10111 | 111010 1000 | 000101 0111 |
| K27.7 | FB | 111 11011 | 110110 1000 | 001001 0111 |
| K29.7 | FD | 111 11101 | 101110 1000 | 010001 0111 |
| K30.7 | FE | 111 11110 | 011110 1000 | 100001 0111 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1230

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Physical Layer Appendix**

**C.1 8b/10b Data Scrambling Example**

**C.**

The following subroutines encode and decode an 8-bit value contained in “inbyte” with the LFSR. This is presented as one example only; there are many ways to obtain the proper output. This

example demonstrates how to advance the LFSR eight times in one operation and how to XOR the data in one operation. Many other implementations are possible but they must all produce the

same output as that shown here.

The following algorithm uses the “C” programming language conventions, where “<<” and “>>” represent the shift left and shift right operators, “>” is the compare greater than operator, and “^” is the exclusive or operator, and “&” is the logical “AND” operator.

/\*

this routine implements the serial descrambling algorithm in parallel form

for the LSFR polynomial: x^16+x^5+x^4+x^3+1

this advances the LSFR 8 bits every time it is called

this requires fewer than 25 xor gates to implement (with a static register)

The XOR required to advance 8 bits/clock is:

bit 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

8 9 10 11 12 13 14 15 0 1 2 3 4 5 6 7

8 9 10 11 12 13 14 15

8 9 10 11 12 13 14 15

8 9 10 11 12 13 14 15

The serial data is just the reverse of the upper byte:

bit 0 1 2 3 4 5 6 7

15 14 13 12 11 10 9 8

\*/

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

int scramble\_byte(int inbyte)

{

static int scrambit[16];

static int bit[16];

static int bit\_out[16];

static unsigned short lfsr = 0xffff; // 16 bit short for polynomial

int i, outbyte;

if (inbyte == COMMA) // if this is a comma

{

lfsr = 0xffff; // reset the LFSR

return (COMMA); // and return the same data

}

if (inbyte == SKIP) // don't advance or encode on skip

return (SKIP);

for (i=0; i<16;i++) // convert LFSR to bit array for legibility

bit[i] = (lfsr >> i) & 1;

for (i=0; i<8; i++) // convert byte to be scrambled for legibility

scrambit[i] = (inbyte >> i) & 1;

// apply the xor to the data

if (! (inbyte & 0x100) &&

! (TrainingSequence == TRUE))

{

// if not a KCODE, scramble the data

// and if not in the middle of

// a training sequence

scrambit[0] ^= bit[15]; scrambit[1] ^= bit[14]; scrambit[2] ^= bit[13]; scrambit[3] ^= bit[12]; scrambit[4] ^= bit[11]; scrambit[5] ^= bit[10]; scrambit[6] ^= bit[9]; scrambit[7] ^= bit[8];

}

|  |  |  |  |
| --- | --- | --- | --- |
| // Now advance the LFSR | 8 serial clocks | |  |
| bit\_out[ 0] = bit[ 8];  bit\_out[ 1] = bit[ 9];  bit\_out[ 2] = bit[10]; |  |  |  |
| bit\_out[ 3] = bit[11] ^ | bit[ 8]; |  |  |
| bit\_out[ 4] = bit[12] ^ | bit[ 9] ^ | bit[ 8]; |  |
| bit\_out[ 5] = bit[13] ^ | bit[10] ^ | bit[ 9] ^ | bit[ 8]; |
| bit\_out[ 6] = bit[14] ^ | bit[11] ^ | bit[10] ^ | bit[ 9]; |
| bit\_out[ 7] = bit[15] ^ | bit[12] ^ | bit[11] ^ | bit[10]; |
| bit\_out[ 8] = bit[ 0] ^ | bit[13] ^ | bit[12] ^ | bit[11]; |
| bit\_out[ 9] = bit[ 1] ^ | bit[14] ^ | bit[13] ^ | bit[12]; |
| bit\_out[10] = bit[ 2] ^ | bit[15] ^ | bit[14] ^ | bit[13]; |
| bit\_out[11] = bit[ 3] ^ | bit[15] ^ | bit[14]; |  |
| bit\_out[12] = bit[ 4] ^ | bit[15]; |  |  |
| bit\_out[13] = bit[ 5]; bit\_out[14] = bit[ 6]; bit\_out[15] = bit[ 7];  lfsr = 0; |  |  |  |
| for (i=0; i <16; i++) | // convert the LFSR back to an integer | | |
| lfsr += (bit\_out[i] | << i); |  |  |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1232

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

outbyte = 0;

for (i= 0; i<8; i++) // convert data back to an integer

outbyte += (scrambit[i] << i);

return outbyte;

}

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

/\* NOTE THAT THE DESCRAMBLE ROUTINE IS IDENTICAL TO THE SCRAMBLE ROUTINE

this routine implements the serial descrambling algorithm in parallel form this advances the lfsr 8 bits every time it is called

this uses fewer than 25 xor gates to implement (with a static register)

The XOR tree is the same as the scrambling routine

\*/

int unscramble\_byte(int inbyte)

{

static int descrambit[8];

static int bit[16];

static int bit\_out[16];

static unsigned short lfsr = 0xffff; // 16 bit short for polynomial

int outbyte, i;

if (inbyte == COMMA) // if this is a comma

{

lfsr = 0xffff; // reset the LFSR

return (COMMA); // and return the same data

}

if (inbyte == SKIP) // don't advance or encode on skip

return (SKIP);

for (i=0; i<16;i++) // convert the LFSR to bit array for legibility

bit[i] = (lfsr >> i) & 1;

for (i=0; i<8; i++) // convert byte to be de-scrambled for legibility

descrambit[i] = (inbyte >> i) & 1;

// apply the xor to the data

if (! (inbyte & 0x100) && // if not a KCODE, scramble the data

! (TrainingSequence == TRUE)) // and if not in the middle of

{ // a training sequence

descrambit[0] ^= bit[15]; descrambit[1] ^= bit[14]; descrambit[2] ^= bit[13]; descrambit[3] ^= bit[12]; descrambit[4] ^= bit[11]; descrambit[5] ^= bit[10]; descrambit[6] ^= bit[9]; descrambit[7] ^= bit[8];

}

// Now advance the LFSR 8 serial clocks

bit\_out[ 0] = bit[ 8];

bit\_out[ 1] = bit[ 9];

bit\_out[ 2] = bit[10];

bit\_out[ 3] = bit[11] ^ bit[ 8];

bit\_out[ 4] = bit[12] ^ bit[ 9] ^ bit[ 8];

bit\_out[ 5] = bit[13] ^ bit[10] ^ bit[ 9] ^ bit[ 8];

bit\_out[ 6] = bit[14] ^ bit[11] ^ bit[10] ^ bit[ 9];

bit\_out[ 7] = bit[15] ^ bit[12] ^ bit[11] ^ bit[10];

bit\_out[ 8] = bit[ 0] ^ bit[13] ^ bit[12] ^ bit[11];

bit\_out[ 9] = bit[ 1] ^ bit[14] ^ bit[13] ^ bit[12];

bit\_out[10] = bit[ 2] ^ bit[15] ^ bit[14] ^ bit[13];

bit\_out[11] = bit[ 3] ^ bit[15] ^ bit[14];

bit\_out[12] = bit[ 4] ^ bit[15];

bit\_out[13] = bit[ 5];

bit\_out[14] = bit[ 6];

bit\_out[15] = bit[ 7];

lfsr = 0;

for (i=0; i <16; i++) // convert the LFSR back to an integer

lfsr += (bit\_out[i] << i);

outbyte = 0;

for (i= 0; i<8; i++) // convert data back to an integer

outbyte += (descrambit[i] << i);

return outbyte;

}

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)The initial 16-bit values of the LFSR for the first 128 LFSR advances following a reset are listed below:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 0, 8 | 1, 9 | 2, A | 3, B | 4, C | 5, D | 6, E | 7, F |
| 00 | FFFF | E817 | 0328 | 284B | 4DE8 | E755 | 404F | 4140 |
| 08 | 4E79 | 761E | 1466 | 6574 | 7DBD | B6E5 | FDA6 | B165 |
| 10 | 7D09 | 02E5 | E572 | 673D | 34CF | CB54 | 4743 | 4DEF |
| 18 | E055 | 40E0 | EE40 | 54BE | B334 | 2C7B | 7D0C | 07E5 |
| 20 | E5AF | BA3D | 248A | 8DC4 | D995 | 85A1 | BD5D | 4425 |
| 28 | 2BA4 | A2A3 | B8D2 | CBF8 | EB43 | 5763 | 6E7F | 773E |
| 30 | 345F | 5B54 | 5853 | 5F18 | 14B7 | B474 | 6CD4 | DC4C |
| 38 | 5C7C | 70FC | F6F0 | E6E6 | F376 | 603B | 3260 | 64C2 |
| 40 | CB84 | 9743 | 5CBF | B3FC | E47B | 6E04 | 0C3E | 3F2C |
| 48 | 29D7 | D1D1 | C069 | 7BC0 | CB73 | 6043 | 4A60 | 6FFA |
| 50 | F207 | 1102 | 01A9 | A939 | 2351 | 566B | 6646 | 4FF6 |
| 58 | F927 | 3081 | 85B0 | AC5D | 478C | 82EF | F3F2 | E43B |
| 60 | 2E04 | 027E | 7E72 | 79AE | A501 | 1A7D | 7F2A | 2197 |
| 68 | 9019 | 0610 | 1096 | 9590 | 8FCD | D0E7 | F650 | 46E6 |
| 70 | E8D6 | C228 | 3AB2 | B70A | 129F | 9CE2 | FC3C | 2B5C |
| 78 | 5AA3 | AF6A | 70C7 | CDF0 | E3D5 | C0AB | B9C0 | D9C1 |

An 8-bit value of 0 repeatedly encoded with the LFSR after reset produces the following consecutive 8-bit values:

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F |
| 00 | FF | 17 | C0 | 14 | B2 | E7 | 02 | 82 | 72 | 6E | 28 | A6 | BE | 6D | BF | 8D |
| 10 | BE | 40 | A7 | E6 | 2C | D3 | E2 | B2 | 07 | 02 | 77 | 2A | CD | 34 | BE | E0 |
| 20 | A7 | 5D | 24 | B1 | 9B | A1 | BD | 22 | D4 | 45 | 1D | D3 | D7 | EA | 76 | EE |
| 30 | 2C | DA | 1A | FA | 28 | 2D | 36 | 3B | 3A | 0E | 6F | 67 | CF | 06 | 4C | 26 |
| 40 | D3 | E9 | 3A | CD | 27 | 76 | 30 | FC | 94 | 8B | 03 | DE | D3 | 06 | 52 | F6 |
| 50 | 4F | 88 | 80 | 95 | C4 | 6A | 66 | F2 | 9F | 0C | A1 | 35 | E2 | 41 | CF | 27 |
| 60 | 74 | 40 | 7E | 9E | A5 | 58 | FE | 84 | 09 | 60 | 08 | A9 | F1 | 0B | 6F | 62 |
| 70 | 17 | 43 | 5C | ED | 48 | 39 | 3F | D4 | 5A | F5 | 0E | B3 | C7 | 03 | 9D | 9B |
| 80 | 8B | 0D | 8E | 5C | 33 | 98 | 77 | AE | 2D | AC | 0B | 3E | DA | 0B | 42 | 7A |
| 90 | 7C | D1 | CF | A8 | 1C | 12 | EE | 41 | C2 | 3F | 38 | 7A | 0D | 69 | F4 | 01 |
| A0 | DA | 31 | 72 | C5 | A0 | D7 | 93 | 0E | DC | AF | A4 | 55 | E7 | F0 | 72 | 16 |
| B0 | 68 | D5 | 38 | 84 | DD | 00 | CD | 18 | 9E | CA | 30 | 59 | 4C | 75 | 1B | 77 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1235

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F |
| C0 | 31 | C5 | ED | CF | 91 | 64 | 6E | 3D | FE | E8 | 29 | 04 | CF | 6C | FC | C4 |
| D0 | 0B | 5E | DA | 62 | BA | 5B | AB | DF | 59 | B7 | 7D | 37 | 5E | E3 | 1A | C6 |
| E0 | 88 | 14 | F5 | 4F | 8B | C8 | 56 | CB | D3 | 10 | 42 | 63 | 04 | 8A | B4 | F7 |
| F0 | 84 | 01 | A0 | 01 | 83 | 49 | 67 | EE | 3E | 2A | 8B | A4 | 76 | AF | 14 | D5 |
| 100 | 4F | AC | 60 | B6 | 79 | D6 | 62 | B7 | 43 | E7 | E5 | 2A | 40 | 2C | 6E | 7A |
| 110 | 56 | 61 | 63 | 20 | 6A | 97 | 4A | 38 | 05 | E5 | DD | 68 | 0D | 78 | 4C | 53 |
| 120 | 8B | D6 | 86 | 57 | B2 | AA | 1A | 80 | 18 | DC | BA | FC | 03 | A3 | 4B | 30 |

At 2.5 GT/s, scrambling produces the power spectrum (in the 10-bit domain) shown in [Figure C-1 .](#bookmark32)

-80.00 -90.00 -100.00 -110.00 -120.00 -130.00 -140.00

Power (dBm/Hz)

![](data:image/png;base64,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)

0 1000 2000 3000 4000 5000 6000 7000 8000 9000 10000

Frequency (MHz)

OM14292A

Figure C-1 Scrambling Spectrum at 2.5 GT/s for Data Value of0

**C.2 128b/130b Data Scrambling Example**

The following subroutines illustrate how calculate the next value of the 128b/130b scrambling LFSR and how to scramble (or descramble) an 8-bit value, both given the current value of the LFSR.

This is presented as one example only; there are many ways to obtain the proper output. This example demonstrates how to advance the LFSR eight times in one operation and how to XOR the data in one operation. Many other

implementations are possible but they must all produce the same output as that shown here.

The following algorithm uses the “C” programming language conventions, where “<<” and “>>” represent the shift left and shift right operators, “^” is the exclusive or operator, and “|=” is the assignment by bitwise or operator.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

#include <stdio.h>

// "Set Bit" - Sets bit number "bit" of "var" to the value "val". Bit "bit" of "var" must start cleared.

#define SB(var,bit,val) var |= (val & 1) << bit

// "Get Bit" - Returns the value of bit number "bit" of "var".

#define GB(var,bit) ((var >> bit) & 1)

// Function to advance the LFSR value by 8 bits, given the current LFSR value

unsigned long int calc\_next\_lfsr(unsigned long int lfsr) {

unsigned long int next\_lfsr = 0;

SB(next\_lfsr,22, GB(lfsr,14) ^ GB(lfsr,16) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(next\_lfsr,21, GB(lfsr,13) ^ GB(lfsr,15) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,20) ^ GB(lfsr,21));

SB(next\_lfsr,20, GB(lfsr,12) ^ GB(lfsr,19) ^ GB(lfsr,21));

SB(next\_lfsr,19, GB(lfsr,11) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(next\_lfsr,18, GB(lfsr,10) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,21));

SB(next\_lfsr,17, GB(lfsr, 9) ^ GB(lfsr,16) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(next\_lfsr,16, GB(lfsr, 8) ^ GB(lfsr,15) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(next\_lfsr,15, GB(lfsr, 7) ^ GB(lfsr,22));

SB(next\_lfsr,14, GB(lfsr, 6) ^ GB(lfsr,21));

SB(next\_lfsr,13, GB(lfsr, 5) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(next\_lfsr,12, GB(lfsr, 4) ^ GB(lfsr,19) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(next\_lfsr,11, GB(lfsr, 3) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(next\_lfsr,10, GB(lfsr, 2) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,20) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(next\_lfsr, 9, GB(lfsr, 1) ^ GB(lfsr,16) ^ GB(lfsr,18) ^ GB(lfsr,19) ^ GB(lfsr,20) ^ GB(lfsr,21));

SB(next\_lfsr, 8, GB(lfsr, 0) ^ GB(lfsr,15) ^ GB(lfsr,17) ^ GB(lfsr,18) ^ GB(lfsr,19) ^ GB(lfsr,20));

SB(next\_lfsr, 7, GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,20) ^ GB(lfsr,21));

SB(next\_lfsr, 6, GB(lfsr,16) ^ GB(lfsr,18) ^ GB(lfsr,19) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(next\_lfsr, 5, GB(lfsr,15) ^ GB(lfsr,17) ^ GB(lfsr,18) ^ GB(lfsr,19) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(next\_lfsr, 4, GB(lfsr,17));

SB(next\_lfsr, 3, GB(lfsr,16));

SB(next\_lfsr, 2, GB(lfsr,15) ^ GB(lfsr,22));

SB(next\_lfsr, 1, GB(lfsr,16) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(next\_lfsr, 0, GB(lfsr,15) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,21) ^ GB(lfsr,22));

return(next\_lfsr);

}

// Function to scramble a byte, given the current LFSR value

unsigned char scramble\_data(unsigned long lfsr, unsigned char data\_in) {

unsigned char data\_out = 0;

SB(data\_out, 7, GB(data\_in,7) ^ GB(lfsr,15) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,21) ^ GB(lfsr,22));

SB(data\_out, 6, GB(data\_in,6) ^ GB(lfsr,16) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(data\_out, 5, GB(data\_in,5) ^ GB(lfsr,17) ^ GB(lfsr,19) ^ GB(lfsr,21));

SB(data\_out, 4, GB(data\_in,4) ^ GB(lfsr,18) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(data\_out, 3, GB(data\_in,3) ^ GB(lfsr,19) ^ GB(lfsr,21));

SB(data\_out, 2, GB(data\_in,2) ^ GB(lfsr,20) ^ GB(lfsr,22));

SB(data\_out, 1, GB(data\_in,1) ^ GB(lfsr,21));

SB(data\_out, 0, GB(data\_in,0) ^ GB(lfsr,22));

return(data\_out);

}

// Example of LFSR and scrambled data “0” sequence for Lane 0

main() {

unsigned long lfsr = 0x1DBFBC; // Lane 0 reset LFSR value

unsigned char unscrambled\_data = 0x00;

int i;

printf("Iteration LFSR Next LFSR Scrambled Data\n");

printf("- - - -\n");

for (i = 0; i < 128; i++) {

unsigned char scrambled\_data = scramble\_data(lfsr,unscrambled\_data);

unsigned long next\_lfsr = calc\_next\_lfsr(lfsr);

printf("%3d %06X %06X %02X\n", i, lfsr, next\_lfsr, scrambled\_data);

lfsr = next\_lfsr;

}

}

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)The initial 23-bit values of the LFSR for the first 128 LFSR advances for an 8-bit quantity following a reset for Lane 0 are listed below (ordered left to right, top to bottom):

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 0, 8 | 1, 9 | 2, A | 3, B | 4, C | 5, D | 6, E | 7, F |
| 00 | 1DBFBC | 498C2E | 1186E9 | 0FC5AD | 7CB75D | 3D8DA2 | 0ECC8F | 379717 |
| 08 | 046BDF | 21D462 | 423FCE | 5177D6 | 1447EF | 67CBA0 | 794F7A | 6CA2AF |
| 10 | 425060 | 3ED9D6 | 3DBF74 | 3C1A8F | 7AE2E0 | 073E71 | 137D99 | 70B139 |
| 18 | 44F521 | 559720 | 1FBBA8 | 689D9F | 376B02 | 597FFA | 297C0E | 7E450A |
| 20 | 4BDE36 | 669B58 | 6BB530 | 78C3F9 | 0322C0 | 45C7FB | 254F6A | 323D89 |
| 28 | 07FDD2 | 71DFBC | 68726B | 799E27 | 1CFE8A | 4AB864 | 42CB12 | 04AAF3 |
| 30 | 41F947 | 51F808 | 3A98CA | 36A816 | 796895 | 4B4DAF | 54037D | 68E5C7 |
| 38 | 4F3302 | 60A51F | 3AFCE3 | 528116 | 248131 | 1F65E6 | 17D2BA | 34987E |
| 40 | 6C0524 | 44DA45 | 7AF320 | 16FE71 | 5A5134 | 60B5F5 | 2A16E3 | 73AFF1 |
| 48 | 3D3ADA | 18B5AA | 4B9306 | 2BAB58 | 2D179E | 5FDE68 | 46E1F8 | 644B91 |
| 50 | 3F78A4 | 7FCE1B | 23CC59 | 7F017F | 4DA97C | 7EDF8B | 705E13 | 0ADE04 |
| 58 | 6F1775 | 318CBE | 70CC0C | 39C021 | 0944ED | 33F8AB | 21DCBD | 4AE0CE |
| 60 | 1A6112 | 1B2F92 | 17ADD8 | 4BFA7E | 42D358 | 1CE0F3 | 54C164 | 0BFDE2 |
| 68 | 0EF33F | 082717 | 1200E1 | 4FCB73 | 39D53A | 1C5FED | 4ADE41 | 24EE12 |
| 70 | 7046E6 | 122B04 | 642E73 | 5A9AA4 | 0A24D0 | 34C250 | 362B24 | 5B5BB0 |
| 78 | 2833BF | 73F640 | 648BDA | 5E3281 | 490B97 | 373ECC | 0CB1FA | 6FE7A6 |

An 8-bit value of 0x00 repeatedly encoded with the LFSR after reset for Lane 0 produces the following consecutive 8-bit values (ordered left to right, top to bottom):

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F |
| 00 | 6C | BD | 94 | 98 | 53 | C6 | D8 | CE | 50 | 6A | 75 | C1 | 04 | 4F | C3 | 07 |
| 10 | 75 | 26 | C6 | 06 | A3 | B0 | B4 | AB | 05 | 11 | CC | 57 | 4E | 69 | 42 | 73 |
| 20 | 1D | 0F | B7 | 03 | E0 | 45 | BA | 5E | 30 | EB | D7 | 43 | 2C | 5D | F5 | D0 |
| 30 | 15 | 41 | 76 | 8E | C3 | 9D | D1 | 57 | CD | FF | 76 | A1 | 7A | 4C | 64 | 2E |
| 40 | 87 | 05 | A3 | 24 | 89 | FF | A2 | 4B | 46 | 7C | 1D | 62 | 12 | 19 | A5 | 2F |
| 50 | E6 | B3 | CA | 33 | ED | F3 | 2B | 88 | 67 | 3E | AB | 96 | E8 | 9E | 6A | 5D |
| 60 | 5C | 1C | 64 | 1D | F5 | 2C | 51 | C8 | D8 | A8 | F4 | 4D | 96 | AC | 5D | 7A |
| 70 | 2B | F4 | 2F | 09 | 08 | 2E | 0E | C9 | 02 | 4B | AF | D9 | 3D | 4E | 78 | E7 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Request Dependencies**

This specification does not specify the rules governing the creation of resource dependencies between TLPs using different Traffic Classes. Dependencies between packets in different Traffic Classes can create potential deadlock if devices make different assumptions about what is

**D.**

allowed and what is not. Dependencies can be created when a packet is forwarded (transmitted verbatim) or translated (transmitted with modification) from an input Port to an output Port.

Resource dependencies are created when received packets are forwarded/translated on the

same or a different Link. Due to the fact that the forwarding/translating device has finite buffer resources this behavior creates a dependency between the ability to receive a packet and the ability to transmit a packet (in potentially a

different VC or sub-channel).

The following notation is used to create a framework to enumerate the possibilities:

X(m) → Y(n) This means:

• a request in sub-channel*X*(TC = m) is forwarded/translated in sub-channel *Y*(TC = n).

• n and m are between 0-7.

• *X* and *Y* are either P (Posted Request), N (Non-Posted Request), or C (Completion).

The list of possible dependencies is: P(m) → P(n)

P(m) → N(n) P(m) → C(n) N(m) → P(n) N(m) → N(n) N(m) → C(n) C(m) → P(n) C(m) → N(n) C(m) → C(n)

For a given system, each of these dependencies needs to be classified as legal or illegal for each of the following cases:

• Root Port forwarding to own Link.

• Root Port forwarding to different Root Port’s Link.

• Endpoint or Bridge forwarding to own Link.

A Switch is not allowed to modify the TLPs that flow through it, but must ensure complete independence of resources assigned to separate VCs. System software must comprehend the system dependency rules when configuring TC/VC mapping throughout the system.

One possible legal mapping is:

|  |  |  |  |
| --- | --- | --- | --- |
|  | RC  (Same Port) | RC  (Different Port) | Endpoint |
| P(m) → P(n) | m ≤ n | m ≤ n | m < n |
| P(m) → N(n) | m < n | m < n | m < n |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |
| --- | --- | --- | --- |
|  | RC  (Same Port) | RC  (Different Port) | Endpoint |
| P(m) → C(n) | illegal | illegal | illegal |
| N(m) → P(n) | m < n | m < n | m < n |
| N(m) → N(n) | m ≤ n | m ≤ n | m < n |
| N(m) → C(n) | m = n | m = n | m = n |
| C(m) → P(n) | illegal | illegal | illegal |
| C(m) → N(n) | illegal | illegal | illegal |
| C(m) → C(n) | m ≥ n | m ≥ n | m > n |

Note that this discussion only deals with avoiding the deadlock caused by the creation of resource dependencies. It does

not deal with the additional livelock issues (or lack of forward progress) caused by the system’s Virtual Channel arbitration policies.

Some of these potential dependencies are illegal or unreachable:

• P(m) → P(n), N(m) → N(n)

。 m = n - This case is illegal and will lead to deadlock, except when a Request is being forwarded from one Port to another of a Switch or Root Complex.

。 m ≠ n - See discussion below.

• P(m) → N(n)

。 m = n - This case is illegal and will lead to deadlock. 。 m ≠ n - See discussion below.

• N(m) → P(n) - See discussion below.

• P(m) → C(n) - This case is illegal and will lead to deadlock.

• N(m) → C(n)

。 m = n - This case occurs during the normal servicing of a non-posted request by either a root complex or an endpoint.

。 m ≠ n - This case is unreachable and should never happen. Completions always use the same TC as the corresponding request.

• C(m) → P(n), C(m) → N(n) - These cases are unreachable and should never happen due to the fact that completion buffers must be preallocated.

• C(m) → C(n)

。 m = n - This case is illegal and will lead to deadlock, except when a Completion is being forwarded from one Port to another of a Switch or Root Complex.

。 m ≠ n - This case will occur if N(n)→N(m) dependencies are allowed.

Other potential dependencies may be legal when comprehended as part of a specific usage model. For example, these cases:

P(m) → P(n), N(m) → N(n), P(m) → N(n), N(m) → P(n) where m ≠ n

might exist where a device services incoming requests by issuing modified versions of those requests using a

different Traffic Class (for example, remapping the first requests address and generating the new request with the

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

resulting address). In these cases, suitable rules must be applied to prevent circular dependencies that would lead to deadlock or livelock.

Examples of devices that may find the above mappings useful:

• Bridges to complex protocols that require state to be save/restored to/from host memory, i.e., PCI Express to Infiniband bridges.

• Messaging engines that must do address translation based upon page tables stored in host memory.

• UMA graphics devices that store their frame buffer in host memory.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**ID-Based Ordering Usage**

**E.1 Introduction**

**E.**

ID-Based Ordering (IDO) is a mechanism that permits certain ordering restrictions to be relaxed as a means to improve performance. IDO permits certain TLPs to pass other TLPs in cases where

otherwise such passing would be forbidden. The passing permitted by IDO is not required for proper operation (e.g., deadlock avoidance); it is only a means of improving performance.

For discussing IDO, it’s useful to introduce the concept of a “TLP stream”, which is a set of TLPs that all have the same originator.173 For several important cases where TLP passing is normally forbidden, IDO permits such passing to occur if the TLPs belong to different TLP streams.

Root Port

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Root Complex  Root Port B   |  | | --- | | TA | | | | |  | | --- | | RCiEP 1 |  |  | | --- | | RCiEP 0 | |
|  | A |
|  |  |  |  |  | |

Switch

|  |  |  |  |
| --- | --- | --- | --- |
| MFD X | | | |
| |  | | --- | | F0 | | |  | | --- | | F1 | | |  | | --- | | F2 | |  |

|  |  |
| --- | --- |
| Device Y   |  | | --- | | F0 | |

|  |  |  |  |
| --- | --- | --- | --- |
| MFD Z | | | |
| |  | | --- | | F0 | | |  | | --- | | F1 | | |  | | --- | | F2 | |  |

A-0757A

Figure E-1 Reference Topology for IDO Use

[Figure E-1](#bookmark33)shows a reference topology. The reference topology is not intended to discourage the use of IDO with other topologies, but rather to provide specific examples for discussion.

Devices X and Z areMulti-Function Devices (MFDs); device Y is a single-Function device. The RCiEPs are Root Complex Integrated Endpoint Functions, and might or might not be part of the same Device. We will assume that one or more Functions are using the Translation Agent (TA) in the Root Complex (RC).

Referring to the ordering table and descriptions inSection 2.4.1, having the IDO bit set in a Posted Request, Non-Posted Request, or Completion TLP permits that TLP to pass a Posted Request TLP if the two TLPs belong to different TLP

streams. In the following examples, DMAR and DMAW stand for Direct Memory Access Read and Write; PIOR and PIOW stand for Programmed I/O Read and Write.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

173. That is, the Requester IDs of Requests and the Completer IDs of Completions are all the same.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**E.2 Potential Benefits with IDO Use**

Here are some example potential benefits that are envisioned with IDO use. Generally, IDO provides the most benefit

when multiple TLP streams share a common Link and that Link becomes congested, either due to high utilization or due to temporary lack of Flow Control (FC) credit.

**E.2.1 Benefits for MFD/RP Direct Connect**

Here are some examples in the context of traffic between MFDX and the RC in [Figure E-1 .](#bookmark33)

• Posted Request passing another Posted Request: when a DMAW from F0 is stalled due to an TA miss, if IDO is set for a DMAW from F1, it is permitted within the RC for this DMAW to pass the stalled DMAW from F0.

• Non-Posted Request passing a Posted Request: when a DMAW from F0 is stalled due to an TA miss, if IDO is set for a DMAR Request from F1, it is permitted within the RC for this DMAR Request to pass the stalled DMAW from F0.

• Completion passing a Posted Request: when a DMAW from F0 is stalled due to an TA miss, if IDO is set for a

PIOR Completion from F1, it is permitted within the RC for this PIOR Completion to pass the stalled DMAW from F0.

**E.2.2 Benefits for Switched Environments**

Here are some examples in the context of traffic within the Switch in [Figure E-1 .](#bookmark33)

• Non-Posted Request passing a Posted Request: when a DMAW from Device Y is stalled within the Switch due to a lack of FC credit from Root Port B, if IDO is set for a DMAR Request from MFD Z, it is permitted within the

Switch for this DMAR Request to pass the stalled DMAW from Device Y. The same also holds for a DMAR Request from one Function in MFD Z passing a stalled DMAW from a different Function in MFD Z.

• Completion passing a Posted Request: when a DMAW from Device Y is stalled within the Switch due to a lack of FC credit from Root Port B, if IDO is set for a PIOR Completion from MFD Z, it is permitted within the Switch for this PIOR Completion to pass the stalled DMAW from Device Y. The same also holds for a PIOR Completion from one Function in MFD Z passing a stalled DMAW from a different Function in MFD Z.

• Posted Request passing another Posted Request: within a Switch, there is little or no envisioned benefit from having a DMAW from one TLP stream passing a DMAW from a different TLP stream. However, it is not prohibited for Switches to implement such passing as permitted by IDO.

**E.2.3 Benefits for Integrated Endpoints**

Here are some examples for the Root Complex Integrated Endpoints (RCiEPs) in [Figure E-1](#bookmark33). The benefits are basically the same as for the MFD/RP Direct Connect case.

• Posted Request passing another Posted Request: when a DMAW from RCiEP 0 is stalled due to an TA miss, if IDO is set for a DMAW from RCiEP 1, it is permitted for this DMAW to pass the stalled DMAW from RCiEP 0.

• Non-Posted Request passing a Posted Request: when a DMAW from RCiEP 0 is stalled due to an TA miss, if IDO is set for a DMAR Request from RCiEP 1, it is permitted for this DMAR Request to pass the stalled DMAW from RCiEP 0.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• Completion passing a Posted Request: when a DMAW from RCiEP 0 is stalled due to an TA miss, if IDO is set for a PIOR Completion from RCiEP 1, it is permitted for this PIOR Completion to pass the stalled DMAW from RCiEP 0.

**E.2.4 IDO Use in Conjunction with RO**

IDO and RO174 are orthogonal. Certain instances of passing; for example, a Posted Request passing another Posted

Request, might be permitted by IDO, RO, or both at the same time. While IDO and RO have significant overlap for some cases, it is highly recommended that both be used whenever safely possible. RO permits certain TLP passing within the same TLP stream, which is never permitted by IDO. For traffic in different TLP streams, IDO permits control traffic to pass any other traffic, and generally it is not safe to Set RO with control traffic.

**E.3 When to Use IDO**

With Endpoint Functions175 , it is safe to Set IDO in all applicable TLPs originated by the Endpoint when the Endpoint is directly communicating with only one other entity, most commonly the RC. For the RC case, “directly communicating” specifically includes DMA traffic, PIO traffic, and interrupt traffic; communicating with RCiEPs or communicating using P2P Root Port traffic constitutes communicating with multiple entities.

With a Root Port, there are no envisioned high-benefit use models where it is safe to Set IDO in all applicable TLPs that it originates. Use models where a Root Port Sets IDO in a subset of the applicable TLPs it originates are outside the scope of this specification.

**E.4 When Not to Use IDO**

**E.4.1 When Not to Use IDO with Endpoints**

With Endpoint Functions, it is not always safe to Set IDO inapplicable TLPs it originates if the Endpoint directly

communicates with multiple entities. It may be safe to Set IDO in some TLPs and not others, but such use models are outside the scope of this specification.

For example, in [Figure E-1](#bookmark33)if Device Y and MFD Z are communicating with P2P traffic and also communicating via host memory, it is not always safe for them to Set IDO in the TLPs they originate. As an example failure case, let’s assume that Device Y does a DMAW (to host memory) followed by a P2P Write to MFD Z. Upon observing the P2P Write, let’s assume that MFD Z then does a DMAW to the same location earlier targeted by the DMAW from Device Y. Normal ordering rules would guarantee that the DMAW from Device Y would be observed by host memory before the DMAW from MFD Z.

However, if IDO is set in the DMAW from MFD Z, the RC would be permitted to have the second DMAW pass the first, causing a different end result in host memory contents.

Synchronization techniques like performing zero-length Reads might be used to avoid such communication failures when IDO is used, but specific use models are outside the scope of this specification.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

174. In this Appendix, “RO” is an abbreviation for the Relaxed OrderingAttribute field.

175. Endpoint Functions include PCI Express Endpoints, Legacy PCI Express Endpoints, and Root Complex Integrated Endpoints.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**E.4.2 When Not to Use IDO with Root Ports**

With Root Ports, it is not always safe to Set IDO inapplicable TLPs it originates if Endpoint Functions in the hierarchy do any P2P traffic. It may be safe to Set IDO in some TLPs and not others, but such use models are outside the scope of this specification.

As an example, in [Figure E-1](#bookmark33)if Device Y and MFD Z are communicating with P2P traffic and also communicating with

host software, it is not always safe for Root Port B to Set IDO in the TLPs it originates. For example, let’s assume that

Device Y does a P2P Write to MFD Z followed by a DMAW (to host memory). Upon observing the DMAW, let’s assume that the host does a PIOW to MFD Z. Normal ordering rules would guarantee that the P2P Write from Device Y would be

observed by MFD Z before the PIOW from the host. However, if IDO is set in the PIOW from the host, the Switch would be permitted to have the PIOW pass the P2P Write, ultimately having the two Writes arrive at MFD Z out of order.

**IMPLEMENTATION NOTE**

Requester and Completer IDs for RC-Originated TLPs

With RC implementations where the Requester ID in a PIO Request does not match the Completer ID in a DMAR Completion, this enables another potential communication failure case if IDO is Set in the Completion. For this case, if a PIOW is followed by a DMAR Completion with IDO Set, a Switch below the Root Port could permit the

DMAR Completion to pass the PIOW, violating the normal ordering rule that a non-RO Read Completion must not pass Posted Requests. The PIOW and DMAR Completion would appear to belong to different TLP streams, though logically they belong to the same TLP stream. Special caution is advised in setting IDO with TLPs originating from such RCs.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADaCAYAAACb+QOvAAAAPklEQVRYhe3KoREAIAwAsZYlsYyGZUow2B4Sk7efjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAAAAC+g2cHOjAEslO7ItUAAAAASUVORK5CYII=)

**E.5 Software Control of IDO Use**

**E.5.1 Software Control of Endpoint IDO Use**

By default, Endpoints are not enabled to Set IDO in any TLPs they originate.

**IMPLEMENTATION NOTE**

The “Simple” Policy for IDO Use

It is envisioned that Endpoints designed primarily to communicate directly with only one other entity (e.g., the RC) may find a “simple” policy for setting IDO to be adequate. Here’s the envisioned “simple” policy. If the IDO Request Enable bit is Set, the Endpoint Sets IDO in all applicable Request TLPs that it originates. If the IDO

Completion Enable bit is Set, the Endpoint Sets IDO in all Completion TLPs that it originates.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAACoCAYAAADdE69lAAAAN0lEQVRYhe3KoQEAIAzAsI0nsZyG5cphsFPY1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAADgpwskJwROWh0xhAAAAABJRU5ErkJggg==)

It is envisioned that a software driver associated with each Endpoint will determine when it is safe for the Endpoint to

set IDO inapplicable TLPs it originates. A driver should be able to determine if the Endpoint is communicating with

multiple other entities, and should know the Endpoint’s capabilities as far as setting IDO with all applicable TLPs when enabled, versus setting IDO selectively. If a driver determines that it is safe to enable the setting of IDO, the driver can set the IDO Request Enable and/or IDO Completion Enable bits either indirectly via OS services or directly, subject to OS

policy.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

If an Endpoint is designed for communication models where it is not safe to utilize the “simple” policy for IDO use, the

Endpoint can implement more complex policies for determining when the Endpoint sets the IDO bit. Such

implementations might utilize device-specific controls that are managed by the device driver. Such policies and device-specific control mechanisms are outside the scope of this specification.

**E.5.2 Software Control of Root Port IDO Use**

Since there are no envisioned high-benefit “simple” use models for Root Ports setting the IDO bit with TLPs they

originate, and there are known communication failure cases if Root Ports set the IDO bit with all applicable TLPs they originate, it is anticipated that Root Ports will rarely be enabled to set IDO in TLPs they originate. Such use models and policies for Root Ports setting IDO are outside the scope of this specification.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Message Code Usage**

[Table F-1](#bookmark34)contains a list of currently defined PCI Express Message Codes. Message codes are defined in this specification and in other specifications. This table will be updated as Messages are defined in other specifications but due to document release schedules, this table might not contain recently

**F.**

defined Messages.

Table F-1 Message Code Usage

|  |  |  |  |
| --- | --- | --- | --- |
| Message Code | Routing r[2:0] | Type | Description |
| 0000 0000 | 011 | Msg | Unlock, see Section 2.2.8.4 |
| 0000 0001 | 010 | MsgD | Invalidate Request Message, see Section 10.3.1 |
| 0000 0010 | 010 | Msg | Invalidate Completion Message, see Section 10.3.2 |
| 0000 0100 | 000 | Msg | Page Request Message, see Section 10.4.1 |
| 0000 0101 | 010 | Msg | PRG Response Message, see [Section 10.4.2](#bookmark1) |
| 0001 0000 | 100 | Msg | Latency Tolerance Reporting (LTR) Message, see Section 2.2.8.8 |
| 0001 0010 | 100 | Msg | Optimized Buffer Flush/Fill (OBFF) Message, see Section 2.2.8.9 |
| 0001 0100 | 100 | Msg | PM\_Active\_State\_Nak, see Section 2.2.8.2 |
| 0001 1000 | 000 | Msg | PM\_PME, see Section 2.2.8.2 |
| 0001 1001 | 011 | Msg | PME\_Turn\_Off, see Section 2.2.8.2 |
| 0001 1011 | 101 | Msg | PME\_TO\_Ack, see Section 2.2.8.2 |
| 0010 0000 | 100 | Msg | Assert\_INTA, see Section 2.2.8.1 |
| 0010 0001 | 100 | Msg | Assert\_INTB, see Section 2.2.8.1 |
| 0010 0010 | 100 | Msg | Assert\_INTC, see Section 2.2.8.1 |
| 0010 0011 | 100 | Msg | Assert\_INTD, see Section 2.2.8.1 |
| 0010 0100 | 100 | Msg | Deassert\_INTA, see Section 2.2.8.1 |
| 0010 0101 | 100 | Msg | Deassert\_INTB, see Section 2.2.8.1 |
| 0010 0110 | 100 | Msg | Deassert\_INTC, see Section 2.2.8.1 |
| 0010 0111 | 100 | Msg | Deassert\_INTD, see Section 2.2.8.1 |
| 0011 0000 | 000 | Msg | ERR\_COR, see Section 2.2.8.3 |
| 0011 0001 | 000 | Msg | ERR\_NONFATAL, see Section 2.2.8.3 |
| 0011 0011 | 000 | Msg | ERR\_FATAL, see Section 2.2.8.3 |
| 0100 0000 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |
| --- | --- | --- | --- |
| Message Code | Routing r[2:0] | Type | Description |
| 0100 0001 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |
| 0100 0011 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |
| 0100 0100 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |
| 0100 0101 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |
| 0100 0111 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |
| 0100 1000 | 100 | Msg | Ignored Message, see Section 2.2.8.7 |
| 0101 0000 | 100 | MsgD | Set\_Slot\_Power\_Limit, see Section 2.2.8.5 |
| 0101 0010 | 100 | Msg | PTM Request, see Section 2.2.8.10 |
| 0101 0011 | 100 | Msg/MsgD | PTM Response/PTM ResponseD, see Section 2.2.8.10 |
| 0111 1110 | 000, 010, 011, or 100 | Msg/MsgD | Vendor\_Defined Type 0, see Section 2.2.8.6 |
| 0111 1111 | 000, 010, 011, or 100 | Msg/MsgD | Vendor\_Defined Type 1, see Section 2.2.8.6 |

[Table F-2](#bookmark35)contains a list of currently defined Subtype codes for PCI-SIG-Defined VDMs (seeSection 2.2.8.6.1). Subtype codes are defined in this specification and in other specifications. This table will be updated as Subtype codes are

defined in other specifications but due to document release schedules, this table might not contain recently defined Subtypes.

Table F-2 PCI-SIG-Defined VDM Subtype Usage

|  |  |  |  |
| --- | --- | --- | --- |
| Subtype | Routing r[2:0] | Type | Description |
| 0000 0000 | 010 or 011 | MsgD | LN Message, see Section 2.2.8.6.2 |
| 0000 0001 | 011 | MsgD | Hierarchy ID Message, See Section 2.2.8.6.5and Section 6.26 |
| 0000 1000 | 100 | Msg | Device Readiness Status, see Section 2.2.8.6.3 |
| 0000 1001 | 000 | Msg | Function Readiness Status, see Section 2.2.8.6.4 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Protocol Multiplexing**

The Protocol Multiplexing mechanism provides a standard mechanism to transport non-PCI

**G.**

Express protocols across a PCI Express Link. The mechanism supports the multiplexing of PMUX Packets and TLPs onto a single PCI Express Link.

An example system topology using Protocol Multiplexing is shown in [Figure G-1 .](#bookmark36) In this example, the Link may operate in two modes:

• PCI Express Link. Protocol Multiplexing is disabled.

• PMUX Link. Protocol Multiplexing is enabled. Both TLPs and PMUX Packets are used in a coordinated fashion. PMUX Packets may be used to support additional protocols efficiently.

|  |
| --- |
| PMUX  Capable Processor |
| PMUX Link    V |
| PMUX Capable Device |

A-0844

Figure G-1 Device and Processor Connected Using a PMUXLink

A PMUX Link is shown in [Figure G-2](#bookmark37). Arbitration and encapsulation occurs between the transmit queues and the Link. Demultiplexing and decapsulation occurs between the Link and the various receive queues. Packets are sent from

transmit queues to the corresponding receive queues. Packets are identified as either PMUX Packets or TLPs.

Demux

Arbiter

|  |
| --- |
| PCI Express  Receive Queue    PMUX  Receive Queue      PCI Express Transmit Queue    PMUX  Transmit Queue |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAJEAAAApCAYAAAA1Qcs7AAAEEElEQVR4nO3czU8jZRwH8O8805nSl2mFSnrAwJa+JVjk4AHQeJCDJnJZPBnCQcKG5X8g4Y/ghHgl9gRRboZs9mBEL03IQqyUaUs0glsigU47nc5AHy9UCgsrNXGHCb/PrfOSfA/fzNPM/GYE3Cza2dn5tWEYw5xz8ZZjyAMhCELD7XZnTk5OngDYfWX/DeckPB5PZmFhwTMzMyPKsvz/pyT3mmVZWFlZaczPzxu6rn8IYOt1x7sVRSkuLS2dc0KuSafT3OfzvQQQbC3NlaVKkqSnw8PDjxcXF92CcNNFijxkqVQK29vbrFAoCJZlPW9ub22K5Pf7Dzc2NkIjIyM2RCROoKoqhoaGqrquvwPgBABYy/6PI5GITAUirxOLxTA2NgYAnze3/VMiRVG+mJqa8tsRjDjL5OSkLxQKfdn83VzOmN/v/yuTybyVSCTsSUYco1wuIxwOm4ZhvA1Aa16J3u/q6nJRgchdBAIBjI6O1gF8BlwuZx+Nj4/TDSFyZxMTE0owGLwsUTAYHBwYGKASkTtLJpOQJCkFXJRIluV3o9GovamIo8TjcRiG8Qi4KJFpmo9isZitoYiz9Pb2wjTNIAAPAyDrut7V19dndy7iIKIoIhwO6wCiDEBfKBSq0YNW0q5EIsEBxBmAWDQaPbc7EHGewcFBDy5K1BOJRCS7AxHniUQiUiAQiDMAbq/Xy/71DEKu6ejogCiKXgZAdrvdVCLSNlmWIQiCu1kiGoElbZNlGYyxDgZAFEWRJtBI20RRBACJAbAsy2rYnIc4kGVZ4JzXGQCzXq9TiUjbTNME59ygEpH/zDRNNBoNgwHQT09P6WYjaZumabAsq8wAFHO53JndgYjzZLPZWrVa/YUBUPf39+nBGWnbzs6OCSDHABzWajWXpml2ZyIOk8/nZQB7DAD3+Xx/FgoFuzMRB6lUKtA0TQLwOwMAl8ulqqpqcyziJKqqwu/3HwJoMACoVCovqESkHXt7e2CM5YCL8dharbaTyWSq9sYiTrK1tXVerVYzwOXLi72KouweHx93uFwuG6MRp+jv768Ui8VPAWw2R0B+c7lcf2xubtqZizjE7u4uSqXSOYCfgZZ38Wu12jerq6umbcmIY6ytrTUYY6sAGsDVT8u8193d/dPBwYGXljRyG8454vF4JZ/PPwbwDLj6aZkXZ2dnv6bTaXvSEUdYX1/H0dHRSwA3fuQKAMZ6enrWc7mcz+v1vtl05N6r1+tIpVJVVVWnAHzb3H59tvp5pVL5fnp62uCcv9mE5F7jnGN2dtYolUo/APiudd9NY7HeQCDwYzKZjM/NzfnopUZimiaWl5er2Wy2WC6XPwBw5UHrbbPVoiRJTxRF+UQQBPqX/cBxzs80TXtmWdZXAF6ZPfsbG+Zr9/JArGoAAAAASUVORK5CYII=)

PMUX Link

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |
| --- |
| Arbiter  Demux  PCI Express Transmit Queue  PMUX  Transmit Queue  PCI Express Receive Queue  PMUX  Receive Queue |

A-0845

Figure G-2 PMUXLink

Important attributes of the Protocol Multiplexing mechanism are:

• Protocol Multiplexing support is optional normative.

• Protocol Multiplexing has no impact on PCI Express components that do not support it.

• Protocol Multiplexing has no impact on PCI Express TLPs and DLLPs, even when it is enabled.

• A Link may be used for both TLPs and PMUX Packets at the same time.

• Protocol Multiplexing does not consume or interfere with PCI Express resources (sequence numbers, credits, etc.). PMUX Packets use distinct resources associated with the specific multiplexed protocol.

• Protocol Multiplexing is disabled by default and is enabled by software. PMUX Packets must not be sent unless enabled by software. PMUX Packets received at Ports that support Protocol Multiplexing are ignored until

Protocol Multiplexing is enabled by software.

• Protocol Multiplexing is selectable on a per-Link basis. Protocol Multiplexing may be used on any collection of Links in a system.

• A PMUX Link may support up to four simultaneously active PMUX Channels. Software configures the protocol used on each PMUX Channel.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• PMUX Packets contain an LCRC. This is used to provide data resiliency in a similar fashion as PCI Express TLPs.

• PMUX Packets do not use the ACK/NAK mechanism of PCI Express. Multiplexed protocol specific acknowledgement mechanisms can be used to provide reliable delivery when needed.

• PMUX Packets do not contain a TLP Sequence Number. Instead, they contain a 12 bit PMUX Packet Metadata field that is available for multiplexed protocol specific use.

• PMUX Packet transmitters must contain some arbitration/QoS mechanism for scheduling sending of PMUX Packets,TLPs and DLLPs; however, the mechanism used is outside the scope of this specification.

• The Protocol Multiplexing mechanism does not define any addressing or routing mechanism for PMUX Packets.

PMUX Packets are similar to PCI Express TLPs. The PMUX Packet Flow Through is shown in [Figure G-3 .](#bookmark38) The PCI Express Packet flow through the layers is shown in Figure 1-5. Changes from PCI Express Packet Flow Through are:

• PMUX Packets use a protocol specific PMUX Protocol Layer instead of the PCI Express Transaction Layer.

• PMUX Packets use a simplified Data Link Layer. The packet integrity portion of the Data Link Layer is mostly

unchanged (LCRC computation uses a different seed value). The reliability and flow control aspects of the Data Link Layer are removed (the TLP Sequence Number field is repurposed as PMUX Packet Metadata).

• The Physical Layer is slightly modified to provide a mechanism to identify PMUX Packets.

|  |
| --- |
| Framing |

|  |
| --- |
| PMUX  Packet  Metadata |

|  |
| --- |
| LCRC |

|  |
| --- |
| Framing |

|  |
| --- |
| PMUX Packet Data |

PMUX Protocol Layer

Data Link Layer

Physical Layer

A-0846

Figure G-3 PMUX Packet Flow Through the Layers

**G.1 Protocol Multiplexing Interactions with PCI Express**

[Table G-1](#bookmark39)and [Table G-2](#bookmark40)describe interactions between Protocol Multiplexing and PCI Express.[Table G-1](#bookmark39)describeshow PCI Express attributes affect Protocol Multiplexing.[Table G-2](#bookmark41)describeshow Protocol Multiplexing features affect PCI

Express attributes.

Table G-1 PCI Express Attribute Impact on Protocol Multiplexing

|  |  |
| --- | --- |
| PCI Express Attribute | Impact on Protocol Multiplexing |
| Link Speed | All PMUX Channels are disabled when the Current Link Speed corresponds to a speed that is not  supported by Protocol Multiplexing (see[Section G.5.4)](#bookmark42). A PMUX Channel may be disabled when the Current Link Speed corresponds to a speed that is not supported by the associated protocol.176 |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

176. The mechanism software uses to determine what Link Speeds are supported by a protocol is outside the scope of this specification.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| PCI Express Attribute | Impact on Protocol Multiplexing |
|  | Link speed can change either explicitly due to a change in the Target Link Speed field or automatically due to an autonomous Link speed change (see Section 6.11).  The PMUX Protocol Layer is permitted to influence the mechanism used by a component to determine when it requests an autonomous Link speed change. In addition, setting Hardware Autonomous Speed Disable at each end of the Link will prevent certain autonomous Link speed changes (see Section  7.5.3.18 ).  The PMUX Protocol Layer may be notified of the change. |
| Link Width | A PMUX Channel may be disabled when the Link Width corresponds to a width that is not supported by the associated protocol.177  The PMUX Protocol Layer is permitted to influence the mechanism used by a component to determine when it requests a Link Width change.  The PMUX Protocol Layer may be notified of the change. |
| FLR initiated | All PMUX Channels on a Link are disabled if an FLR is directed to the Upstream Port’s Function 0. No PMUX Channels are affected if an FLR is directed to any other Function. |
| DL\_Down | All PMUX Channels on a Link are disabled. |
| Hot Reset | All PMUX Channels on a Link are disabled. |
| PERST# | All PMUX Channels on a Link are disabled. |
| TLP Replay | No effect on Protocol Multiplexing. |
| DLLP Lost | No effect on Protocol Multiplexing. |
| TLP Prefix | No effect on Protocol Multiplexing. |
| Locked Transactions | No effect on Protocol Multiplexing (including no effect on any protocol specific forwarding of PMUX Packets). |
| AtomicOp Transactions | No effect on Protocol Multiplexing. |
| Multicast Transactions | No effect on Protocol Multiplexing. |
| Access Control Services  (ACS) | No effect on Protocol Multiplexing. |
| Alternative Routing ID-Interpretation (ARI) | No effect on Protocol Multiplexing. |
| TPH Requester | No effect on Protocol Multiplexing. |
| Virtual Channels | No effect on Protocol Multiplexing. PCI Express Links remain capable of supporting a full complement of VCs. |
| Internal Error | Corrected or Uncorrectable Internal Errors in the PMUX Protocol Layer may be reported as PCI Express Internal Errors. |
| L0s Link Power State | Protocol Multiplexing tracks the Link state. The PMUX Protocol Layer may request the Link transition back to L0. |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)177. The mechanism software uses to determine what Link Widths are supported by a protocol is outside the scope of this specification.

Page 1254

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| PCI Express Attribute | Impact on Protocol Multiplexing |
| L1 Link Power State | Protocol Multiplexing tracks the Link state. The PMUX Protocol Layer may request the Link transition back to L0. |
| Disabled LTSSM State | Disabling a Link also disables all PMUX Channels on the Link. |
| Loopback LTSSM State | Entering Loopback state disables all PMUX Channels on the Link. |
| Recovery LTSSM State | No effect on Protocol Multiplexing. The PMUX Protocol Layer may be notified. |
| Receiver or Framing Error | The error is reported to the PMUX Protocol Layer to indicate that data might have been lost. This can be used to initiate protocol specific error recovery mechanisms. The Error is reported to software using PCI Express Mechanisms. |
| Lane Reversal | No effect on Protocol Multiplexing. Support for Lane Reversal remains optional. |
| Polarity Inversion | No effect on Protocol Multiplexing. |
| Crosslink | No effect on Protocol Multiplexing. Support for Crosslink remains optional. If supported, the PMUX Protocol Layer may be notified of the outcome of the Crosslink Upstream / Downstream negotiation. |
| Lane assignment rules | Placement and frequency rules for STP Symbols and STP Tokens are not changed (see Section 4.2.1.2 and Section 4.2.2.3.2). These rules apply identically to PCI Express TLPs and PMUX Packets. |
| PCI Power Management Power State | All PMUX Channels on a Link are disabled if the Upstream Port’s Function 0 is sent to non-D0 state. |
| Dynamic Power Allocation (DPA) | No effect on Protocol Multiplexing. The PMUX Protocol Layer is notified of the change and may  participate in the power reduction. PCI Express power management includes any power used by the PMUX Protocol Layer. |
| PCI Power Management  Power Consumed /  Power Dissipated /  Aux\_Current | Power required by the PMUX Protocol Layer is included in the PCI structures. |
| Power Budgeting | Power required by the PMUX Protocol Layer is included in the PCI Express structures. |
| Slot Power Limit | Slot Power Limit includes power available to PMUX Protocol Layer. |
| ASPM L0s Entry Condition | The definition of Idle is extended to include:  • No pending PMUX Packets to transmit over the Link.  • For PMUX Channels that use protocol specific Flow Control, no credits are available to send PMUX Packets in that PMUX Channel. |
| ASPM L1 Entry Condition | A Link may not enterL1if PMUX Packets are pending or scheduled to be transmitted. |
| ASPM L0s/L1 Exit Conditions | A Link may be directed to exit L0sor L1if a component needs to transmit a PMUX Packet. Routing of  PMUX Packets through routing elements is outside the scope of this specification; the associated L0s/L1 exit rules are also unspecified. |
| Bus Renumbering | No effect on Protocol Multiplexing. |
| Hot Plug | No direct effect on Protocol Multiplexing. Note Hot Plug events indirectly affect Data Link State which, in turn affects Protocol Multiplexing. |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1255

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| PCI Express Attribute | Impact on Protocol Multiplexing |
| TLP Sequence Number | No effect on Protocol Multiplexing. PMUX Packets do not consume TLP Sequence Numbers. |
| PCI Express Flow Control | No effect on Protocol Multiplexing. PMUX Packets do not consume PCI Express Flow Control credits. Flow Control Update DLLPs must be sent as required by PCI Express. |
| Error Reporting | No direct effect on Protocol Multiplexing. The PMUX Protocol Layer may be notified when an error is signaled or when an error message is received. |
| LCRC Errors in TLPs | No effect on Protocol Multiplexing. |
| Nullified TLPs | No effect on Protocol Multiplexing. |
| VC Arbitration | No effect on Protocol Multiplexing. Arbitration within PCI Express is unaffected by Protocol Multiplexing. |
| Port Arbitration | No effect on Protocol Multiplexing. Arbitration within PCI Express is unaffected by Protocol Multiplexing. |
| Electrical Idle Inference | PMUX Packets count as TLPs for the purpose of inferring Electrical Idle. |
| MR-IOV | Protocol Multiplexing may co-exist with MR-IOV. PMUX Packets are not part of any MR-IOV Virtual Hierarchy. Protocol Multiplexing is controlled using configuration space in the Management VH(s). |
| Table G-2 PMUX Attribute Impact on PCI Express | |
| PMUX Attribute | Impact on PCI Express |
| PMUX Protocol Error | No effect on PCI Express. |
| LCRC Errors in PMUX Packets | No effect on PCI Express. PMUX Packets with LCRC errors are discarded without triggering PCI Express replay. This error is reported to the PMUX Protocol Layer and can be used to initiate protocol specific error recovery and/or error reporting mechanisms. |
| Link Unreliability | The PMUX Protocol Layer is permitted to influence the mechanism used by a component to determine if it requests an autonomous link speed change. |
| Nullified PMUX Packets | No effect on PCI Express. It is protocol specific whether PMUX Packets within a specific PMUX Channel  may be nullified. If supported, PMUX Packets are nullified in the same manner as TLPs (e.g., inverting the LCRC and signaling nullification at the Physical Layer). Receiving a nullified PMUX Packet may be  reported to the PMUX Protocol Layer. |
| Electrical Idle Inference | PMUX Packets count as TLPs for the purpose of inferring Electrical Idle. |
| PMUX Protocol Layer  directs LTSSM to enter  Recovery | Both PCI Express and the PMUX Protocol Layer are permitted to direct a transition from L0 to Recovery. |
| PMUX Channel Enabled / Disabled | No effect on PCI Express |
| PMUX Packet Receiver Buffer Overflow | No effect on PCI Express. This is a protocol problem within the PMUX Channel. The PMUX Transport Layer must continue to accept such packets dispose of them using protocol specific mechanisms. |
| Received PMUX Packet  larger or smaller than  supported by the  associated protocol | No effect on PCI Express. These are protocol problems within the PMUX Channel. The PMUX Transport Layer must accept such packets and dispose of them using protocol specific mechanisms. |
| Received PMUX Packet that contains more than | No effect on PCI Express. This is an invalid PMUX Packet. The PMUX Transport Layer must accept such a packet and dispose of it. A protocol specific mechanism may be used to report the error. |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1256

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| PMUX Attribute | Impact on PCI Express |
| 125 DWORDs of PMUX Packet Data | Note: This situation only exists for a packet encoded using 8b/10b. The TLP Length field of a packet encoded using 128b/130b cannot contain values that cause this situation. |
| PMUX Packet Received  on disabled PMUX  Channel | No effect on PCI Express. No effect on any other PMUX Channel. Receivers must silently ignore such packets regardless of packet length and regardless of whether or not the packet is nullified.  PMUX Packets arriving on a disabled PMUX Channel may occur normally when software is in the process of initializing Protocol Multiplexing. |
| PMUX Packet Received  at component that does  not support Protocol  Multiplexing | Software should not enable PMUX Packets unless both ends of a Link support Protocol Multiplexing.  In the 128b/130b encoding, receiving a PMUX Packet by a component that does not support Protocol Multiplexing is a Framing Error (seeSection 4.2.2.3.1).  In the 8b/10b encoding, the PMUX Packet LCRC is computed differently that the TLP LCRC. Receivers that do not support Protocol Multiplexing will interpret PMUX Packets as TLPs with LCRC errors and will not process them. |
| Large PMUX Packets  when PCI Express  Max\_Payload\_Size is  small | Under certain conditions, it is possible for a large PMUX Packet to trigger a premature PCI Express replay.  For example, this can occur when the time needed to transmit a PMUX Packet is larger than the REPLAY\_TIMER (see Section 3.6.2.1).  To avoid this issue, implementations are permitted to not advance (hold) their REPLAY\_TIMER during the reception of PMUX Packets.  Note: The PCI Express REPLAY\_TIMER mechanism has adequate headroom for most cases. This issue exists when (1) Max\_Payload\_Size is 000b, (2) PMUX Packets are larger than about 80 DWORDs, and (3) the REPLAY\_TIMER is at the low end of the -0%/+100% tolerance. |

**G.2 PMUX Packets**

A PMUX Packet contains the information shown in [Figure G-4 .](#bookmark43)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1257

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

PMUX Channel ID [1:0]

PMUX Packet Metadata [11:0]

|  |
| --- |
|  |
|  |
|  |
|  |
|  |

PMUX Packet Data DWORD 0 [31:0] PMUX Packet Data DWORD 1 [31:0]

PMUX Packet Data DWORD n [31:0] A-0847

Figure G-4 PMUX Packet

PMUX Channel ID is a 2 bit field that identifies which protocol is associated with a PMUX Packet. PMUX Channel ID values are between 0 and 3 (inclusive).

PMUX Packet Metadata is a 12 bit field that provides information about the PMUX Packet. Definition of this field is protocol specific and is outside the scope of this specification.

A PMUX Packet consists of between 0 and 125 DWORDs of PMUX Packet Data. Layout and usage of these DWORDs is

protocol specific and is outside the scope of this specification. A PMUX Packet need not have any PMUX Packet Data and may consist only of PMUX Channel ID and PMUX Packet Metadata.

**G.3 PMUX Packet Layout**

There are two layouts defined for PMUX Packets. One layout is used for 2.5 and 5.0 GT/s data rates and another layout is used for 8.0 GT/s and higher data rates. These layouts are discussed in the following sections.

**G.3.1 PMUX Packet Layout for 8b/10b Encoding**

[Figure G-5](#bookmark44)and [Table G-3](#bookmark45)show the layout of PMUX Packets when using 8b/10b encoding. For reference, the 8b/10b encoding of a TLP is also shown (see Section 4.2.1.2for the official definition).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

PCI Express TLP Layout

Symbol 1

Symbol 0

Symbols Symbols

3 to N-6 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAhCAYAAAAYucG/AAAAGklEQVQImWNgYGBQZ2BgYPjKxMDAwDAoiU8AwsoCTUSiLWIAAAAASUVORK5CYII=) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAhCAYAAADzjnq8AAAAJklEQVQYlWNkYGDgZ2Bg4GZhYGDwY2BgcGNigIJRBpTxm4GB4TsA8D4C5E5OIfkAAAAASUVORK5CYII=) N-5 to N-2

Symbol 2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAALMAAAAYCAYAAACxz8zeAAADP0lEQVR4nO3af6hfcxzH8ce9dseGbNYkZZqIuH9o8iOMrZtRZmXkD3/4WWiKsj/85Y+JopTC/PhD224Jf/hH/MGSSGIRJbcWMmUli2JmyrXrj/c59e3cc8/9Xp0f2+nzrNO3zvl8X5/355zXeX/e55wPRz8T2NF1EDXyHLZ0HUSNfIjVXQcBo10HMARLsLLrIGpkFCNdB1EjZ2BR10FwbJg5kRiKZOZEb0hmTvSGZOZEb0hmTvSGZOZEb+jKzE/hcVyDsZo0z8Z9eAPn1KQ5DOfjNdyDVTVpjmINHsEkTqhJdxhuxsu4Bctr0lyGm/AC7qhJ86hhHP9gBgfxNh7CBSVtN2bHiyzDZryI7zKtGbzUQLzzsWug/714Hptwcknb7XigZP+ZuBuv48CA3m0NxFvFInyT9f0vPlOdeL7FuYV9Y7gK2/AJpjO9fVjaRNDEy/uluKKpDirYIu7WIvuxe2C7DPdnbS/HBlyLS8yeWQ7iTvzRSMRzsxw7zb5Q08IMu/Ee9uBZTImMu06MZQPOK9H9GluFEdpkjZg9i/wpvvjl12ZKmPmG7Hh+bSZwYsn/t+HjuoPN2DsivuBMNtRBFStwUcXx/XgXX+BGvC+mvjIT5/yGL2uMcSFcLGaLMqbxqSiBxvGjGP9G5SbO+V5ks7Y5Dmuz3zIO4QO8gqfxpBjLBE6q0P1IzMhNsL0h3XkZERlrZmA7LLLXVnHBc4plxqm4VZzInwoaM7qZZSZK4tgnas/NOGWgbbHMOAv34k38XtA4oL66dSE8WojjCL4Spl2PxQNtB8uMMVyNJ/C52efkmRZib527xOCmxACvF2swypirZiZuigvxsMjif4uTOFdGaYK8xjyEd/Cg6mw7V82ca12Jx8TNfkQsTGqTVfgLv+BV3I7TK9qX1cw5K0XNP4mfRVYuey46ptkkHniGocrMRZbgugVo18FqkZmPH7J9lZmLrBBvFxbP17BGLhUl07CLoarMPMioKCvX/s+45qWr1U5vNaR7WGToNvkh25rgV1F+tMmehnTzUqUx0keTRG9IZk70hmTmRG9IZk70hmTmRG9IZk70hmTmRKJFThPrMfrCuPiE3RfWKV9U1Dr/ASbsovXnBIssAAAAAElFTkSuQmCC) Symbol N-1

K27.7 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGDQYGBgYLjFxMDAwEAv4h8Ae/4CLYjx3q4AAAAASUVORK5CYII=) R ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGDQYmBgYHjOxMDAwEAv4h8AgokCPPdhb34AAAAASUVORK5CYII=) R ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAJElEQVQImdXGsQ0AIAgAsAqHeLlvMhIXnqBTExcn8VBhbE3DB3LRAuTaQMP1AAAAAElFTkSuQmCC) R ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAJUlEQVQImWNkYGAQYWBgYGdhYGCIYGBg0GBigIKhyvjPwMDwHwCX0ALLomiHlQAAAABJRU5ErkJggg==) R ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGBQY2BgYDjPxMDAwEAv4h8AdlECIIIZjDYAAAAASUVORK5CYII=)S11S10![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGDQYWBgYPjIxMDAwEAv4h8Ah8cCSPjAtwcAAAAASUVORK5CYII=) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAJElEQVQImdXGQREAIAgAsJ0UITsBjQB+LMFeCyQmULjHtzUNDz/TA+BqNyIRAAAAAElFTkSuQmCC) S9 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAJUlEQVQImWNkYGAQY2BgYGZhYGBIYGBgEGFigIKhyvjPwMDwHwCNBAK9JxUmpgAAAABJRU5ErkJggg==) S8 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGBQZWBgYDjJxMDAwEAv4h8Ac0MCGZB+w7cAAAAASUVORK5CYII=) S7 ![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0aHBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAAYAAEDASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD5/ooooAKKKKAP/9k=) S6 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGBQYmBgYNjDxMDAwEAv4h8AbEQCCRRMZhcAAAAASUVORK5CYII=) S5 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAJElEQVQImdXGMREAIAwEsMBVBBbrf+e7YIJMWThIoXG359cEGRiTBK6Tv3J/AAAAAElFTkSuQmCC) S4 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGBQZmBgYNjPxMDAwEAv4h8AbgUCDQvtEb0AAAAASUVORK5CYII=) S3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGDQZWBgYPjFxMDAwEAv4h8AjCICUiMYpo4AAAAASUVORK5CYII=) S2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGBQYWBgYDjOxMDAwEAv4h8AcfECFuC3m/EAAAAASUVORK5CYII=) S1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAJUlEQVQImWNkYGCQZGBg+MvCwMBQxMDA8IqJAQqGKuM/AwPDfwAPXgSifGoihQAAAABJRU5ErkJggg==) S0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAYCAYAAADQ+yzZAAAAIUlEQVQImWNkYGDgY2BgEGZgYGDwYWBg2MLEAAVDmfEPAPewAk0AFKcgAAAAAElFTkSuQmCC) TLP ... ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAASCAYAAABxYA+/AAAAJUlEQVQImWNmYGDIZmBgkGBhYGDQYmBgYGBigIKBZ/xnYGD4DwB9YgLTfonCpgAAAABJRU5ErkJggg==) LCRC ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAYCAYAAAA7zJfaAAAAGklEQVQImWNgYGDQYGBgYLjNxMDAwEAv4h8AfG0CLkAjrzIAAAAASUVORK5CYII=) K29.7

7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16

STP

Reserved TLP Sequence

Number

PCI Express END

TLP

PMUX Packet Layout

Symbol 1

Symbol 0

Symbols Symbols

3 to N-6 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAiCAYAAACeLbMRAAAAHklEQVQImWNgYGDgZ2BgYPjKxMDAwDA4CQYGBgYuALkZAU2MkedvAAAAAElFTkSuQmCC) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAiCAYAAAB1GggSAAAAJ0lEQVQYle3GMREAIAwEsBT+kIaF+nfCwoAIMqWwkKCxh+vnTSGYB+qLAPPfoTcrAAAAAElFTkSuQmCC) N-5 to N-2

Symbol 2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAALMAAAAYCAYAAACxz8zeAAADNUlEQVR4nO3aS4gcVRTG8V/PxNeoBBcJGmJ8m7hQiKCgYlBwjMQHKEEiMeBCRRDB3YjEpeArRCSCgoroIiCiG0HxFUHRnaIEA5mN0UAUdFCCRCWmXZwO05RVRWWox0xx/9CbW7dOnXP7O+ee6tssfm7AS107USM78GDXTtTIBzi/aydgomsHKnAGVnftRI2cipO6dqJGLrJI4lkKYk4kKpHEnOgNScyJ3pDEnOgNScyJ3pDEnOgNXYn5STyOq2r04Rxsw+u4uCabVViH13APVtRkczCy+wheET/ntcVd2IlNmKrJ5hQ24jncW5PNRcN6/IshfsNbeADn5cy9De/ljE/hFnEI8d3I1lAIq212j559DN/gGdwkX4Qv4uGc8RXYIvz/yXw899XvbiknY//o2X9jj/LCM4tLMmMTuBIz+Bh/jewdFOcGjTAQC35FUw8oYUZUgSyz+Gj0+RQb8BDuEElwM6ZxnVj4cf7EZsw143IhK0VCnpYZP4IvRCwfiqTbhe/xqohhWsS0PsfuXpHkxxrxuphr8HzO+Bw+MR/PAfF9bRKCnR59NuKsnPu3j+5tggMDcbr2TkMPKGM5Li25Pof38SVux2fYistL7vlDVJUuWIczC64NRcV+A5cJEZyNO3Fuic2DOFSjj1WZEMlV1AL+I5J0F57FU7hbFJ5TSux+LXbkJtjRkN1KfG5+Kx3iqFigJ3C1+YXMthmrxNa7G79mbAzFdtg2G3L8+AVvih5x5djc8TZjIMT9qEjcIxkbP4ukb5sZ/49nP17ArTh9bO54m3G89dspdp+sjadb8L11torgfsDLot0o+tKKemaYFOLdLpLjKL7S7ovtJL4V1WoPHhNVbVAwv6hnJlq+afGitFesUdsVZxUOi13uXdHiXVAyP69nPs4a3I+38btYo6K5S5bNWFtxbpmYsywXW/eahTi1QC4UbVDVF5syMWdZLSp79t2gSa7F9VhWcX6ZmMdZNrJ94wL96gUnIualwImIeSlQVcyNkw5NEr0hiTnRG5KYE70hiTnRG5KYE70hiTnRG5KYE71hsmsHKnBYHI3+2LUjNXFIxNP2n6GaYhb7xOlep/wHAw2mN/tk6FkAAAAASUVORK5CYII=) Symbol N-1

K27.7 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGBQYGBgYLjFxMDAwEA3goGBgYENAH0pAS0Sl7/CAAAAAElFTkSuQmCC)ID1![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGBQYmBgYHjOxMDAwEA3goGBgYENAIP/ATxQwiPZAAAAAElFTkSuQmCC)ID0![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJUlEQVQImdXGsQ0AIAgAsArxCL/nTEYWn6BTEw8nUejwrQ5cxAB9+gHsFgc1yAAAAABJRU5ErkJggg==)ID1![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJ0lEQVQImdXGMREAIAwEsDzlmJGBKPzr6IIJMiXYWBMXZ3i+TlBIA5gnANGLNKT4AAAAAElFTkSuQmCC)ID0M11M10M9![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGCQY2BgYDjPxMDAwEA3goGBgYEVAHc6AR/RDLjEAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGBQZmBgYPjIxMDAwEA3goGBgYENAIkAAUfSAZqiAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJUlEQVQImdXGMQ0AMAgAsAYyE/ifvkmAZybo1UShExcvfKsDBzFTCALnL5NtEwAAAABJRU5ErkJggg==) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJklEQVQImdXGMREAIAwEsHyLAg6J+NfAUhNkSrBRCxenjK8TNPIAjN0Awz6hi0MAAAAASUVORK5CYII=) M8![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGCQY2BgYDjJxMDAwEA3goGBgYEVAHSCARnv66EyAAAAAElFTkSuQmCC) M7![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGBQZWBgYPjDxMDAwEA3goGBgYENAI7uAVTjJlQ8AAAAAElFTkSuQmCC) M6![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGCQYWBgYNjDxMDAwEA3goGBgYEVAG2sAQp6GccZAAAAAElFTkSuQmCC) M5![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJUlEQVQImWNkYGAQZmBgYGBhYGDIY2Bg+MfEAAVDmsHIAPHSfwBTggK184D7IAAAAABJRU5ErkJggg==) M4![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGCQYWBgYNjPxMDAwEA3goGBgYEVAG8IAQ2M/BaHAAAAAElFTkSuQmCC) M3![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGBQZWBgYPjFxMDAwEA3goGBgYENAI4GAVKjyMyUAAAAAElFTkSuQmCC) M2![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGCQZWBgYDjOxMDAwEA3goGBgYEVAHMhARY1WR89AAAAAElFTkSuQmCC) M1![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJ0lEQVQImdXGQQ0AIAwEsB6ZBVTjFA0k7IMJ+mowcYKFPTxfJyjcBjAjA7l6QQmkAAAAAElFTkSuQmCC) M0![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAZCAYAAAAbp/98AAAAJElEQVQImWNkYGDgZmBgEGBgYGDwYWBg2MLEAAVDmsEI5TADAP1tAU9wQ/wQAAAAAElFTkSuQmCC) Data ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAATCAYAAAC6PNwaAAAAJ0lEQVQImc3GQREAIAgAsKGcFaxBKftH0A8h3GsTBztRWEP7JIHEfYLEAd5hwJvVAAAAAElFTkSuQmCC) LCRC\* ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAZCAYAAADwkER/AAAAHklEQVQImWNgYGBQYGBgYLjNxMDAwEA3goGBgYENAH2dAS5emBa4AAAAAElFTkSuQmCC) K29.7

7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16

STP PMUX Channel ID PMUX Packet PMUX END

(and Inverted PMUX Metadata Packet

Channel ID) Data

\* LCRC for PMUX Packets uses a different starting seed than that used for TLPs. This avoids aliasing problems and potential errors if software misconfigures a link so that PMUX Packets are seen by existing silicon.

A-0848

Figure G-5 TLP and PMUX Packet Framing (8b/10b Encoding)

Table G-3 PMUX Packet Layout (8b/10b Encoding)

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Symbol | Field | Bit  Position(s) | PMUX Packet Usage | TLP Usage |
| 0 | Start TLP Indicator | 7:0 | K27.7 | |
| 1 | Inverted PMUX Channel ID[1:0] | 7:6 | Inverted (1s complement) of Symbol 1 bits 6:4 | Reserved |
| PMUX Channel ID[1:0] | 5:4 | PMUX Channel ID | Reserved |
| PMUX Packet Metadata[11:8] | 3:0 | PMUX Packet Metadata[11:8] | TLP Sequence Number[11:8] |
| 2 | PMUX Packet Metadata[7:0] | 7:0 | PMUX Packet Metadata[7:0] | TLP Sequence Number[7:0] |
| 3 to N-6 | Packet | 7:0 | PMUX Packet | TLP |
| N-5 to N-2 | LCRC | 7:0 | PMUX LCRC | PCI Express LCRC |
| N-1 | END | 7:0 | K29.7 | |

For PMUX Packets, symbols 1 and 2 contain PMUX Packet Metadata in the same bit positions that TLPs use for TLP Sequence Number.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

The PMUX LCRC algorithm is identical to the TLP LCRC algorithm as described inSection 3.6.2with the following modifications:

• The seed value is FB3E E248h (TLP LCRC uses FFFF FFFFh).

• The PMUX Channel ID field in Symbol 1 bits 7:4 is included in the PMUX LCRC in the same manner as the 4 reserved bits in the TLP LCRC.

• The PMUX Packet Metadata field is included in the PMUX LCRC in the same manner as the TLP Sequence Number field is included in the TLP LCRC.

**IMPLEMENTATION NOTE**

PMUX Packets at Receivers that do not Support Protocol Multiplexing

The bits used for PMUX Channel ID are reserved unless Protocol Multiplexing is supported. As such, Receivers that do not support Protocol Multiplexing must ignore the PMUX Channel ID bits. If software misconfigures Protocol

Multiplexing, a component that does not support Protocol Multiplexing could receive a PMUX Packet. To prevent that component from misinterpreting such a PMUX Packet as a valid TLP, the LCRC computation is changed for PMUX Packets. The result is that a valid PMUX Packet will never be misinterpreted as a valid TLP. These LCRC

“errors” may trigger PCI Express replay and may result in REPLAY\_NUM Rollover correctable errors being reported.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAD4CAYAAADRnaeSAAAAQUlEQVRYhe3KoREAIAwAsZYlsYyGZUow2B4Kl7efjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA+gWcH4zgE7qEdWkwAAAAASUVORK5CYII=)

**IMPLEMENTATION NOTE**

PMUX Packet LCRC

The PMUX Channel ID field is covered by the LCRC. As such, when using 8b/10b encoding, receivers must wait until the LCRC is checked to make firm decisions based on the PMUX Channel ID value. The Inverted PMUX

Channel ID can be compared against the PMUX Channel ID to make tentative decisions.

Note: The value of the LCRC associated with a given PMUX Packet is independent of the encoding used to transmit the packet.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADCCAYAAAB0fINZAAAAOklEQVRYhe3KoQEAIAzAsI0nsZyG5cphsPOI1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAIDfwAXz2QSEmplM9wAAAABJRU5ErkJggg==)

**G.3.2 PMUX Packet Layout at 128b/130b Encoding**

[Figure G-6](#bookmark46)and [Table G-4](#bookmark47)show the layout of PMUX Packets when using 128b/130b encoding. For reference, the 128b/ 130b encoding of a TLP is also shown (see Section 4.2.2.2for the official definition).

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

PCI Express TLP Layout

Symbols Symbols

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAHCAYAAAB6BA+OAAAAlklEQVQ4jcXSKwpCURCA4e9afBSx3xUY3YOP4hLcgEU0me13PVrchd2qQW4RFIuGYzgIXg1y/GFgZpiBH2b4jhZGWKHx5c5PqFX0e1hiixJrnHFNoxbIojxHHwMM0XmZ3WOMWxo1cMhQxxSLp+Q7SpxSWEXM4iJDF3NscME9iiPaiQUraQrnLrATJIu/Gn0gx0R4iWQ8AL/AFy+y6/aZAAAAAElFTkSuQmCC) Symbol 0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAE8AAAAYCAYAAAC7v6DJAAABfklEQVRYhe3WPUsdQRSA4efGSyCoIBoIsQgEgoJVBIUkbTDExiAEi1R2FlpYWIhNfoKVlYX2djaBhIAiWFrYBIKkUBC7FLFSUYtZ8YP7Rea6e5F54cDCzpxz9mVmdtq0Np/wBEdFN1KJR0U3UIdxvC66iWq0uryWJsmLIMmLIMmLIMmLIMmLoAh5s5hAd5PyldCHGYw2KWdDlPMslrGLnzjHDr5nsY3TBnP04D1G8AEvhIt0f7ObrUVZWAE9OdY8wDdhlQxlsYBjbOKHIPPXjTmP8VYQNYrBCnkX8SyLPDgpYQpzORW8oh3Pa7z/ixX0ChKH8VHtnfJHWM158TvHWrfYwsWNOBO27Ve8QVs2bhWT2XMnxrCEvTvzLzCfS+cF80X42H0s4zO6qoxddS3vLq8wjXX8E7Z9bxP7rEsRP4xTDLh9pv0Pe1ksCWfiO7zEYWTehilC3to95DzBxj3krUm6JEeQ5EWQ5EWQ5EWQ5EWQ5EWQ5D1gnqKj6CaqcQlKizmpL1L2mgAAAABJRU5ErkJggg==) Symbol 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAE8AAAAYCAYAAAC7v6DJAAABSklEQVRYhe3YQSuEQRzH8c9aXBz25CJpFcpBosTVhXBydeLiJciBvBalXJSLC1LKRXkBzg5SUnKQhDg8Dhv7rM2sfdbTfOupp2ae//z6NjPPNLQ2m1kH+M+8ZR2gFm1ZB/jPRHkBRHkBRHkBRHkBRHkBNFveCNYxjkKDahYxKTkTDjSoZstyhnfcYhcr6E3pm3bO68cq9nD/We+gsTF/poDBJo85jH3fZ/0ljnGEUzxK5BVRwjRmMIfyl29fMI+rP8pcjYeCJHR7EweFPnSmtL3jHFs4xOLn+1iNek+4bmTAOthp8nhgViKo8rnBNpbQXdG3ctn2YFmy1O+q1Jj649yZ0yGZ6c84wRpGpf880va8IiawIdlDX3Eh56eHISygq87+9V4MlCTLu/yLTLkl3qrklSgvgCgvgCgvgCgvgCgvgCgvx5SzDlCLD3tgNYZCPLEtAAAAAElFTkSuQmCC) Symbol 2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAE8AAAAYCAYAAAC7v6DJAAABe0lEQVRYhe3VP0scQRjH8Y96BBQJhEOrUxAMpLk2mEpUIqSTaJXCQrDJW0iRKpBKUpxV6qSyS5c0VqLmBVxhEbGyMhZpAvFPMXdkDa5nmNvbQ+cL0+zOPM9vv8zM0t/U8bLsEHkMlh2gA3WslB0ij36X19ckeREkeREkeREkeREkeRFUSui5jCq+4rBLNatYwAQ2cNGlun3HOE6FDzzAJpbw8Jq5r/D5mucPMIt3+I7zVr3nBeTNpYJh1HrZFA28wXRrvMYf7As78hv2MvMH8ESQs4h5IXeW9k5+XGDuLCcDeIpPPWrYZghTN7z/jS+CwGf4gTU8umHNMX51K+AtaPSw1xXeC8csO5r4gBcYac3LHtshzOAtdnD2z/pd9+AHOC3srJ/Ywjomc+bm3XmEXbiCjzgSBK52NWkHyvjb1jAnHMmziDpt+Vv+3on16HT/QRnytguo2T72zQJq53Ln74giSfIiSPIiSPIiSPIiSPIiSPLuMKMYKztEHpfy1TwnVNN17AAAAABJRU5ErkJggg==) Symbol 3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAI8AAAAYCAYAAADDAK5oAAAChklEQVRoge3ZTYiNURzH8c+dZoRmhGhS0pS3vCWSt8SCNBYaYTEiGwsbCy8LJDWxUahZkIUpYWVjY2GM5C0pCwtRSll4Taws5HWuxXlw3ebemXnmmecm51vP5rnn/M/vnPs7//95nodInnTVWkBGbMW0Wov43+ittYCM6EZrXa1VRP5donkiqYnmiaQmmieSmmieSGqieSKpqYV5RqAD6zA6w7gTsQW7MozZH8uxF/MyjFmHRTiIuRnG7Y/92ISxOY6Zin0o4jNu4AAWojCIGCOxGsfwMIlXxLJMlVanHk+Scd/gPLahuUL7Su95pmAHLuFDEu+2wa3HUGlLxv2O+ziCFcIcy+lGawGNmJSXwoR6XMHUsvvvBTP14DpelfxWwBysTa6VGFXW/7JgxDxZigtl94p4JMyhB3eFjdIrZJYmrPJnLjPL+vdiA54Om+q+6RLWtZSPuCXMowfPBPN0FgTxp3MU+IvxyVWJl+jEKSGVHsZ2jKnS5w0+ZSVwELToe4fCDyGLHMY9oVx3YEmVeF+E+edNk8pZk5AVz2IxTuSiqA+a8NafUlMU/vRu7MHsCv0ahFR6FA+EHVoa45p8Uz2hTBXLrhfCIm/GuJK2pWWrOel7Ee/6iLFmuIWXUefv8l/EN9zBIeEc9uuM3I3WnPX95rgg7jFOCtlvZIo4E9COc3idxGzLSONAaEzG/YSr2I1ZVdpXOvPUYYFQcm/iq3CWashMaf/sFNbvOc4IZbNSlq+ZeRqEHTc547gF4alnY8ZxqzHf4Iw/0A+jTViPGWlEpaQd0wfYtqaZ538lflWPRIhvmCNDIJonkpponkhqonkiqYnmiaQmmicS+UdoqbWAjGjGqJ/WkXwyXVpjJwAAAABJRU5ErkJggg==)

4 to N-5 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAhCAYAAADzjnq8AAAAJklEQVQYle3GMQEAIAgAsKHcVCAa+W3hYwx3LdCIxCCX5wcbhXMBvUoBv0ONFF0AAAAASUVORK5CYII=) N-4 to N-1

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAO0AAAAICAYAAAAVxHi+AAAAvUlEQVRYhe3XMUpDQRQF0PMxEMHOMmCTzt5WLEQkZAPiKlK7FFdhZ+kedAU2aUwTUgSTIhYTsBnJD5gvwj3wmpk3cJth3rCfAfp7nomIX9TbsX+CK9xsa4rbQ4eKiPaOcIEHvGCFzbbWOP+7aBEBjTLu3mOEa5z+0PuOt45yRUTdaw+feMICc2X8Pas0f+Cxu2wRUTGrLTbKGDzBM5a+R+RxZ9Eioqpp0XOMS+UFHuJO+etGxD/R5qJHxIF8ATJLGDJ04B7FAAAAAElFTkSuQmCC) STP Token ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAO4AAAAICAYAAAD+88O9AAAAsElEQVRYhe3WsUpCURzH8Y9avkOjg4G0+hA9jmOET+IeLW0NIkgNvkgguLVGKmLDFVvuLR28d/l94EznHPguh/8hIprWxc05FzoXComI0+3wggf00cYK2yajIuJ/t1hjf1hrvOMRQ8VjPmrhtebAiCh3h17F3ifeMMXTFSZ1VUXEn8bKH+4Ss8OaY1NnVERUu/f7Tf5STNYRBmWHW/V1RUSFazzjQzFVF/huMigiLuAHuEEbqyuQeSwAAAAASUVORK5CYII=)

L3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGAIYmBgkGBhYGCQY2BgUGBigIIhxGBmYGBgZ2BgeAUAmDQBynXbaEsAAAAASUVORK5CYII=) L2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNmYGAoZGBgEGZhYGDQZGBg+MrEAAVDiMHMwMDAxcDAcBsAVP8CujIB5S0AAAAASUVORK5CYII=) L1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGCYwMTAwGDCxMDAwEAHYhUAXvcBm0N5AyIAAAAASUVORK5CYII=) L0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYyMDAwPCRiYGBgYEOxDQAupgCY8h7B4YAAAAASUVORK5CYII=) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYwcDAwPCUiYGBgYEOxGwAsb4CU9Svs38AAAAASUVORK5CYII=) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGAwZWBgCGJiYGAQZmBgMGRigIIhxGBmYGBgZWBg+A4AsQoB9qz4nJkAAAAASUVORK5CYII=) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGAIYWBgEGFhYGCQY2BgkGFigIIhxGBmYGBgZ2BgeAkAk7UBwxmcZmIAAAAASUVORK5CYII=) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGAoZWBg4GVhYGDQZmBgeM3EAAVDjPGOgYHhGwBSHwOuY/WuoAAAAABJRU5ErkJggg==) P ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGCYzMTAwGDGxMDAwEAH4hUAYVgB4I+xLLIAAAAASUVORK5CYII=)L10![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYysDAwPCdiYGBgYEOxFMAvx8CvEYDncoAAAAASUVORK5CYII=) L9 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYzMDAwHCfiYGBgYEOxHMArWMClIolQQ8AAAAASUVORK5CYII=) L8 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNkYGCwZGBg8GJiYGAQZWBg0GdigIIhxvjBwMDwBgCysQLZDsmquQAAAABJRU5ErkJggg==) L7 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGCIYGBg4GFhYGBQYGBgEGBigIIhxGBhYGD4zMDAwAgAjQIBujzA4YoAAAAASUVORK5CYII=) L6 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGCoZGBgYGdiYGDQYWBgkGBigIIhxnjHwMDwDQCzLgLY985/hwAAAABJRU5ErkJggg==) L5 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGCYwcDAwHCeiYGBgYEOxEsAogACe7Rmz3oAAAAASUVORK5CYII=) L4 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYycDAwPCXiYGBgYEOxBMAw1YCxU9Bq2cAAAAASUVORK5CYII=) C3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYwMDAwHCLiYGBgYEOxAsAqgUCjUdlSlgAAAAASUVORK5CYII=) C2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNkYGCwY2BgcGBiYGAQY2Bg0GNigIIhxvjOwMDwFgCu4gLUTftn6QAAAABJRU5ErkJggg==) C1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJklEQVQImdXGMREAMAgEsMC9kQrD/14FLDXRTCkMOjhIez5KcJEFgQsBrGId5hQAAAAASUVORK5CYII=) C0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGCoZWBgYGRiYGDQY2BgEGNigIIhxnjLwMDwHQCxtALWhBP3sAAAAABJRU5ErkJggg==)S11![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGCYw8DAwHCViYGBgYEOxAsApjcChAP2c8UAAAAASUVORK5CYII=)S10![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYxcDAwPCPiYGBgYEOxBMAxC8Cx9KakxAAAAAASUVORK5CYII=) S9 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGCYzcDAwHCFiYGBgYEOxAsApV4Cgk3po0sAAAAASUVORK5CYII=) S8 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNkYGBwYmBgsGBiYGCQYGBg0GFigIIhxvjGwMDwDgCr2gLQWnAlMwAAAABJRU5ErkJggg==) S7 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKElEQVQImdXGMQ0AIAwAsEImBWf4P1iW3TyYoFcHNjqwkNPzUQIHdQH3XQSGEPEmEgAAAABJRU5ErkJggg==) S6 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGBoZWBg+MrEwMBgwMDAIMLEAAVDjPGGgYHhBwB1ywPSZX7LuQAAAABJRU5ErkJggg==) S5 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYzMDAwHCPiYGBgYEOxHMArPkCkzrLsoMAAAAASUVORK5CYII=) S4 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYzMDAwPCFiYGBgYEOxFMAvQMCt6bT/5QAAAAASUVORK5CYII=) S3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGCYysDAwHCaiYGBgYEOxCsAnwwCdeMqIAgAAAAASUVORK5CYII=) S2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJElEQVQImWNkYGDwZGBg0GJiYGCQgjEYGBgYGIYY4ysDA8N7AKaJAsmMIb+YAAAAAElFTkSuQmCC) S1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNkYGBIZ2BgeMfCwMCgxsDA8IyJAQqGGOMjAwPDZwDs2gR1plYxQwAAAABJRU5ErkJggg==) S0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNmYGAoZGBg+MnEwMDgxMDAIMPEAAVDiMHMwMCgwMDAcAkAeIYC6zcJ3eQAAAAASUVORK5CYII=) TLP ... ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAASCAYAAACaV7S8AAAAGklEQVQImWNgYGCwZmBgYDjJxMDAwEA9Yj8AWdQB5BkLEPAAAAAASUVORK5CYII=) LCRC

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAGCAYAAAACEPQxAAAAHUlEQVQImWNgYGDoZmJgYDBiYmBgYEAQDAwMDDEAEz4BIvO420oAAAAASUVORK5CYII=) 7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16 31 30 29 28 27 26 25 24

TLP Length [3:0]

|  |  |  |  |
| --- | --- | --- | --- |
| Parity  TLP Length [10:4] | CRC | TLP Sequence Number | PCI Express TLP |

Note: TLP Length [10:0] = INT((N+1) / 4) TLP Length [10:7] < 1100b

PMUX Packet Layout

Symbols Symbols

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACgAAAAHCAYAAAB6BA+OAAAAlElEQVQ4jcXSIQoCYRCG4WdVUIPBZPIAdkGwCRptBrPF6hk8gtgEr+FJBEE0eAOTcQ37C8uC7BZ/X/gYGGbgZRiq0ccKe7Qq7vyUDubY4YI0ZB1bpJGrQ8xCxqgXZq+4YRLNjnOCpuwyS4xQ+zL8wD2S2IdtsdHFAocglObyRC+mXRkJBtjghBeOfzUqoY2p7CWi8QYBdBV5QFYlUQAAAABJRU5ErkJggg==) Symbol 0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAE8AAAAYCAYAAAC7v6DJAAABeElEQVRYhe3Xv0scQRjG8Y+noCB2ooVFwB+VNoIgqWxEIZB/wCZa2FhZWtn6F9jKlbYSEDGFhVjYiUhsEi1MKyhioShazGnkvFNk7nYXmS9MsbvD8777zPvuzLYqNnPoxFneidSilHcC7zCBobyTqEfRzSs0ybwIknkRJPMiSOZFkMyLoC2HmMu4xC/8boBeO75iCvvYaIBmYRnDPR7wD2XMoKfG3DJmq+61YBiL2MR1ResEHU3Ity5t+IL+LINiC9/Qhx+V8YBDbAtVuftifi8mheqarlxXsyZUYFZctwirPp9hUOjGyBvPj4T2G8AxBgXTalUnwfg93DUwx/c4zTDWM604EF74aZxjXfiX7Xsxt+x/25YwiiXs4LZKY6XpmReABaFC9oTNY1z9Xb/s9TfviS58xyr+4Eao0MzIY7c9Ftr2IlLnCj8rg9DiXZGaHyIP83aapPu3Sbp1SYfkCJJ5ESTzIkjmRZDMiyCZF0Ey7xNTUuAFfgSCtzpZwcjV3wAAAABJRU5ErkJggg==) Symbol 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAE8AAAAYCAYAAAC7v6DJAAABXElEQVRYhe3Yv0scQRiH8c9djMIlhUUaMY0gKU1jSKMQCKaysRHSmM6/Ik3Ays7mihRio7VNCn8gpEphIXZ2AUFSKISkCoJeivFAznP1mL29u2UeWLbYd9/98swM7Az9zddeBxhkrnodIItqrwMMMkleBEleBEleBEleBEleBEXLm8Ia5vE8p56jWEAdkzn17Fu+oYFLfMdnvMWTNrXt/vOeYgZf8OOmpoHNboTNooJ3N/eiGMe6IOE2v3GAPezipyBmCK8whw94j1rLu/+whIuupb7LWQX72o96N3mDZ/c8+ytIrGNHWJLLwiC3SmvyB0f5RnyQ7YK/BxaFZda8rnGIFcwKM63J7WU7Isy6VRy39GgIs7LU1HCKX9jAR7zIqM/a247hE7ZwjhMM55KyT5nA6w7qH3swUMU0XnacqMSkU5WykuRFkORFkORFkORFkORFkOSVmKL33B3xHyjMNPHcKVm2AAAAAElFTkSuQmCC) Symbol 2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAE8AAAAYCAYAAAC7v6DJAAABcklEQVRYhe3WsUsbYRzG8U9iFHSocemkk3QoFlQ6KNJFwdJNumYsdCq4lK6Cf4GOjtqh0M1NMbSbi+AmsaMdMugg7dSlJR0uYgxJFF9zd8j7hVvufe/5Pffc+773I9/M4X3WJrpRzNrALUxiMWsT3ch7eLkmhhdADC+AGF4AMbwAYngBlDKoWcEzVHGEv4F6BTzHMsawjkagZm4ZxbnkBX9jFx8kgbZTwZcO9582x7ZRb2o1JE11apRQxmyaRbGDT3iCleYFPyUrsopvLfOH8Uqyul5juoPmHkak11SfFZpGNlMqeMUQFnqM17GPH5jHKd5iqsczNVw8lME78DnFWjfYcr3VGviDA3zEi5Z57dt2HO/wFZdtGicY7LfxrJmR/CRq2MAbybbsRLczDwYkZ9waDvEPqw/qNIe8xMQd5/YKr50ylu7l6J5k0aoc90n3F773SbsjsUkOIIYXQAwvgBheADG8AGJ4AcTwHjFFOf7A/wHoGzaQ2FgQPwAAAABJRU5ErkJggg==) Symbol 3 一![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAAAYCAYAAABKtPtEAAABrklEQVRYhe3XP0hVYRjH8Y/3hqD0D5QQmqIhgwKjIJf+Y9ypxaEhCFqtoSmhwa0mh6RRJ6HVQR0uVkOEQ2AEjW1FQhS0iVDhcXjvLTvcK/fce/BVOd/xnPd53t/ze573cF6ys9hGzG7kIc60E7iRs5BYVFEpxVYRm8KA2AJiUxgQW0BsCgNwCZO4iZ6c8h7GLTzH2ZxytsITPMCpLEFdeIcE63iFRzhXe5em0X/AAQxjAm/xu5ZvIYuQHLhW2zfBZ8zgNvoarK2iUi/wgmBC+kj8wGss4SW+CgaUcFKYmhFcx5FU7B/cw2onFbXBBK6mnm3gg1DDEpYxj2d1A8qCY8ebJP0pTMZULbiCMaHwg01i1rAidGMnGcBgk3cJPmIOl4WjD+77NzqJ0L1lwc2L/p+MrUegG1fwFO9TORKMdlpNRrrxKaXhO17grmBOnarQSP1Ch79gWhB9dJtNtrsLHMMdzOKbMFW92etom3H8whs8xnmNv2NsMWAQpzNs0uplqIQhnMiQu1Nu4FCLa/8akJXiNrifKAyILSA2hQGxBcSmMCC2gL1IObaAnCijaxMJz1L/YkurSgAAAABJRU5ErkJggg==)

4 to N-5 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAhCAYAAADzjnq8AAAAJklEQVQYlWNkYGDQZWBgYGJhYGAIZGBgYGFigIJRBgMDAzOUfggAvpsBqn3ofL4AAAAASUVORK5CYII=) N-4 to N-1

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAANUAAAAHCAYAAACftginAAAAp0lEQVRYhe3WMWoCQRgF4G/ZInbBC0haDxDJDWwtLATrJK3kMDZ6Aj2NtVZikyZd6ljsQiS4YBpl5X3ww8DMwGuGeVyuxACdf9yJiD+e8IY1vrC6aZqIFnrECHNs8XMy3+jdLlpEOxR4wDsmqnpXNpz9xOFKuSLa6qOoFyWeMaznRfXgTm3wqvq1IuK8XdNGF2MssPdbAafXyRVx3wr0McNSVRcjosERhaYVs7t3td4AAAAASUVORK5CYII=) Modified STP Token ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAANYAAAAHCAYAAAB0gbOkAAAAq0lEQVRYhe3XMWpCURAF0GOCtrEKAcHa1sJ9BGx0FSnch6VIVuAWdAfqElJlA8HC9qPFDygB8SNEUe6B18x7A7cZmEdEnNNAD09VG57/L0vEwygwxlQ5YE38YHPLUBGPoIUtdkfnCxO84+X4cQ0jDK+bMeIutfB24q7ACjNMa2jj9UrBIu7ZJ7p/agWWmGOB9W8tIioYOKyA38oh6yv/WxFxgbpykD7QqdKwB9hWGdXDk7d2AAAAAElFTkSuQmCC)

L3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKElEQVQImdXGIQEAIAwAsHESYDCEe3Z6IDAv8akNJE5gYYfSKBMP9wOWxgKt7UyxAwAAAABJRU5ErkJggg==) L2 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKElEQVQImdXGMQ0AIAwAsGYTwLegF5mTwsWDifVq4qACGyt8g5K46AewTQLECCkG9gAAAABJRU5ErkJggg==) L1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAHklEQVQImWNgYGBYxsTAwCDHxMDAwEBjgoGBgSEaAF8MAUpvzCWJAAAAAElFTkSuQmCC) L0 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAHklEQVQImWNgYGA4w8DAwPCRiYGBgYHGBAMDA0MBAMYdAlbdnJTfAAAAAElFTkSuQmCC) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAHklEQVQImWNgYGA4xMDAwPCUiYGBgYHGBAMDA0MWALzJAjqbCq/SAAAAAElFTkSuQmCC) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKElEQVQImdXGMQ0AIAwAsDJOLGAFLbOPCsIzE+vVgYMMLOxQGmXi4X6wpQLY5WKZNwAAAABJRU5ErkJggg==) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJ0lEQVQImdXGIQEAIAwAsHESYCDfo9MDgXmJT20gcQILO5RGmXi4H5VAAquKqBM0AAAAAElFTkSuQmCC) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGBoZ2Bg4GNiYGCQZGBg4GdigIIhxrjDwMDwGgCuQAK0qt1jvwAAAABJRU5ErkJggg==) P ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYxcTAwCDPxMDAwEAH4jIAYbQByZO1UU4AAAAASUVORK5CYII=) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGC4yMDAwPCdiYGBgYEOxEkAyycCvHHbyTgAAAAASUVORK5CYII=) 1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYy8DAwHCfiYGBgYEOxDkAuJAClaJr+dAAAAAASUVORK5CYII=)ID1![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGBwYmBgCGViYGDgYWBgkGZigIIhxGBmYGAQY2BgEAYAp30BFvdVIz0AAAAASUVORK5CYII=)ID0![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGBIY2Bg4GVhYGAQYmBgEGBigIIhxGBmYGBQZGBg+AEAixsB329y1vkAAAAASUVORK5CYII=) L6 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGDoYWBgYGdiYGCQZGBg4GNigIIhxrjNwMDwBgCsBAKxPShSOgAAAABJRU5ErkJggg==) L5 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYz8TAwKDAxMDAwEAH4hIAZEgBzuR75GQAAAAASUVORK5CYII=) L4 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGC4xsDAwPCXiYGBgYEOxHEAz8wCxdy04XsAAAAASUVORK5CYII=) C3 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYwcTAwKDExMDAwEAH4jwAaQAB1qByxXAAAAAASUVORK5CYII=) C2![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGBwZ2Bg8GZiYGDgZWBgkGJigIIhxGBmYGAQZ2BgEAAAo7QBD8kbEgsAAAAASUVORK5CYII=) C1 ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImdXGMQEAIAwDsIzVATKxjRAeTCxXCgcdbGT5BiW46AeCCQGeYLuZ9wAAAABJRU5ErkJggg==) C0![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGCYyMDAwMDEwMAgxcDAwMvEAAVDjHGLgYHhLQCqigKvfEYTOwAAAABJRU5ErkJggg==)M11M10M9![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYwsTAwKDIxMDAwEAH4gIAZtsB0slzurcAAAAASUVORK5CYII=)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGC4zsDAwPCPiYGBgYEOxHEA0KUCxyGMCO4AAAAASUVORK5CYII=) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYzMTAwKDIxMDAwEAH4gIAZmwB0QQWFQ4AAAAASUVORK5CYII=) M8![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJ0lEQVQImdXGsQ0AIAgAsIqjCTvnsPv/PS4+QacuXHQgUeEblI3CeZ/uAQe3bxb6AAAAAElFTkSuQmCC) M7![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKElEQVQImdXGMQ0AIAwAsI4smQKMInke9vNggl4NHExio5bnoyQacwFIaQOMlkTZxQAAAABJRU5ErkJggg==) M6![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJUlEQVQImWNmYGCYycDA8IWJgYFBhoGBgZuJAQqGGOM6AwPDBwBumQOrTZfL3QAAAABJRU5ErkJggg==) M5![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGDYw8DAwHCPiYGBgYEOxDkAt7cCk0F6PT8AAAAASUVORK5CYII=) M4![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGA4x8DAwPCFiYGBgYEOxEkAyJwCtjc1aoEAAAAASUVORK5CYII=) M3![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAXCAYAAADKmiUPAAAAGklEQVQImWNgYGBYw8TAwCDPxMDAwEAH4jIAYpIBy84Srs0AAAAASUVORK5CYII=) M2![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKUlEQVQImWNkYGAIYWBgMGRiYGDgZ2BgkGBigIIhxGBmYGCQYWBgYAUAmeMA/PwekCsAAAAASUVORK5CYII=) M1![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAJ0lEQVQImdXGMREAIAgAwMcjA1XN60wFBhdL+NMHNjpRmOX5KImDvvsjBHKLlS2MAAAAAElFTkSuQmCC) M0![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAAXCAYAAAAhrZ4MAAAAKElEQVQImdXGMREAIAgAwD+Y3chhSxMSxtXFEvz0iYMb2KjwDUpioR9xXgLPwYM5iwAAAABJRU5ErkJggg==) Data ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAASCAYAAACaV7S8AAAAGklEQVQImWNgYGAIYmBgYDjJxMDAwEA9YiUAYXgB5czEFYMAAAAASUVORK5CYII=) LCRC

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAGCAYAAAACEPQxAAAAHUlEQVQImWNgYGBYwMTAwCDLxMDAwIAgGBgYGNwBE5IBDagAnrUAAAAASUVORK5CYII=) 7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 23 22 21 20 19 18 17 16 31 30 29 28 27 26 25 24

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIgAAAAMCAYAAAC5m/WcAAACqElEQVRYhe3XX2hWdRzH8ZfbclPSbfkvpgiSc2IjGTKhxW6mUSKkpgQ1F3gV1kVE0I2igkJXeREhC6IiL7TIIiX8izf+uRDFBKGi6I8mrdHEFlqUOS++58HHh9hz2M7zHC983zwPv3PO9/v5/r5/zu9wn/uMQi224zqujNHGCryBOTibka6x8C568Ad+yUnDTLyDdfg8Jw1Z0YdFNWjEU+MwtAYTE4N5MQ29eEAUbF50YT5WoiVHHVnwvNhPizGIjjEYWYbfxfT4Di9jQkYC01KPT0TntotYllRZA8zGt1iNnTiAhhx0ZEEvfsakQjKfwy6cwABuYB9Olzy4XHRoPVpFcb2A41ggNuUqLihfKP/iDHZjpGj9EWxAc4pA6vBk4u9F/Im16Mcp/IqaMjau4zOcLFnvEZMgTZKb8DTewpuJro/QjYO4lcJGOf7GEXxZsr5E5O/BDHzcwmOYi2dxvjiJzWJDpuIhvCrGzLHk+ivYhLdFAV3BUQwX2agTGzUX/5URU4+N+BRbRJEsxRfYgx/cXTilFLSfwlcl9zYlsTSm0DFdxNqHw8naS9gmYh3+/8fu0lFI3qWSax0ipglGjyUNU/AaNuODZG0V3hPNPThO+0T+vhcN/1e5m7vFNJiOTtGN8zIQUcwMfCOqtQGXk//VpkvEOkskdUCcJe412vCbmNwtQnNnJR3WjnLtknhttIqR3+/ONMmKGyIZr2OymCpbM/aRhsui+B/FeryPQznoKMeQ6PJn8Lh4RX+Yp6B2MRqHxJdKJajFT4mfJyrkIw1tiYZrolDvVZpFY43g4Zy1IIScq7CP/Ymfugr7KccIvs5ZQxr+Mf4zTSrKnfALVPqb/mbJb57MzltACqrWSGkc7cPFCuv4GAsr7CMNe/Fj3iJSsEOV9us2WEeCDcFsnx0AAAAASUVORK5CYII=)

Pta[3c:e]t Parity ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAtCAYAAADP5GkqAAAAh0lEQVRYhe3XoQ3CQACF4Q/aBElCahrWQTEBguAZgUk6CUzTMXA1CFBNCYb2zPvlnXifvKtMt0WF4cv9P9p8dibrcJ1xHI54rGce+VkAAQQQQAABBBBAAAEEUBxQY49mdL5bEnDBaXQ+4LYUolT5mgUQQAABBBAAWOGMQ4HtFs8avffDpET3FxL8Ci0laIf8AAAAAElFTkSuQmCC) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAA8CAYAAABMxmv5AAAAJ0lEQVQokWNkYGDgY2Bg+MvIwMAwiYGB4Q4TAxSMMkYu4wkDA8NrAJ1ZBL80PpxnAAAAAElFTkSuQmCC) CRC

PMUX Flag

PMUX Channel ID

PMUX Packet Length [6:4]

PMUX Packet Metadata

PMUX

Packet

Data

Notes:

1. PMUX Packet Length [6:0] = INT((N+1) / 4)

2. The LCRC used by PMUX at 128b/130b and at 8b10b are the same. Even though they do not appear in the PUMX Packet, the 128b/130b LCRC includes the four PMUX Channel ID bits that are located at Symbol 1 bits 15:12 of an

8b10b PMUX Packet. For 128b/130b Links, components construct an equivalent 4 bit value using the PMUX Channel ID value located at Symbol 1 bits 12:11 and include that constructed 4 bit value in the LCRC computation.

A-0849

Figure G-6 TLP and PMUX Packet Framing (128b/130b Encoding)

Table G-4 PMUX Packet Layout (128b/130b Encoding)

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Symbol | Field | Bit  Position(s) | PMUX Packet Usage | TLP Usage |
| 0 | Start TLP Indicator | 3:0 | Value of 1111b | |
| PMUX Packet Length[3:0] | 7:4 | Bits [3:0] of the PMUX Packet Length. Bit 0 is the least significant PMUX Packet Length bit. | Bits [3:0] of the TLP Length field. Bit 0 is the least significant TLP Length bit. |
| 1 | Frame Parity  (P) | 7 | Even parity of Symbol 0 bits [7:4], Symbol 1 bits [6:0] and Symbol 2 bits [7:4] | |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Symbol | Field | Bit  Position(s) | PMUX Packet Usage | TLP Usage |
|  | PMUX Packet Indicator | 6:5 | Value of 11b | Bits [10:4] of the TLP Length field. Bit 10 is the most significant TLP Length bit. |
| PMUX Channel ID[1:0] | 4:3 | PMUX Channel ID |
| PMUX Packet Length[6:4] | 2:0 | Bits [6:4] of PMUX Packet Length. Bit 6 is the most significant PMUX Packet Length bit. |
| 2 | PMUX Packet Metadata[11:8] | 3:0 | PMUX Packet Metadata[11:8] | TLP Sequence Number[11:8] |
| Frame CRC (C[3:0]) | 7:4 | CRC of Symbol 0, bits [7:4] and Symbol 1 bits [6:0] | |
| 3 | PMUX Packet Metadata[7:0] | 7:0 | PMUX Packet Metadata[7:0] | TLP Sequence Number[7:0] |
| 4 to N-5 | Packet | 7:0 | PMUX Packet | TLP |
| N-4 to N-1 | LCRC | 7:0 | PMUX LCRC | PCI Express LCRC |

[Table G-5](#bookmark48)describes the encodings of Symbol 1 bits [6:3] in more detail. If these bits contain a valueless than 1001b, the packet is a TLP and is processed as described in Section 4.2.2 .178 If these bits contain 1001b, 1010b, or 1011b, the

encoding is reserved for future standardization and is processed as described in Section 4.2.2.3.3 . If these bits contain a value greater than or equal to 1100b, the packet is a PMUX Packet is defined as specified in this appendix.179

Table G-5 Symbol 1 Bits [6:3]

|  |  |
| --- | --- |
| Symbol 1 bits [6:3] | Meaning |
| 0xxxb or 1000b | Packet is a TLP. Bits [6:3] are TLP Length [10:7]. |
| 1001b, 1010b, or 1011b | Encoding reserved for future standardization. Receivers detecting these encodings shall process them as described in Section 4.2.2.3.3 . |
| 1100b | Packet is a PMUX Packet. PMUX Channel ID is 0. |
| 1101b | Packet is a PMUX Packet. PMUX Channel ID is 1. |
| 1110b | Packet is a PMUX Packet. PMUX Channel ID is 2. |
| 1111b | Packet is a PMUX Packet. PMUX Channel ID is 3. |

For PMUX Packets, the packet length in DWORDs is contained in PMUX Packet Length [6:0]. Other than being a smaller field, PMUX Packet Length is interpreted in the same manner as TLP Length. Specifically, PMUX Packet Length also

includes the framing and PMUX LCRC DWORDs (seeSection 4.2.2.2).

For PMUX Packets, symbols 2 and 3 contain PMUX Packet Metadata in the same bit positions that TLPs use for TLP Sequence Number.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

178.The value 1001b supports a maximum TLP Length [10:0] value of 1151 DWORDs (decimal).This will accommodate a TLP consisting of 4096 bytes of payload, 16 bytes ofTLP Header, 4 bytes ofTLP digest, and 480 bytes ofTLP Prefix.

179.The value 1100b was chosen to simplify distinguishing PMUX Packets from TLPs and from the reserved encodings.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

The PMUX LCRC algorithm is identical to the TLP LCRC algorithm as described inSection 3.6.2with the following modifications:

• The seed value is FB3E E248h (TLP LCRC uses FFFF FFFFh).

• The PMUX Channel ID field in Symbol 1 bits 4:3 is used to compute a 4 bit value that is included in the PMUX

LCRC in the same manner as the 4 reserved bits in the TLP LCRC. This 4 bit value contains the value that would be used, by the 8b/10b encoding, for Symbol 1 bits 7:4. Specifically, the lower 2 bits of this 4 bit value contain the PMUX Channel ID and the upper 2 bits contain the inverse (1s complement) of the PMUX Channel ID.

• The PMUX Packet Metadata field is included in the PMUX LCRC in the same manner as the TLP Sequence Number field is included in the TLP LCRC.

The Frame CRC and Frame Parity fields are computed as shown below. This is the same algorithm computed over the same bit positions as defined in Section 4.2.2.2 .

![](data:image/png;base64,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)

L[6] L[5] L[4] L[3] L[2] L[1] ^ L[0]

^ C[3] ^ C[2] ^ C[1] ^ C[0]

**IMPLEMENTATION NOTE**

PMUX Channel ID and Frame CRC

When using 128b/130b encoding, the PMUX Channel ID field is covered by the Frame CRC and Frame Parity fields. As such, receivers may make decisions based on the PMUX Channel ID value as soon as the Frame CRC and Frame Parity is checked and need not wait until the PMUX LCRC is checked.

Note: The PMUX Channel ID is also covered by the LCRC. The value of the LCRC associated with a given PMUX Packet is independent of the encoding used to transmit the packet.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADCCAYAAAB0fINZAAAAOklEQVRYhe3KoQEAIAzAsI0nsZyG5cphsPOI1DYZ61R07ZmjnS8AAAAAAAAAAAAAAAAAAAAAAIDfwAXz2QSEmplM9wAAAABJRU5ErkJggg==)

**G.4 PMUX Control**

Protocol Multiplexing is disabled by default. Each PMUX Channel must be explicitly enabled by software at each end of the associated Link. Protocol Multiplexing is disabled whenever the link drops (Data Link Layer indicates DL\_Down).

A component that supports Protocol Multiplexing indicates such by the presence of the[PMUX Extended Capability.](#bookmark49) The following rules apply to components that support Protocol Multiplexing:

• PMUX Packets received in a PMUX Channel that is not enabled are silently ignored.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

• PMUX Packets may not be transmitted unless the associated PMUX Channel is enabled. A PMUX Channel may also require additional, protocol specific, initialization mechanisms before PMUX Packets may be transmitted.

**G.5 PMUX Extended Capability**

[Figure G-7](#bookmark51)shows the [PMUX Extended Capability](#bookmark50)structure. The presence of this capability indicates that the Port

supports the optional Protocol Multiplexing mechanism. This capability is optional and may be present in any

Downstream Port and in Function 0 of any Upstream Port. It must not be present in non-zero Functions of Upstream Ports or in RCRBs.

The length of the [PMUX Extended Capability](#bookmark50)is determined by the [PMUX Protocol Array Size](#bookmark52)field (see [Section G.5.2)](#bookmark53).

This capability contains a list of the protocols supported by the Link (the PMUX Protocol Array). It also contains the

mechanism software uses to enable and configure PMUX Channels. This capability must be present in both the Upstream and Downstream Ports of a Link in order for Protocol Multiplexing to be successfully enabled.

Software may enable the Upstream and Downstream Ports of a Link in either order. Software may enable multiple PMUX Channels using a single write to the[PMUX Control Register.](#bookmark54)

Behavior is undefined if software enables Protocol Multiplexing in one Port and the other Port of the Link does not support Protocol Multiplexing. Behavior is also undefined if software configures a PMUX Channel inconsistently (the same PMUX Channel in the Ports on each end of a Link configured with incompatible protocols).

31 16 15 0

|  |
| --- |
| PMUX Extended Capability Header |
| PMUX Capability |
| PMUX Control |
| PMUX Status |
| PMUX Protocol Array [1] |
| PMUX Protocol Array [2] |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAVCAYAAACOuSR+AAAAHElEQVQYlWNUllf4z4AGmNAFqCBIIWAcdScqAAB08AQ/UU0omQAAAABJRU5ErkJggg==)

|  |
| --- |
| PMUX Protocol Array [62] |
| PMUX Protocol Array [63] |

Byte Offset

00h

04h

08h

0Ch

10h

14h

104h

108h

A-0850

Figure G-7 [PMUX Extended Capability](#bookmark50)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAJEAAAAjCAYAAACU2uhdAAAB70lEQVR4nO3bvaoaURiF4TW/wTn+gKQQrAVvwd4qvYWFjUXKECxsnUpIZeElCKksrNJYqa23YLBIbaE7GHVmz2lyIOU3+QhmYD2dsAa2wws6oIjjuB/H8RREf8kFUAHw/tkHoeJyn30AKj5GRGqMiNQYEakxIlJjRKTGiEjNB4DtdtsC8PHJZ6Hi+QHgm1OpVD6t1+svjUYjffaJqFh2u50dDAYf/Mvl8q7VaqFer788+1BULMfj8SeAF34nIjVGRGqMiNQYEakxIlJjRKTGiEiNEZEaIyI1RkRqjIjUGBGpMSJSY0SkxohILXdEaZrCWvvf7JMkQZZlufZ55NlnWZZrb61Fmsp/C5h3/6/v/ZvcEU0mE0yn8r/uD4dDLBYL8b7b7WKz2Yj37XYbh8NBvI+iSLwFgGazKd7u93t0Oh3xfrVaodfriffz+Ryj0Ui8H4/HmM1m4n2/38dyuRTv3/DjjNQYEakxIlJjRKTmA/h1Op3cMAzvkgscx/EAwBgjekwIgsBP0zST7kulUnC/31NjjOgxoVwuB9frNTHGiB7RarVaaIwRvVcAqFar4v3tdnOjKPKMMQ/J/vF4uGEYusYY0SOdtdbzPM+R7l3X9QGI730QBH6SJFZ678/nswsgcX6//gygLLmQ6A/fAXx9BQ2GwBnfq5xoAAAAAElFTkSuQmCC)

31 20

Next Capability Offset

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**G.5.1 PMUX Extended Capability Header (Offset 00h)**

[Figure G-8](#bookmark55)details the allocation of fields in the [PMUX Extended Capability header;](#bookmark55)[Table G-6 pro](#bookmark56)vides the respective bit definitions.

|  |
| --- |
| 19 16 |
|  |

|  |
| --- |
| 15 0 |
|  |

PCI Express Extended Capability ID Capability Version

Figure G-8 PMUX Extended Capability Header Table G-6 PMUX Extended Capability Header

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 15:0 | **PCI Express Extended Capability ID** - This field is a PCI-SIG defined ID number that indicates the nature and format of the Extended Capability.  The Extended Capability ID for the [PMUX Extended Capability](#bookmark50)is 001Ah. | RO |
| 19:16 | **Capability Version** - This field is a PCI-SIG defined version number that indicates the version of the Capability structure present. Must be 1h for this version of the specification. | RO |
| 31:20 | **Next Capability Offset** - This field contains the offset to the next PCI Express Capability structure or 000h if no other items exist in the linked list of capabilities.  This offset is relative to the beginning of PCI compatible Configuration Space and thus must always be either 000h (for terminating the list of Capabilities) or greater than 0FFh. | RO |

**G.5.2 PMUX Capability Register (Offset 04h)**

[Figure G-9](#bookmark58)details the allocation of fields in the [PMUX Capability Register.](#bookmark53)[Table G-7 pro](#bookmark59)vides the respective bit definitions.

5 0

7 6

8

16

31

15

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
| RsvdP |

PMUX Protocol Array Size

RsvdP

PMUX Supported Link Speeds

Figure G-9 PMUX Capability Register

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Table G-7 PMUX Capability Register

|  |  |  |  |
| --- | --- | --- | --- |
| Bit Location | Register Description | | Attributes |
| 5:0 | **PMUX Protocol Array Size** - Indicates the size of this Function’s PMUX Protocol Array. This field may be 0 to indicate that even though no protocols are supported, the Port will ignore all received PMUX Packets. | | RO |
| 15:8 | **PMUX Supported Link Speeds** - This field indicates the Link speed(s) where Protocol Multiplexing is  supported. Each bit corresponds to a Link speed. If a bit is Set, Protocol Multiplexing is supported at that Link speed. If a bit is Clear, Protocol Multiplexing is not supported at that Link speed.  Bit definitions are: | | RO / RsvdP |
| **Bit 8 Bit 9 Bit 10 Bit 11 Bit 12**  **Bits 15:13** | 2.5 GT/s 5.0 GT/s 8.0 GT/s 16.0 GT/s 32.0 GT/s RsvdP |
| At least one Link speed must be supported (i.e., the field must be non-zero). A Port may support any combination of Link speeds. For example, this field could contain the value 0000 0100b indicating that Protocol Multiplexing is only supported at 8.0 GT/s.  This field must not indicate support for Link speeds that are not supported by the Link (see Section  7.5.3.18 ).  Note that this field indicates the Link speeds supported by Protocol Multiplexing for the Link. The Link speeds that a particular protocol supports and the mechanism used to report that information are  protocol specific. | |

**G.5.3 PMUX Control Register (Offset 08h)**

[Figure G-10](#bookmark62)details the allocation of fields in the [PMUX Control Register.](#bookmark61)[Table G-8 pro](#bookmark63)vides the respective bit definitions.

Channel n is enabled and available for use by the PMUX Protocol Layer when all of the following are true:

• The Channel n Assignment field is non-zero.

• The Channel n Assignment field is less than or equal to[PMUX Protocol Array Size.](#bookmark60)

• The Channel n Assignment field indicates an implemented entry in the PMUX Protocol Array (see[Section G.5.5](#bookmark64) ).

• All of the PMUX Channel n Disabled bits are Clear (see[Section G.5.4)](#bookmark65). Otherwise, Channel n is disabled.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

5 0

7 6

13 8

21 16

23 22

29 24

31 30

15 14

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
|  |

|  |
| --- |
|  |

PMUX Channel 0 Assignment

RsvdP

PMUX Channel 1 Assignment

RsvdP

PMUX Channel 2 Assignment

RsvdP

PMUX Channel 3 Assignment

RsvdP

Figure G-10 PMUX Control Register Table G-8 PMUX Control Register

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 5:0 | **PMUX Channel 0 Assignment** - This field indicates the protocol assigned to PMUX Channel 0. If the field is 0h, no protocol is assigned. If the field is non-zero, it is the index in the PMUX Protocol Array of the  protocol assigned to PMUX Channel 0.  If[PMUX Protocol Array Size](#bookmark60)is less than 63 (see [Section G.5.2](#bookmark53)), unused upper bits of this field may be hardwired to 0b. If[PMUX Protocol Array Size](#bookmark52)is 0, this entire field may be hardwired to 0.  This field defaults to 0h. | RW |
| 13:8 | **PMUX Channel 1 Assignment** - This field indicates the protocol assigned to PMUX Channel 1. If the field is 0h, no protocol is assigned. If the field is non-zero, it is the index in the PMUX Protocol Array of the  protocol assigned to PMUX Channel 1.  If[PMUX Protocol Array Size](#bookmark52)is less than 63 (see [Section G.5.2](#bookmark53)), unused upper bits of this field may be hardwired to 0b. If[PMUX Protocol Array Size](#bookmark52)is 0, this entire field may be hardwired to 0.  This field defaults to 0h. | RW |
| 21:16 | **PMUX Channel 2 Assignment** - This field indicates the protocol assigned to PMUX Channel 2. If the field is 0h, no protocol is assigned. If the field is non-zero, it is the index in the PMUX Protocol Array of the  protocol assigned to PMUX Channel 2.  If[PMUX Protocol Array Size](#bookmark52)is less than 63 (see [Section G.5.2](#bookmark53)), unused upper bits of this field may be hardwired to 0b. If[PMUX Protocol Array Size](#bookmark52)is 0, this entire field may be hardwired to 0.  This field defaults to 0h. | RW |
| 29:24 | **PMUX Channel 3 Assignment** - This field indicates the protocol assigned to PMUX Channel 3. If the field is 0h, no protocol is assigned. If the field is non-zero, it is the index in the PMUX Protocol Array of the  protocol assigned to PMUX Channel 3.  If[PMUX Protocol Array Size](#bookmark52)is less than 63 (see [Section G.5.2](#bookmark53)), unused upper bits of this field may be hardwired to 0b. If[PMUX Protocol Array Size](#bookmark52)is 0, this entire field may be hardwired to 0.  This field defaults to 0h. | RW |

**G.5.4 PMUX Status Register (Offset 0Ch)**

[Figure G-11](#bookmark70)details the allocation of fields in the [PMUX Status Register.](#bookmark65)[Table G-9 pro](#bookmark71)vides the respective bit definitions.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1267

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Each channel has a set of Disabled bits. When Channel n Assignment field is non-zero, the Channel n Disabled bits reflect the error status of the channel. The following Disabled bits are defined:

• PMUX Channel n Disabled: Link Speed

• PMUX Channel n Disabled: Link Width

• PMUX Channel n Disabled: Protocol Specific

When there are multiple reasons for disabling a channel, an implementation may choose which reason(s) to report. For example,if a protocol needs bandwidth equivalent to x1 8.0 GT/s, when there is inadequate bandwidth (e.g., the Link is operating atx1 5.0 GT/s, x1 2.5 GT/s, or x2 2.5 GT/s), it could disable the PMUX Channel by indicating any or all of

Disabled: Link Width, Disabled: Link Speed, or Disabled: Protocol Specific.

31 27

0

2

8

9

10

16

18

7 3

24

25

26

23 19

1

15 11

17

|  |
| --- |
| RsvdZ |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA0AAAAYCAYAAAAh8HdUAAAAdklEQVQ4je3OsQ1CIRSF4Z8L8YXEvAVkh7sFtYVruYAL2FiyFQmtJo+AtRW0Jvz1+ZJjgB24MdcbeDpVfaSUrtbaOhI5Z6OqJyci5xDCBmwj5L3/ALtM3vppoYUW+kvUe7ez49aaALhSyj3GeDHGHCNUaz2A1xcwzxuRE/mFBAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA0AAAAYCAYAAAAh8HdUAAAAdUlEQVQ4je3OoQ3FIACE4Z+G5AVRgWSEJk93BXZBIxnhzcEWyDdBVUeoaYKraamuAtuE0/flTgBfYKYtK/AXzrk9hPABSk3EGE/v/SSVUqMxRrbMaK0PQA6Ntx7pqKOO3opEa7mUMgDIlNLPWmuBq4Zyzguw3YQ+GV8AQX78AAAAAElFTkSuQmCC)

PMUX PMUX PMUX PMUX PMUX PMUX PMUX PMUX PMUX PMUX PMUX PMUX

|  |
| --- |
| RsvdZ |

|  |
| --- |
| RsvdZ |

|  |
| --- |
| RsvdZ |

Channel 0 Disabled: Link Speed

Channel 0 Disabled: Link Width

Channel 0 Disabled: Protocol Specific

Channel 1 Disabled: Link Speed

Channel 1 Disabled: Link Width

Channel 1 Disabled: Protocol Specific

Channel 2 Disabled: Link Speed

Channel 2 Disabled: Link Width

Channel 2 Disabled: Protocol Specific

Channel 3 Disabled: Link Speed

Channel 3 Disabled: Link Width

Channel 3 Disabled: Protocol Specific

Figure G-11 PMUX Status Register Table G-9 PMUX Status Register

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 0 | **PMUX Channel 0 Disabled: Link Speed** - If Set, Channel 0 is disabled because the Current Link Speed (Section 7.8.8 ) is not supported by Protocol Multiplexing or by the protocol assigned to Channel 0. This bit is 0 when no protocol is assigned to Channel 0 (i.e., Channel 0 Control field is 0h). | RO |
| 1 | **PMUX Channel 0 Disabled: Link Width** - If Set, Channel 0 is disabled because the current Link Width is not supported by the protocol assigned to Channel 0.  This bit is 0 when no protocol is assigned to Channel 0 (i.e.,[PMUX Channel 0 Assignment](#bookmark66)field is 0h). | RO |
| 2 | **PMUX Channel 0 Disabled: Protocol Specific** - If Set, Channel 0 is disabled for protocol specific reasons. This bit is 0 when no protocol is assigned to Channel 0 (i.e.,[PMUX Channel 0 Assignment](#bookmark66)field is 0h). | RO |
| 8 | **PMUX Channel 1 Disabled: Link Speed** - If Set, Channel 1 is disabled because the Current Link Speed (Section 7.8.8 ) is not supported by Protocol Multiplexing or by the protocol assigned to Channel 1. This bit is 0 when no protocol is assigned to Channel 1 (i.e.,[PMUX Channel 1 Assignment](#bookmark67)field is 0h). | RO |
| 9 | **PMUX Channel 1 Disabled: Link Width** - If Set, Channel 1 is disabled because the current Link Width is not supported by the protocol assigned to Channel 1.  This bit is 0 when no protocol is assigned to Channel 1 (i.e.[PMUX Channel 1 Assignment](#bookmark67)field is 0h). | RO |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 10 | **PMUX Channel 1 Disabled: Protocol Specific** - If Set, Channel 1 is disabled for protocol specific reasons. This bit is 0 when no protocol is assigned to Channel 1 (i.e.,[PMUX Channel 1 Assignment](#bookmark67)field is 0h). | RO |
| 16 | **PMUX Channel 2 Disabled: Link Speed** - If Set, Channel 2 is disabled because the Current Link Speed (Section 7.8.8 ) is not supported by Protocol Multiplexing or by the assigned protocol.  This bit is 0 when no protocol is assigned to Channel 2 (i.e.,[PMUX Channel 2 Assignment](#bookmark68)field is 0h). | RO |
| 17 | **PMUX Channel 2 Disabled: Link Width** - If Set, Channel 2 is disabled because the current Link Width is not supported by the assigned protocol.  This bit is 0 when no protocol is assigned to Channel 2 (i.e.,[PMUX Channel 2 Assignment](#bookmark68)field is 0h). | RO |
| 18 | **PMUX Channel 2 Disabled: Protocol Specific** - If Set, Channel 2 is disabled for protocol specific reasons. This bit is 0 when no protocol is assigned to Channel 2 (i.e.,[PMUX Channel 2 Assignment](#bookmark68)field is 0h). | RO |
| 24 | **PMUX Channel 3 Disabled: Link Speed** - If Set, Channel 3 is disabled because the Current Link Speed (Section 7.8.8 ) is not supported by Protocol Multiplexing or by the assigned protocol.  This bit is 0 when no protocol is assigned to Channel 3 (i.e.,[PMUX Channel 3 Assignment](#bookmark69)field is 0h). | RO |
| 25 | **PMUX Channel 3 Disabled: Link Width** - If Set, Channel 3 is disabled because the current Link Width is not supported by the assigned protocol.  This bit is 0 when no protocol is assigned to Channel 3 (i.e.,[PMUX Channel 3 Assignment](#bookmark69)field is 0h). | RO |
| 26 | **PMUX Channel 3 Disabled: Protocol Specific** - If Set, Channel 3 is disabled for protocol specific reasons. This bit is 0 when no protocol is assigned to Channel 3 (i.e.,[PMUX Channel 3 Assignment](#bookmark69)field is 0h). | RO |

**G.5.5 PMUX Protocol Array (Offsets 10h through 48h)**

The [PMUX Protocol Array](#bookmark64)consists of up to 63 entries. The size of the [PMUX Protocol Array](#bookmark64)is indicated by the [PMUX](#bookmark60) [Protocol Array Size](#bookmark60)field (see [Section G.5.2)](#bookmark57).

[Figure G-12](#bookmark72)details the allocation of fields in each [PMUX Protocol Array Entry.](#bookmark64)[Table G-10 pro](#bookmark73)vides the respective bit definitions.

15 0

31 16

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Authority ID |  |  | Protocol ID |  |

Figure G-12 PMUX Protocol Array Entry Table G-10 PMUX Protocol Array Entry

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 15:0 | **Protocol ID** - In conjunction with Authority ID designates a specific protocol and the mechanism by which that protocol is mapped onto Protocol Multiplexing.  This value is assigned by the Vendor associated with the [Authority ID](#bookmark75)field. | RO |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |
| --- | --- | --- |
| Bit Location | Register Description | Attributes |
| 31:16 | **Authority ID** - Designates the authority controlling the values used in the [Protocol ID](#bookmark74)field. The Authority ID field contains a Vendor ID as assigned by the PCI-SIG. | RO |

The value 0000 0000h indicates an unimplemented[PMUX Protocol Array Entry](#bookmark64). The PMUX Protocol Array is indexed starting at 1.

PMUX Channel n is enabled and configured to support the protocol associated with [PMUX Protocol Array Entry](#bookmark64)at index m when the PMUX Channel n Assignment field contains the value m (see [Section G.5.3)](#bookmark54).

Entries in the PMUX Protocol Array with the Authority ID value 1 (0001h) represent protocols that are defined by the PCI-SIG.

Duplicate Entries in the PMUX Protocol Array may be used to represent multiple instances of a particular protocol. This permits software control of the mapping between PMUX Channel ID and a specific instance of a protocol.

**IMPLEMENTATION NOTE**

Multiple Protocol Instances

A Link may have a single PMUX Protocol assigned to multiple PMUX Channels. Each PMUX Channel is assigned to a different instance of the protocol. Each instance of a protocol corresponds to an entry in the PMUX Protocol

Array.

Consider a Port that supports two instances of protocol X. Two entries in the PMUX Protocol Array would indicate protocol X (indexes A and B for example). To assign instance A to PMUX Channel 0 and instance B to PMUX

Channel 2, place the value A in the [PMUX Channel 0 Assignment](#bookmark66)field and the value B in the [PMUX Channel 2](#bookmark68) [Assignment](#bookmark68)field.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAADkCAYAAACliWVyAAAAQElEQVRYhe3MsQ0AIAwDwYQlaRmNlinDBCg9Ord/ckSzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAB8Ay67TATGzqKZhAAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Flow Control Update Latency and ACK Update Latency Calculations**

**H.**

This appendix is informational only and should not be considered normative. Earlier revisions of this specification outlined the method used to calculate the Flow Control Update Latency and Ack Update Latency. This appendix describes the method used to derive the values and

preserves the UpdateFactor and AckFactor values.

**H.1 Flow Control Update Latency**

Recommended Flow Control Update Latency is described in the Implementation Note in Section 2.6.1.2entitled, FC Information Tracked by Receiver.

Flow Control Update Latency tables were simplified in the 4.0 Revision of this specification. At that time, the original

tables were moved to this appendix. Note that in the 4.0 Revision of this specification, Tables 2-47 and 2-48 were distinct, but identical tables. The 5.0 Revision contains a single table that applies to 8.0 GT/s or higher.

|  |  |  |  |
| --- | --- | --- | --- |
| Original Tables | | Simplified Tables | |
| Base 3.1 | Base 4.0 or later | Base 4.0 | Base 5.0 or later |
| Table 2-42 | [Table H-1](#bookmark76) | Table 2-45 | Table 2-46 |
| Table 2-43 | [Table H-2](#bookmark77) | Table 2-46 | Table 2-47 |
| Table 2-44 | [Table H-3](#bookmark78) | Table 2-47 | Table 2-48 |
| n/a | n/a | Table 2-48 |

The values in the Tables are measured starting from when the Receiver Transaction Layer makes additional receive buffer space available by processing a received TLP, to when the first Symbol of the corresponding UpdateFC DLLP is transmitted. The values are calculated as a function of the largest TLP payload size and Link width using the formula:

LinkWidth + InternalDelay

( Max\_Payload\_Size +TLPOverhead ) × UpdateFactor

Equation H-1 Max UpdateFC Latency

where:

**Max\_Payload\_Size**

The value in theMax\_Payload\_Sizefield of the Device Control register. For a Multi-Function Device, it is recommended that the smallest Max\_Payload\_Sizesetting across all Functions180 is used.

**TLPOverhead**

Represents the additional TLP components which consume Link bandwidth (TLP Prefix, header, LCRC, framing Symbols) and is treated here as a constant value of 28 Symbols.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)180. For ARI Devices, the Max\_Payload\_Sizeis determined solely by the setting in Function 0, and thus the settings in the other Functions should be ignored.

Page 1271

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**UpdateFactor**

Represents the number of maximum size TLPs sent during the time between UpdateFC receptions, and is used to balance Link bandwidth efficiency and receive buffer sizes -the value varies according toMax\_Payload\_Sizeand Link width.[Table H-1 ,](#bookmark79)[Table H-2 ,](#bookmark80) and [Table H-3](#bookmark81)below include the UpdateFactor(UF).

**LinkWidth**

The operating width of the Link

**InternalDelay**

Represents the internal processing delays for received TLPs and transmitted DLLPs, and is treated here as a

constant value of 19 Symbol Times for 2.5 GT/s mode operation, 70 Symbol Times for 5.0 GT/s mode operation, and 115 Symbol Times for 8.0 GT/s and 16.0 GT/s modes of operation.

Table H-1 Maximum UpdateFC Transmission Latency Guidelines for 2.5 GT/s Mode Operation by

Link Width and Max Payload (Symbol Times)

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
| Max\_Payload\_Size | 128 | 237  UF = 1.4 | 128  UF = 1.4 | 73  UF = 1.4 | 67  UF = 2.5 | 58  UF = 3.0 | 48  UF = 3.0 | 33  UF = 3.0 |
| 256 | 416  UF = 1.4 | 217  UF = 1.4 | 118  UF = 1.4 | 107  UF = 2.5 | 90  UF = 3.0 | 72  UF = 3.0 | 45  UF = 3.0 |
| 512 | 559  UF = 1.0 | 289  UF = 1.0 | 154  UF = 1.0 | 86  UF = 1.0 | 109  UF = 2.0 | 86  UF = 2.0 | 52  UF = 2.0 |
| (bytes) | 1024 | 1071  UF = 1.0 | 545  UF = 1.0 | 282  UF = 1.0 | 150  UF = 1.0 | 194  UF = 2.0 | 150  UF = 2.0 | 84  UF = 2.0 |
| 2048 | 2095  UF = 1.0 | 1057  UF = 1.0 | 538  UF = 1.0 | 278  UF = 1.0 | 365  UF = 2.0 | 278  UF = 2.0 | 148  UF = 2.0 |
| 4096 | 4143  UF = 1.0 | 2081  UF = 1.0 | 1050  UF = 1.0 | 534  UF = 1.0 | 706  UF = 2.0 | 534  UF = 2.0 | 276  UF = 2.0 |

Table H-2 Maximum UpdateFC Transmission Latency Guidelines for 5.0 GT/s Mode Operation by

Link Width and Max Payload (Symbol Times)

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
| Max\_Payload\_Size | 128 | 288  UF = 1.4 | 179  UF = 1.4 | 124  UF = 1.4 | 118  UF = 2.5 | 109  UF = 3.0 | 99  UF = 3.0 | 84  UF = 3.0 |
| 256 | 467  UF = 1.4 | 268  UF = 1.4 | 169  UF = 1.4 | 158  UF = 2.5 | 141  UF = 3.0 | 123  UF = 3.0 | 96  UF = 3.0 |
| 512 | 610  UF = 1.0 | 340  UF = 1.0 | 205  UF = 1.0 | 137  UF = 1.0 | 160  UF = 2.0 | 137  UF = 2.0 | 103  UF = 2.0 |
| (bytes) |
| 1024 | 1122  UF = 1.0 | 596  UF = 1.0 | 333  UF = 1.0 | 201  UF = 1.0 | 245  UF = 2.0 | 201  UF = 2.0 | 135  UF = 2.0 |
| 2048 | 2146  UF = 1.0 | 1108  UF = 1.0 | 589  UF = 1.0 | 329  UF = 1.0 | 416  UF = 2.0 | 329  UF = 2.0 | 199  UF = 2.0 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
|  | 4096 | 4194  UF = 1.0 | 2132  UF = 1.0 | 1101  UF = 1.0 | 585  UF = 1.0 | 757  UF = 2.0 | 585  UF = 2.0 | 327  UF = 2.0 |

Table H-3 Maximum UpdateFC Transmission Latency Guidelines for 8.0 GT/s Operation by Link

Width and Max Payload (Symbol Times)

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
| Max\_Payload\_Size | 128 | 333  UF = 1.4 | 224  UF = 1.4 | 169  UF = 1.4 | 163  UF = 2.5 | 154  UF = 3.0 | 144  UF = 3.0 | 129  UF = 3.0 |
| 256 | 512  UF = 1.4 | 313  UF = 1.4 | 214  UF = 1.4 | 203  UF = 2.5 | 186  UF = 3.0 | 168  UF = 3.0 | 141  UF = 3.0 |
| 512 | 655  UF = 1.0 | 385  UF = 1.0 | 250  UF = 1.0 | 182  UF = 1.0 | 205  UF = 2.0 | 182  UF = 2.0 | 148  UF = 2.0 |
| (bytes) | 1024 | 1167  UF = 1.0 | 641  UF = 1.0 | 378  UF = 1.0 | 246  UF = 1.0 | 290  UF = 2.0 | 246  UF = 2.0 | 180  UF = 2.0 |
| 2048 | 2191  UF = 1.0 | 1153  UF = 1.0 | 634  UF = 1.0 | 374  UF = 1.0 | 461  UF = 2.0 | 374  UF = 2.0 | 244  UF = 2.0 |
| 4096 | 4239  UF = 1.0 | 2177  UF = 1.0 | 1146  UF = 1.0 | 630  UF = 1.0 | 802  UF = 2.0 | 630  UF = 2.0 | 372  UF = 2.0 |

**H.2 Ack Latency**

Ack Latency tables were simplified in the 4.0 Revision of this specification. At that time, the original tables were moved to this appendix. Note that in the 4.0 Revision of this specification, Tables 3-9 and 3-10 were distinct, but identical tables. The 5.0 Revision contains a single table that applies to 8.0 GT/s or higher.

|  |  |  |  |
| --- | --- | --- | --- |
| Original Tables | | Simplified Tables | |
| Base 3.1 | Base 4.0 or later | Base 4.0 | Base 5.0 or later |
| Table 3-7 | [Table H-4](#bookmark82) | Table 3-7 | Table 3-7 |
| Table 3-8 | [Table H-5](#bookmark83) | Table 3-8 | Table 3-8 |
| Table 3-9 | [Table H-6](#bookmark84) | Table 3-9 | Table 3-9 |
| n/a | n/a | Table 3-10 |

The Maximum Ack Latency limits are calculated using the formula:

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

LinkWidth + InternalDelay

( Max\_Payload\_Size+TLPOverhead ) × UpdateFactor

Equation H-2 Max Ack Latency

where:

**Max\_Payload\_Size**

is the value in theMax\_Payload\_Sizefield of the Device Control register. For ARI Devices, the Max\_Payload\_Sizeis determined solely by the setting in Function 0. For a non-ARI Multi-Function Devicewhose Max\_Payload\_Size

settings are identical across all Functions, the commonMax\_Payload\_Sizesetting must be used. For a non-ARI

Multi-Function Devicewhose Max\_Payload\_Sizesettings are not identical across all Functions, the selected

Max\_Payload\_Sizesetting is implementation specific, but it is recommended to use the smallest Max\_Payload\_Size setting across all Functions.

**TLPOverhead**

represents the additional TLP components which consume Link bandwidth (TLP Prefix, header, LCRC, framing Symbols) and is treated here as a constant value of 28 Symbols.

**AckFactor**

represents the number of maximum size TLPs which can be received before an Ack is sent, and is used to balance Link bandwidth efficiency and retry buffer size -the value varies according toMax\_Payload\_Sizeand Link width. Table H-4, Table H-5, and Table H-6 below include the AckFactor(AF).

**LinkWidth**

is the operating width of the Link.

**InternalDelay**

represents the internal processing delays for received TLPs and transmitted DLLPs, and is treated here as a constant value of 19 Symbol Times for 2.5 GT/s mode operation, 70 Symbol Times for 5.0 GT/s operation, and 115 Symbol

Times for 8.0 GT/s and 16.0 GT/s operation.

Table H-4 Maximum Ack Latency Limit and AckFactor for 2.5 GT/s (Symbol Times)

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
| Max\_Payload\_Size | 128 | 237  AF = 1.4 | 128  AF = 1.4 | 73  AF = 1.4 | 67  AF = 2.5 | 58  AF = 3.0 | 48  AF = 3.0 | 33  AF = 3.0 |
| 256 | 416  AF = 1.4 | 217  AF = 1.4 | 118  AF = 1.4 | 107  AF = 2.5 | 90  AF = 3.0 | 72  AF = 3.0 | 45  AF = 3.0 |
| 512 | 559  AF = 1.0 | 289  AF = 1.0 | 154  AF = 1.0 | 86  AF = 1.0 | 109  AF = 2.0 | 86  AF = 2.0 | 52  AF = 2.0 |
| 1024 | 1071  AF = 1.0 | 545  AF = 1.0 | 282  AF = 1.0 | 150  AF = 1.0 | 194  AF = 2.0 | 150  AF = 2.0 | 84  AF = 2.0 |
| (bytes) |
| 2048 | 2095  AF = 1.0 | 1057  AF = 1.0 | 538  AF = 1.0 | 278  AF = 1.0 | 365  AF = 2.0 | 278  AF = 2.0 | 148  AF = 2.0 |
| 4096 | 4143  AF = 1.0 | 2081  AF = 1.0 | 1050  AF = 1.0 | 534  AF = 1.0 | 706  AF = 2.0 | 534  AF = 2.0 | 276  AF = 2.0 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

Table H-5 Maximum Ack Transmission Latency Limit and AckFactor for 5.0 GT/s (Symbol

Times)

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
| Max\_Payload\_Size | 128 | 288  AF = 1.4 | 179  AF = 1.4 | 124  AF = 1.4 | 118  AF = 2.5 | 109  AF = 3.0 | 99  AF = 3.0 | 84  AF = 3.0 |
| 256 | 467  AF = 1.4 | 268  AF = 1.4 | 169  AF = 1.4 | 158  AF = 2.5 | 141  AF = 3.0 | 123  AF = 3.0 | 96  AF = 3.0 |
| 512 | 610  AF = 1.0 | 340  AF = 1.0 | 205  AF = 1.0 | 137  AF = 1.0 | 160  AF = 2.0 | 137  AF = 2.0 | 103  AF = 2.0 |
| (bytes) | 1024 | 1122  AF = 1.0 | 596  AF = 1.0 | 333  AF = 1.0 | 201  AF = 1.0 | 245  AF = 2.0 | 201  AF = 2.0 | 135  AF = 2.0 |
| 2048 | 2146  AF = 1.0 | 1108  AF = 1.0 | 589  AF = 1.0 | 329  AF = 1.0 | 416  AF = 2.0 | 329  AF = 2.0 | 199  AF = 2.0 |
| 4096 | 4194  AF = 1.0 | 2132  AF = 1.0 | 1101  AF = 1.0 | 585  AF = 1.0 | 757  AF = 2.0 | 585  AF = 2.0 | 327  AF = 2.0 |

Table H-6 Maximum Ack Transmission Latency Limit and AckFactor for 8.0 GT/s (Symbol

Times)

|  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
|  | | Link Operating Width | | | | | | |
| x1 | x2 | x4 | x8 | x12 | x16 | x32 |
| Max\_Payload\_Size | 128 | 333  AF = 1.4 | 224  AF = 1.4 | 169  AF = 1.4 | 163  AF = 2.5 | 154  AF = 3.0 | 144  AF = 3.0 | 129  AF = 3.0 |
| 256 | 512  AF = 1.4 | 313  AF = 1.4 | 214  AF = 1.4 | 203  AF = 2.5 | 186  AF = 3.0 | 168  AF = 3.0 | 141  AF = 3.0 |
| 512 | 655  AF = 1.0 | 385  AF = 1.0 | 250  AF = 1.0 | 182  AF = 1.0 | 205  AF = 2.0 | 182  AF = 2.0 | 148  AF = 2.0 |
| (bytes) | 1024 | 1167  AF = 1.0 | 641  AF = 1.0 | 378  AF = 1.0 | 246  AF = 1.0 | 290  AF = 2.0 | 246  AF = 2.0 | 180  AF = 2.0 |
| 2048 | 2191  AF = 1.0 | 1153  AF = 1.0 | 634  AF = 1.0 | 374  AF = 1.0 | 461  AF = 2.0 | 374  AF = 2.0 | 244  AF = 2.0 |
| 4096 | 4239  AF = 1.0 | 2177  AF = 1.0 | 1146  AF = 1.0 | 630  AF = 1.0 | 802  AF = 2.0 | 630  AF = 2.0 | 372  AF = 2.0 |

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Async Hot-Plug Reference Model**

This appendix presents a recommended reference model for async hot-plug. The reference model covers three areas:

**I.**

• Async hot-plug initial configuration

• Async removal configuration and interrupt handling

• Async hot-add configuration and interrupt handling

There are no normative requirements in this section. The entire reference model is contained in a series of

implementation notes. The reference model documents how the various hot-plug mechanisms are envisioned be used to implement a robust asynchronous hot-plug model, but does not mandate that they be used that way.

For brevity and readability, this section uses the following acronyms:

**DLL**

Data Link Layer

**DSP**

Downstream Port

**FWF**

firmware first

**HPS**

Hot-Plug Surprise

**OOB**

out-of-band

**OS**

operating system

**PD**

presence detect

**SFW**

system firmware

The reference model covers both the HPS and DPC mechanisms. DPC is the recommended mechanism. The reference model covers FWF for DPC but not for HPS.

The reference model provides a recommended framework for DPC software to supportContainment Error Recovery (CER) along with async hot-plug. The reference model does not explicitly coverCERoutside of async hot-plug, but certain aspects can be leveraged for DPC support ofCERwhen async hot-plug is not being used.

SFW may use theSystem Firmware Intermediary (SFI) Capability for async hot-plug, orderly removal hot-plug, or other operations. This reference model does not rely on its functionality nor cover its use.

The reference model refers to various bits or fields outlined in Section 6.7.2. For brevity, pointers to the associated registers are not replicated in this section.

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

In-band Presence Detect Mechanism Deprecated for Async Hot-Plug

Due to architectural issues, the in-band (Physical-Layer-based) portion of the PD mechanism is deprecated for

use with async hot-plug. One issue is that in-band PD as architected does not detect adapter removal during

certain LTSSM states, notably the L1and Disabled States. Another issue is that when both in-band and OOB PD are being used together, the Presence Detect State bit and its associated interrupt mechanism always reflect the

logical OR of the inband and OOB PD states, and with some hot-plug hardware configurations, it is important for software to detect and respond to in-band and OOB PD events independently.

IfOOB PD is being used and the associated DSP supports In-Band PD Disable, it is recommended that the In-Band

PD Disable bit be Set, and the Presence Detect State bit and its associated interrupt mechanism be used exclusively for OOB PD.

As a substitute for in-band PD with async hot-plug, the reference model uses either the DPC or the DLL Link Active mechanism.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFPCAYAAABwJY/rAAAAS0lEQVRoge3MoREAIAwEwYQmsZSGpcpQAROJ2be38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAL/ABWgqBZxS1Qy6AAAAAElFTkSuQmCC)

The reference model assumes and covers the configurations listed below. While these cover the bulk of the envisioned use cases, many minor variations are not explicitly covered. For example, there are multiple ways to determine if a slot supports OOB PD, and the reference model does not cover them. As another example, the reference model refers to

adding or removing an adapter, but some hot-pluggable modules may include a Switch and multiple Endpoint components.

• Reference model assumptions:

。 DSPs support DLL Link Active Reporting

。 DSPs support In-Band PD Disable

。 Operating systems support both HPS and DPC, using DPC if available • Reference model covers:

。 Slots that support HPS and/or DPC (SW never enables both at same time) 。 Slots with or without OOB PD

。 RPs with or without RP Extensions for DPC

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**I.1 Async Hot-Plug Initial Configuration**

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAN2CAYAAADEz8inAAAAf0lEQVR4nO3MMREAIAwEwQSTtEijRWVQwEQA++3tfESzjHXqWffM0T0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB8CC4a3gnq6LJoPQAAAABJRU5ErkJggg==)

**IMPLEMENTATION NOTE**

Async Hot-Plug Initial Configuration

|  |  |  |
| --- | --- | --- |
| Basic Steps | HPS | DPC |
| Determine capability control entity | • OS requests, and is granted control of PCIe Native Hot-Plug  • If FWF, SFW retains control of AER and DPC  • Else OS requests and is granted control of AER and DPC | |
| OS and SFW determine which async hot-plug mechanism to use; OS/SFW interactions here are outside scope of this  specification | • If DPC capability then  。 If HPS bit not Set, use DPC  。 Else attempt to Clear HPS bit (Section  6.7.4.4 )  ▪ If successful, use DPC  ▪ Else use HPS  • Else if HPS bit Set, use HPS  • Else async hot-plug cannot be supported by this slot  • Configure DSP for selected mechanism | |
| OS determines if adapter present | • IfOOB PD supported, use it to determine if adapter is present  。 Set In-band PD Disable bit (SFW may have it Set by default)  。 Read PD State bit  • Else allow Link to attempt to train; use DLL Link Active to determine if adapter is present (and at least minimally functional) | |
| If adapter is present, OS waits for adapter to become ready for configuration | • If using Device Readiness Status (DRS), begin  configuration if/after DSP receives a DRS Message  • If using CRS Software Visibility, can attempt first  Configuration Read (of Vendor ID field) after 100 ms  • Otherwise, must wait at least 1000 ms before attempting first Configuration Read | |
| OS configures for appropriate case | • If adapter is present, configure system for handling async removal  • Else configure system for handling async hot-add | |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1280

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**I.2 Async Removal Configuration and Interrupt Handling**

**IMPLEMENTATION NOTE**

Async Removal Configuration

|  |  |  |  |
| --- | --- | --- | --- |
| Basic Steps |  | HPS | DPC |
| OS/SFW configure appropriate error handling | •  • | IfOS and driver support a non-CER error  recovery approach, its policies may influence some of these error settings  Configure the error handling supported by HPS | • IfOS and driver support CER, its policies may influence some of these error settings  • Enable uncorrectable AER errors to trigger DPC, including  Surprise Down  • If using RP Extensions for DPC, configure RP PIO error handling  • Configure RP Completion  Timeout handling per platform and OS policies |
| OS/SFW configure async removal  interrupts |  | • OS enables DLL State Changed interrupt | • If FWF, configure DPC for  ERR\_CORsignaling to enable SFW handling  • Else configure DPC for interrupt to enable OS handling |
| • | IfOOB PD supported, OS enables PD Changed interrupt | |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAIMCAYAAADIAe20AAAAXUlEQVR4nO3MsQ0AIAwDwYQlaRmNlinDBCg10rn9kyOaZaxTz7pnju4BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAL4AFy/xBxbwPm/bAAAAAElFTkSuQmCC)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAANpCAYAAAA2T3jpAAAAf0lEQVR4nO3MoREAIAwEwYQmsZSGpcpQAROD3Le38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAvcAGQ2QnQ/J0nYAAAAABJRU5ErkJggg==)

**IMPLEMENTATION NOTE**

Async Removal Interrupt Handling

|  |  |  |  |
| --- | --- | --- | --- |
| Basic Steps |  | HPS | DPC |
| Service routine entry | • | If PD Changed or DLL State Change, OS is interrupted | • If PD Changed, OS is interrupted  。 If FWF, OS invokes SFW; preferably via OS Setting DPC Software Trigger bit (if  implemented) |
| • If DPC triggered  。 If FWF, DPC sends ERR\_CORto signal SFW 。 Else DPC interrupts OS |
| Prevent further Link activity | •  • | OS Sets Disable Link; Link goes down and stays down  OS polls DLL Link Active until Clear | • DPC automatically keeps Link down |
| Log errors from DSP’s AER/DPC |  |  | • If FWF, SFW logs DSP errors  。 SFW invokes OS and exits |
| • | OS logs and then clears DSP errors | |

OS notifies impacted software/driver, which cease accessing the adapter

|  |  |
| --- | --- |
| OS determines if adapter is still present | • Some FFs with OOB PD automatically power off slot and/or disable switched signals  • IfOOB PD supported, use it to determine if adapter is physically present  • If adapter not determined to be absent, re-enable the Link and slot 。 As applicable, Clear Disable Link or release DPC  。 Wait until Link trains or adapter is deemed absent or non-functional 。 If non-functional, optionally perform a slot reset (if supported)  。 If still non-functional, optionally power-cycle the slot (if supported) |
| IfOS determined | • OS waits for adapter to become ready for configuration |
| adapter to be present | • OS enumerates and configures the adapter  • If DPC and FWF, OS invokes SFW to log adapter AER errors |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1282

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |  |
| --- | --- | --- |
| Basic Steps | HPS | DPC |
|  | • OS logs adapter AER errors and then clears them | |
|  | • IfOS determines the adapter is suitable for continued operation | |
|  | 。 OS configures for async removal handling | |
|  | 。 OS resumes driver | |
|  | • Else OS takes OS-specific action | |
| Else (adapter not | • OS ensures DSP is in a clean state ready for a new/different adapter | |
| present) | • OS configures for async hot-add handling | |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAEYCAYAAABhrrekAAAARklEQVRoge3MoREAIAwEwYQmsZSGpcpQAROH2re38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMBncAEfxgUue82O/gAAAABJRU5ErkJggg==)

**I.3 Async Hot-Add Configuration and Interrupt Handling**

**IMPLEMENTATION NOTE**

Async Hot-Add Configuration

|  |  |  |
| --- | --- | --- |
| Basic Steps | HPS | DPC |

OS configures for async hot-add handling

• Enable Link to train if/when an adapter is inserted 。 E.g., Clear Disable Link or release DPC if needed

• If appropriate for form factor, enable power controller prior to adapter insertion

• IfOOB PD supported, enable OS interrupt on PD Changed

• Else enable OS interrupt on DLL State Changed

![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0aHBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAACAckDASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD5/ooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKAP/9k=)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAEUCAYAAAAWbHffAAAAQ0lEQVRoge3KoREAIAwAsZYlsYyGZUow2B4DkLefjLF2VM2erZw3AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAPgKPDsfQQUmX+KWjgAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**IMPLEMENTATION NOTE**

Async Hot-Add Interrupt Handling

|  |  |  |
| --- | --- | --- |
| Basic Steps | HPS | DPC |

OS is interrupted due to PD Changed or DLL State Changed

|  |
| --- |
| OS waits for the adapter to become ready for configuration  • If appropriate for form factor, enable power controller now (following adapter insertion)  • Wait for DLL Link Active  • Wait for adapter to become ready for configuration |
| OS configures adapter per standard OS conventions |
| OS configures for async removal handling |
| OS calls driver to complete adapter configuration and begin normal operation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAFdCAYAAAA+Oyx7AAAATElEQVRoge3MoREAIAwEwYQmsZSGpcpQAROB3be38xHNMtapZ90zR/cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADwDy6jWgW4dwstDQAAAABJRU5ErkJggg==)

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

**Acknowledgements**

The following persons were instrumental in the development of this specification:181

|  |  |
| --- | --- |
| Name | Affiliation |
| Chamath Abhayagunawardhana | Intel Corporation |
| Ryan Abraham | Oracle Corporation |
| Shiva Aditham | Intel Corporation |
| Hong Ahn | Xilinx |
| Shay Aisman | Mellanox Technologies, Ltd. |
| Jasmin Ajanovic | Intel Corporation |
| KatsutoshiAkagi | NEC Corporation |
| Joe Allen | Tektronix, Inc. |
| Michael W. Altmann | Intel Corporation |
| TahaAmiralli | Advanced Micro Devices, Inc. |
| Boon Ang | VMware Corporation |
| SujithArramreddy | ServerWorks, Inc. |
| Antonio Asaro | Advanced Micro Devices, Inc. |
| YuvalAvnon | Marvell Semiconductor, Inc. |
| Jay Avula | ServerWorks, Inc. |
| Pervez Aziz | NVIDIA Corporation |
| Brian Baldwin | Synopsys, Inc. |
| Jasper Balraj | Intel Corporation |
| Nat Barbiero | Advanced Micro Devices, Inc. |
| Phillip Barnes | Hewlett-Packard Company |
| Suparna Behera | LSI Logic Corporation |
| JosephA. Bennett | Intel Corporation |
| Richard Bell | Advanced Micro Devices, Inc. |
| Stuart Berke | Hewlett-Packard Company |
| Harish Bharadwaj | LSI Logic Corporation |
| Ajay V. Bhatt | Intel Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAKElEQVRYhe3OAQkAQAgEMO1f6pr9pxBBtgSrAgAAGNZJ3nYCAAC47QOcDgNBkGYMzwAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)181. Company affiliation listed is at the time of specification contributions.

Page 1285

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Gaurav Bhide | Advanced Micro Devices, Inc. |
| Harmeet Bhugra | IDT Corporation |
| Christiaan Bil | Intel Corporation |
| Bill Bissonette | Intel Corporation |
| Cass Blodget | Intel Corporation |
| Jeffrey D. Bloom | Intel Corporation |
| Mahesh Bohra | IBM Corporation |
| Naveen Bohra | Intel Corporation |
| Karl Bois | Hewlett Packard Enterprise |
| Austin Bolen | Dell Inc. |
| Jerry Bolen | Intel Corporation |
| Michele Bologna | Synopsys, Inc. |
| Wilde Bont | National Instruments |
| David Bouse | Intel Corporation |
| Hicham Bouzekri | ST-Ericsson |
| Gavin Bowlby | Marvell Semiconductor, Inc |
| Suri Brahmaroutu | Dell Inc. |
| Dave Brown | Integrated Device Technology |
| Tory Brown | Intel Corporation |
| Mike Brownell | Intel Corporation |
| Bala Cadambi | Intel Corporation |
| John Calvin | VTM |
| John Calvin | Tektronix, Inc. |
| Jun Cao | Synopsys, Inc. |
| Gord Caruk | Advanced Micro Devices, Inc. |
| Paul Cassidy | Synopsys, Inc. |
| James Chapple | Intel Corporation |
| Kabitha Chaturvedula | LSI Logic Corporation |
| Yogesh Chaudhary | Mentor Graphics |
| Santanu Chaudhuri | Intel Corporation |
| Rajinder Cheema | LSI Logic Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1286

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Albert Chen | LSI Logic Corporation |
| Chih-Cheh Chen | Intel Corporation |
| Jian Chen | Parade |
| Qunwei Chen | Advanced Micro Devices, Inc. |
| Tony Chen | Marvell Semiconductor, Inc |
| Jonathan Cheung | Advanced Micro Devices, Inc. |
| Yorick Cho | Advanced Micro Devices, Inc. |
| Dickson Chow | Advanced Micro Devices, Inc. |
| Gene Chui | IDT Corporation |
| Shawn Clayton | Emulex Corporation |
| Mark Clements | IBM Corporation |
| Debra Cohen | Intel Corporation |
| Eric Combs | LSI Logic Corporation |
| Brad Congdon | Intel Corporation |
| Mike Converse | IDT Corporation |
| Justin Coppin | Hewlett-Packard Company |
| Joe Cowan | Hewlett-Packard Enterprise |
| Carrie Cox | IBM Corporation |
| H. Clay Cranford | IBM Corporation |
| Kenneth C. Creta | Intel Corporation |
| Pamela Cristo | Emulex Corporation |
| Sanjay Dabral | Intel Corporation |
| Eric Dahlen | Intel Corporation |
| Tugrul Daim | Intel Corporation |
| Ron Dammann | Intel Corporation |
| Sumit Das | Texas Instruments Incorporated |
| Debendra Das Sharma | Intel Corporation |
| Nicole Daugherty | Intel Corporation |
| Glen Dearth | Advanced Micro Devices, Inc. |
| Eric DeHaemer | Intel Corporation |
| Fei Deng | Intel Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1287

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Dan DeSetto | Intel Corporation |
| Karishma Dhruv | LSI Logic Corporation |
| Gary Dick | Cadence Design Systems, Inc. |
| Robert Dickson | Oracle Corporation |
| Bob Divivier | IDT Corporation |
| Hormoz Djahanshahi | Microsemi Corporation |
| Daniel Dreps | IBM Corporation |
| Ken Drottar | Intel Corporation |
| Dave Dunning | Intel Corporation |
| Rick Eads | Keysight |
| Rick Eads | Agilent Technologies, Inc. |
| Gregory L. Ebert | Intel Corporation |
| Imtinan Elahi | NVIDIA Corporation |
| Yaron Elboim | Intel Corporation |
| Bassam Elkhoury | Intel Corporation |
| Salem Emara | Advanced Micro Devices, Inc. |
| Mike Engbretson | Tektronix, Inc. |
| Ohad Falik | Intel Corporation |
| David Fair | Intel Corporation |
| Blaise Fanning | Intel Corporation |
| John Feehrer | Oracle Corporation |
| Wes Ficken | GLOBALFOUNDRIES Inc. |
| Joshua Filliater | LSI Logic Corporation |
| Michael Fleischer-Reumann | Agilent Technologies, Inc. |
| Pelle Fornberg | Intel Corporation |
| Jeff Fose | Emulex Corporation |
| Jim Foster | IBM Corporation |
| Mike Foxcroft | Advanced Micro Devices, Inc. |
| Douglas Freimuth | IBM Corporation |
| Daniel S. Froelich | Intel Corporation |
| SivaPrasad Gadey | Intel Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1288

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| YoniGalezer | Mellanox Technologies, Ltd. |
| Eric Geisler | Intel Corporation |
| Gordon Getty | Agilent Technologies, Inc. |
| Gregory Geyfman | Intel Corporation |
| John Geldman | Toshiba Memory Corporation |
| Stefano Giaconi | Intel Corporation |
| Steve Glaser | NVIDIA Corporation |
| Thorsten Goetzelmann | Keysight |
| Marc A. Goldschmidt | Intel Corporation |
| Dean Gonzales | Advanced Micro Devices, Inc. |
| Alan Goodrum | Hewlett-Packard Company |
| Robert Gough | Intel Corporation |
| Lucian Gozu | Neterion Corporation |
| Ilya Granovsky | IBM Corporation |
| Brien Gray | Intel Corporation |
| Richard Greene | Intel Corporation |
| Stephen Greenwood | ATITechnologies Inc. |
| Michael J. Greger | Intel Corporation |
| Buck Gremel | Intel Corporation |
| Andrew Gruber | Advanced Micro Devices, Inc. |
| George Gruber | Qualcomm |
| Vijay Gudur | LSI Logic Corporation |
| Dale Gulick | Advanced Micro Devices, Inc. |
| Liping Guo | Marvell Semiconductor, Inc. |
| Mickey Gutman | Intel Corporation |
| Clifford D. Hall | Intel Corporation |
| Stephen H. Hall | Intel Corporation |
| Joseph Hamel | IBM Corporation |
| Ken Haren | Intel Corporation |
| David Harriman | Intel Corporation |
| Hiromitsu Hashimoto | NEC Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1289

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| George R. Hayek | Intel Corporation |
| Wenmu He | Texas Instruments Incorporated |
| Matt Hendrick | Intel Corporation |
| Hamish Hendry | Cadence Design Systems, Inc. |
| Michael Herz | Blackberry |
| Bent Hessen-Schmidt | Tektronix, Inc. |
| Hanh Hoang | Intel Corporation |
| Joe Hock | Intel Corporation |
| Michael Hopgood | NVIDIA Corporation |
| Dorcas Hsia | NVIDIA Corporation |
| James Huang | Advanced Micro Devices, Inc. |
| Robert Huang | NVIDIA Corporation |
| Yifan Huang | Amphenol-FCI |
| Kamlesh Hujwant | Advanced Micro Devices, Inc. |
| Mark Hummel | Advanced Micro Devices, Inc. |
| Mikal Hunsaker | Intel Corporation |
| Joaquin Ibanez | Synopsys, Inc. |
| Yasser Ibrahim | Microsoft Corporation |
| Franko Itay | Intel Corporation |
| Carl Jackson | Hewlett-Packard Company |
| David R. Jackson | Intel Corporation |
| Praveen Jain | NVIDIA Corporation |
| Martin James | Cadence Design Systems, Inc. |
| Duane January | Intel Corporation |
| James E. Jaussi | Intel Corporation |
| Mike Jenkins | LSI Logic Corporation |
| Peter Jenkins | GLOBALFOUNDRIES Inc. |
| Hong Jiang | Intel Corporation |
| Viek Joshi | Intel Corporation |
| Dave Kaffine | Oracle Corporation |
| David Kahmayhew | Oracle Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1290

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Ravi Kammaje | LSI Logic Corporation |
| Girish Karanam | LSI Logic Corporation |
| Kapil Karkra | Intel Corporation |
| Navnit Kashyap | Cadence Design Systems, Inc. |
| Chad Kendall | Broadcom Inc. |
| Mukund Kharti | Dell Computer Corporation |
| Gyanaranjan Khuntia | Mentor Graphics |
| David Kimble | Texas Instruments Incorporated |
| Lavi Koch | Mellanox Technologies, Ltd. |
| Mohammad Kolbehdari | Intel Corporation |
| Abhimanyu Kolla | Intel Corporation |
| Ganesh Kondapuram | Intel Corporation |
| Kwok Kong | IDT Corporation |
| Michael Krause | Hewlett-Packard Enterprise |
| Gopi Krishnamurthy | Cadence Design Systems, Inc. |
| Sreenivas Krishnan | NVIDIA Corporation |
| Kumaran Krishnasamy | Broadcom Inc. |
| Steve Krooswyk | Samtec |
| Manjari Kulkarni | Intel Corporation |
| Akhilesh Kumar | Intel Corporation |
| Mohan J. Kumar | Intel Corporation |
| Richard Kunze | Intel Corporation |
| Hugh Kurth | Oracle Corporation |
| Seh Kwa | Intel Corporation |
| Ricky Lai | Hewlett Packard Enterprise |
| Sunny Lam | Intel Corporation |
| Dave Landsman | Sandisk |
| Brian Langendorf | NVIDIA Corporation |
| Raymond R. Law | Intel Corporation |
| Dror Lazar | Intel Corporation |
| Brian L'Ecuyer | Agilent Technologies, Inc. |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1291

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Beomtek Lee | Intel Corporation |
| Clifford D. Lee | Intel Corporation |
| David M. Lee | Intel Corporation |
| Edward Lee | Advanced Micro Devices, Inc. |
| Moshe Leibowitz | IBM Corporation |
| Tony L. Lewis | Intel Corporation |
| Mike Li | Wavecrest Corporation |
| Paul Li | Pericom Semiconductor Corporation |
| Stephen Li | Texas Instruments Incorporated |
| Ying Li | NVIDIA Corporation |
| Tao Liang | Intel Corporation |
| Andrew K. Lillie | Intel Corporation |
| Wendy Liu | Advanced Micro Devices, Inc. |
| Jeff Lukanc | IDT Corporation |
| Jeffrey Lu | IBM Corporation |
| Betty Luk | Advanced Micro Devices, Inc. |
| Ngoc Luu | Advanced Micro Devices, Inc. |
| Kenneth Ma | Broadcom Inc. |
| Stephen Ma | Advanced Micro Devices, Inc. |
| ZorikMachulsky | IBM Corporation |
| Mallik Mahalingam | VMware, Inc. |
| Kevin Main | Texas Instruments Incorporated |
| Steven Makow | IBM Corporation |
| Tony Mangefeste | Microsoft Corporation |
| Nilange Manisha | Intel Corporation |
| Steve Manning | Advanced Micro Devices, Inc. |
| Gold Mao | VIA Technologies, Inc. |
| Jarek Marczewski | Advanced Micro Devices, Inc. |
| Mark Marlett | LSI Logic Corporation |
| Alberto Martinez | Intel Corporation |
| Andrew Martwick | Intel Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1292

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Paul Mattos | GLOBALFOUNDRIES Inc. |
| RobertA. Mayer | Intel Corporation |
| David Mayhew | (Stargen, Inc.) Advanced Micro Devices, Inc. |
| Mohiuddin Mazumder | Intel Corporation |
| Mehdi Mechaik | Cadence Design Systems, Inc. |
| Mehdi M. Mechaik | NVIDIA Corporation |
| Pranav H. Mehta | Intel Corporation |
| Vishal Mehta | NVIDIA Corporation |
| Richard Mellitz | Intel Corporation |
| Adi Menachem | Valens Semiconductor, Ltd. |
| Cindy Merkin | Dell Computer Corporation |
| Slobodan Milijevic | Microsemi Corporation |
| Dennis Miller | Intel Corporation |
| Jason Miller | Oracle Corporation |
| Robert J. Miller | Intel Corporation |
| Michael Mirmak | Intel Corporation |
| Suneel Mitbander | Intel Corporation |
| Mohammad Mobin | NVIDIA Corporation |
| Daniel Moertl | IBM Corporation |
| Lee Mohrmann | National Instruments Corporation |
| Puga Nathal Moises | Intel Corporation |
| Richard Moore | Cavium Inc. |
| Wayne Moore | Intel Corporation |
| Douglas R. Moran | Intel Corporation |
| Terry Morris | Hewlett-Packard Enterprise |
| Jeff C. Morriss | Intel Corporation |
| Linna Mu | Avago Technologies |
| Sridhar Muthrasanallur | Intel Corporation |
| Suresh Babu M. V. | LSI Logic Corporation |
| Gautam V. Naik | LSI Logic Corporation |
| Mohan K. Nair | Intel Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1293

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Mukund Narasimhan | Intel Corporation |
| Alon Naveh | Intel Corporation |
| Ramin Neshati | Intel Corporation |
| Surena Neshvad | Intel Corporation |
| Andy Ng | IDT Corporation |
| Manisha Nilange | Intel Corporation |
| Paul Nitza | Marvell Semiconductor, Inc |
| Hajime Nozaki | NEC Corporation |
| Kugao Ohuchi | NEC Corporation |
| Vitor Oliveira | Synopsys, Inc. |
| Olufemi Oluwafemi | Intel Corporation |
| Takuya Omura | Synopsys, Inc. |
| Peter Onufryk | Integrated Device Technology |
| Mike Osborn | Advanced Micro Devices, Inc. |
| Jake Oshins | Microsoft Corporation |
| Randy Ott | Intel Corporation |
| Jonathan Owen | Advanced Micro Devices, Inc. |
| Ali Oztaskin | Intel Corporation |
| David Pabisz | Oracle Corporation |
| Shreeram Palghat | Intel Corporation |
| Jim Panian | Qualcomm |
| Marc Pegolotti | ServerWorks, Inc. |
| Henry Peng | Intel Corporation |
| Akshay Pethe | Intel Corporation |
| Chris Pettey | NextIO, Inc. |
| Tien Pham | Hewlett Packard Enterprise |
| Lu-vong Phan | Intel Corporation |
| Tony Pierce | Microsoft Corporation |
| Edmund Poh | Molex, Inc. |
| Harshit Poladia | Intel Corporation |
| Jim Prijic | Intel Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1294

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Dave Puffer | Intel Corporation |
| Duane Quiet | Intel Corporation |
| Jeffrey D. Rabe | Intel Corporation |
| Andy Raffman | Microsoft Corporation |
| Kianoush Rahbar | Intel Corporation |
| Guru Rajamani | Intel Corporation |
| Ramesh Raman | LSI Logic Corporation |
| Adee Ran | Intel Corporation |
| Todd Rasmus | IBM Corporation |
| Renato Recio | IBM Corporation |
| Ramakrishna Reddy | LSI Logic Corporation |
| Jack Regula | PLX Technology, Inc. |
| Dick Reohr | Intel Corporation |
| Curtis Ridgeway | LSI Logic Corporation |
| Dwight Riley | Hewlett-Packard Enterprise |
| Yoav Rozenbert | Mellanox Technologies, Ltd. |
| Chris Runhaar | NVIDIA Corporation |
| Rajanataraj S. | LSI Logic Corporation |
| DevangSachdev | NVIDIA Corporation |
| Gene Saghi | Broadcom Inc. |
| Rajesh Sankaran | Intel Corporation |
| Bill Sauber | Dell Computer Corporation |
| Joseph Schachner | Teledyne LeCroy |
| Mike Schaecher | Oracle Corporation |
| Joe Schaefer | Intel Corporation |
| Michael Scheid | Broadcom Inc. |
| Daren Schmidt | Intel Corporation |
| Mark Schmisseur | Intel Corporation |
| Richard Schober | NVIDIA Corporation |
| Zale Schoenborn | Intel Corporation |
| Rick Schuckle | Dell Computer Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1295

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Richard Schumacher | Hewlett-Packard Enterprise |
| Jeremiah Schwartz | Intel Corporation |
| Tudor Secasiu | Intel Corporation |
| Kazunori Seki | Synopsys, Inc. |
| Oren Sela | Mellanox Technologies, Ltd. |
| Kevin Senohrabek | Advanced Micro Devices, Inc. |
| Kalev Sepp | Tektronix, Inc. |
| Prashant Sethi | Intel Corporation |
| Ankur Shah | Intel Corporation |
| Vasudevan Shanmugasundaram | Intel Corporation |
| Wesley Shao | Oracle Corporation |
| Prateek Sharma | LSI Logic Corporation |
| Charlie Shaver | Hewlett-Packard Company |
| Robert Sheldon | Oracle Corporation |
| John Sheplock | IBM Corporation |
| Wenjun Shi | NVIDIA Corporation |
| Milton Shih | Oracle Corporation |
| Mark Shillingburg | Agilent Technologies |
| Oren Shirak | Mellanox Technologies, Ltd. |
| Sarvesh Shrivastava | Qualcomm |
| Bill Simms | NVIDIA Corporation |
| Vinita Singhal | NVIDIA Corporation |
| Dan Slocombe | Cadence Design Systems, Inc. |
| Brian Small | Northwest Logic, Inc. |
| George Smith | Microsoft Corporation |
| Shamnad SN | LSI Logic Corporation |
| Rick Sodke | PMC-Sierra |
| Gary Solomon | Intel Corporation |
| Richard Solomon | Synopsys, Inc. |
| Gao Song | IDT Corporation |
| BradSonksen | Marvell Semiconductor, Inc |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1296

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Walter Soto | Broadcom Inc. |
| Fulvio Spagna | Intel Corporation |
| Jason Squire | Molex, Inc. |
| Patrick Stabile | Oracle Corporation |
| Sean O. Stalley | Intel Corporation |
| Stan Stanski | IBM Corporation |
| Hermann Stehling | Bitifeye Digital Test Solutions |
| John Stonick | Synopsys, Inc. |
| Ron Swartz | Intel Corporation |
| Tim Symons | PMC-Sierra |
| Miki Takahashi | NEC Corporation |
| Gerry Talbot | Advanced Micro Devices, Inc. |
| Anthony Tam | Advanced Micro Devices, Inc. |
| Wanru Tao | Oracle Corporation |
| Mark Taylor | NVIDIA Corporation |
| Matthew Tedone | LSI Logic Corporation |
| Grigori Temkine | Advanced Micro Devices, Inc. |
| Peter Teng | NEC Corporation |
| Bruce A. Tennant | Intel Corporation |
| Larry Tesdall | Marvell Semiconductor, Inc |
| Andrew Thornton | Microsoft Corporation |
| Steven Thurber | IBM Corporation |
| Mike Tobin | Intel Corporation |
| BenToby | Hewlett Packard Enterprise |
| Duke Tran | Broadcom Inc. |
| Tan V. Tran | Intel Corporation |
| Alok Tripathi | Intel Corporation |
| William Tsu | NVIDIA Corporation |
| Alexander Umansky | Huawei Technologies Co. |
| Chris Van Beek | Intel Corporation |
| Arie van der Hoeven | Microsoft Corporation |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1297

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Andrew Vargas | Intel Corporation |
| Robertson Velez | ATITechnologies Inc. |
| Archana Vasudevan | LSI Logic Corporation |
| Kiran Velicheti | Intel Corporation |
| BalajiVembu | Intel Corporation |
| Gary Verdun | Dell Computer Corporation |
| Sushil Verghese | Broadcom Inc. |
| Divya Vijayaraghavan | Altera Corporation |
| Ravindra Viswanath | LSI Logic Corporation |
| Pete D. Vogt | Intel Corporation |
| Andrew Volk | Intel Corporation |
| Mahesh Wagh | Intel Corporation |
| Clint Walker | Intel Corporation |
| Davis Walker | Microsoft Corporation |
| Hui Wang | IDT Corporation |
| KaiA. Wang | Intel Corporation |
| Leo Warmuth | NXP Semiconductors |
| Dan Wartski | Intel Corporation |
| Neil Webb | Cadence Design Systems, Inc. |
| Eric Wehage | Intel Corporation |
| Dong Wei | Hewlett-Packard Company |
| Ron Weimer | QLogic Corporation |
| Amir Wiener | Intel Corporation |
| Marc Wells | Intel Corporation |
| Rob Wessel | Hewlett-Packard Company |
| Stephen F. Whalley | Intel Corporation |
| Bryan White | Intel Corporation |
| Paul Whittemore | Oracle Corporation |
| Amir Wiener | Intel Corporation |
| Timothy Wig | Intel Corporation |
| Craig Wiley | Parade |

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1298

5.0-1.0-PUB — PCI Express® Base Specification Revision 5.0 Version 1.0

|  |  |
| --- | --- |
| Name | Affiliation |
| Jim Williams | Emulex Corporation |
| Theodore L. Willke | Intel Corporation |
| Dawn Wood | Intel Corporation |
| John Wood | Emulex Corporation |
| David Woodral | QLogic Corporation |
| David Wooten | Microsoft Corporation |
| Zhi Wong | Altera Corporation |
| David Wormus | LSI Logic Corporation |
| David Wu | Broadcom Inc. |
| William Wu | Broadcom Inc. |
| Zuoguo Wu | Intel Corporation |
| Liu Xin | IDT Corporation |
| DanYaklin | Texas Instruments Incorporated |
| Howard Yan | Intel Corporation |
| Jane Yan | Oracle Corporation |
| AlYanes | IBM Corporation |
| Gin Yee | Advanced Micro Devices, Inc. |
| Ahmed Younis | Xilinx, Inc. |
| Chi-Ho Yue | NVIDIA Corporation |
| Wayne Yun | Advanced Micro Devices, Inc. |
| Dave Zenz | Dell Computer Corporation |
| ShubingZhai | IDT Corporation |
| Wei Zhang | Broadcom Inc. |
| Bo Zhang | Intel Corporation |
| Guoqing Zhang | Cadence Design Systems, Inc. |
| Kevin Ziegler | Tektronix, Inc. |
| Yaping Zhou | NVIDIA Corporation |

↑

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAFCAYAAABxeg0vAAAAQElEQVQImb3NMRGAMBAAwQ1YiQEcvDgoKBATB2+FAgMYIEUMQMPWN3OzYcWJDQsuHKi4saP5RcnM520cEWX6euhkNwnk26wztwAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAx4AAAACCAYAAADWxgpDAAAAIklEQVRYhe3BAQ0AAAgDoNvUeqbUHG5ApWcDAAAAAADw2QHZqwIKU+HaKwAAAABJRU5ErkJggg==)

Page 1299