

### 9.5.1.7 UCIe Link DVSEC - Link Event Notification Control (Offset 18h)

Link event notification related controls are in this register.

**Table 9-11. UCIe Link DVSEC - Link Event Notification Control**

| Bit   | Attribute                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RW(RP/DSP), RsvdP (Others) | <b>'Link Status changed' UCIe Link Event Interrupt enable</b><br>0: Reporting of this event via interrupt is not enabled<br>1: Reporting of this event via interrupt is enabled.<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1     | RW(RP/DSP), RsvdP (Others) | <b>'HW autonomous BW changed' UCIe Link Event Interrupt enable</b><br>0: Reporting of this event via interrupt is not enabled<br>1: Reporting of this event via interrupt is enabled<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10:2  | RsvdP                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15:11 | RO(RP/DSP), RsvdP(Others)  | <b>Link Event Notification Interrupt number</b><br><br>This field indicates which MSI vector (for host UCIe Links), or MSI/MSI-X vector (for switch DSP UCIe Links) is used for the interrupt message generated in association with the events that are controlled via this register.<br><br>For MSI, the value in this field indicates the offset between the base Message Data and the interrupt message that is generated. Hardware is required to update this field so that it is correct if the number of MSI Messages assigned to the Function changes when software writes to the Multiple Message Enable field in the Message Control Register for MSI. For first generation of UCIe, maximum 2 interrupt vectors could be requested for UCIe related functionality and the 'Link event' is one of them.<br><br>For MSI-X (applicable only for interrupts from Switch DSPs with UCIe Links), the value in this field indicates which MSI-X Table entry is used to generate the interrupt message. The entry must be one of the first 32 entries even if the Function implements more than 32 entries. For a given MSI-X implementation, the entry must remain constant.<br><br>For UCIe related interrupts, a switch should request its interrupt requirements from either MSI or MSI-X capability but not both. |

### 9.5.1.8 UCIe Link DVSEC - Error Notification Control (Offset 1Ah)

Link error notification related controls are in this register.

**Note:** This register only controls the propagation of the error condition and it has no impact on the setting of the appropriate status bits in the Link Status register, when the relevant error happens.

**Table 9-12. UCIe Link DVSEC - Error Notification Control (Sheet 1 of 3)**

| <b>Bit</b> | <b>Attribute</b>           | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW(RP/DSP), RsvdP (Others) | <p><b>'Correctable error detected' protocol layer based reporting enable</b></p> <p>0: Reporting of this error via protocol layer mechanism is not enabled<br/>1: Reporting of this error via protocol layer mechanism is enabled</p> <p>Default is 0</p> <p>When enabled, the reported PCIe/CXL protocol layer correctable error type is 'Correctable internal error'.</p> <p>This bit is applicable for only RP/DSP.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1          | RW                         | <p><b>'Correctable error detected' UCIe Link Error Interrupt enable RP/DSP</b></p> <p>0: Reporting of this error via UCIe Link Error interrupt is not enabled<br/>1: Reporting of this error via UCIe Link Error interrupt is enabled</p> <p><b>EP/USP</b></p> <p>0: Reporting of this error via sideband error message is not enabled<br/>1: Reporting of this error via sideband error message is enabled</p> <p>Note that in the case of EP/USP connected to a retimer, their sideband error message targets the retimer and how the retimer sends it across to the partner retimer is vendor specific.</p> <p>Retimer connected to RP/DSP</p> <p>0: Reporting of this error via sideband error message to RP/DSP is not enabled<br/>1: Reporting of this error via sideband error message to RP/DSP is enabled</p> <p>Retimer connected to EP/USP</p> <p>0: Reporting of this error to the partner retimer is disabled.<br/>1: Reporting of this error to the partner retimer is enabled. The specific mechanism for reporting the error to the partner retimer is vendor-specific.</p> <p>Default is 0</p> |
| 2          | RW(RP/DSP), RsvdP (Others) | <p><b>'Uncorrectable non-fatal error detected' protocol layer based reporting enable</b></p> <p>0: Reporting of this error via protocol layer mechanism is not enabled<br/>1: Reporting of this error via protocol layer mechanism is enabled</p> <p>Default is 0</p> <p>This bit is applicable for only RP/DSP.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Table 9-12. UCIe Link DVSEC - Error Notification Control (Sheet 2 of 3)**

| Bit | Attribute                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW                          | <p><b>'Uncorrectable non-fatal error detected' UCIe Link Error Interrupt enable</b></p> <p>RP/DSP<br/>0: Reporting of this error via UCIe Link Error interrupt is not enabled<br/>1: Reporting of this error via UCIe Link Error interrupt is enabled</p> <p>EP/USP<br/>0: Reporting of this error via sideband error message is not enabled<br/>1: Reporting of this error via sideband error message is enabled</p> <p>Note that in the case of EP/USP connected to a retimer, their sideband error message targets the retimer and how the retimer sends it across to the partner retimer is vendor specific.</p> <p>Retimer connected to RP/DSP<br/>0: Reporting of this error via sideband error message to RP/DSP is not enabled<br/>1: Reporting of this error via sideband error message to RP/DSP is enabled</p> <p>Retimer connected to EP/USP<br/>0: Reporting of this error to the partner retimer is disabled.<br/>1: Reporting of this error to the partner retimer is enabled. The specific mechanism for reporting the error to the partner retimer is vendor specific.</p> <p>Default is 0</p> |
| 4   | RW (RP/DSP), RsvdP (Others) | <p><b>'Uncorrectable fatal error detected' protocol layer based reporting enable</b></p> <p>0: Reporting of this error via protocol layer mechanism is not enabled<br/>1: Reporting of this error via protocol layer mechanism is enabled<br/>Default is 0<br/>When enabled, the reported PCIe/CXL protocol layer uncorrectable error type is 'Uncorrectable internal error'<br/>This bit is applicable for only RP/DSP.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**Table 9-12. UCIe Link DVSEC - Error Notification Control (Sheet 3 of 3)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5     | RW        | <p><b>'Uncorrectable fatal error detected' UCIe Link Error Interrupt enable</b><br/>RP/DSP<br/>0: Reporting of this error via UCIe Link Error interrupt is not enabled<br/>1: Reporting of this error via UCIe Link Error interrupt is enabled</p> <p>EP/USP<br/>0: Reporting of this error via sideband error message is not enabled<br/>1: Reporting of this error via sideband error message is enabled</p> <p>Note that in the case of EP/USP connected to a retimer, their sideband error message targets the retimer and how the retimer sends it across to the partner retimer is vendor specific.</p> <p>Retimer connected to RP/DSP<br/>0: Reporting of this error via sideband error message to RP/DSP is not enabled<br/>1: Reporting of this error via sideband error message to RP/DSP is enabled</p> <p>Retimer connected to EP/USP<br/>0: Reporting of this error to the partner retimer is disabled.<br/>1: Reporting of this error to the partner retimer is enabled. The specific mechanism for reporting the error to the partner retimer is vendor specific.</p> <p>Default is 0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10:6  | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15:11 | RW/RO     | <p><b>Link Error Notification Interrupt number</b></p> <p>This field indicates which MSI vector (for host UCIe Links), or MSI/MSI-X vector (for switch DSP UCIe Links) is used for the interrupt message generated in association with the events that are controlled via this register.</p> <p>For MSI, the value in this field indicates the offset between the base Message Data and the interrupt message that is generated. Hardware is required to update this field so that it is correct if the number of MSI Messages assigned to the Function changes when software writes to the Multiple Message Enable field in the Message Control Register for MSI. For first generation of UCIe, maximum 2 interrupt vectors could be requested for UCIe related functionality and the 'Error' is one of them.</p> <p>For MSI-X (applicable only for interrupts from Switch DSPs with UCIe Links), the value in this field indicates which MSI-X Table entry is used to generate the interrupt message. The entry must be one of the first 32 entries even if the Function implements more than 32 entries. For a given MSI-X implementation, the entry must remain constant.</p> <p>For UCIe related interrupts, a switch should request its interrupt requirements from either MSI or MSI-X capability but not both.</p> <p>It is strongly recommended that this field be implemented as RO but for backward compatibility reasons, it is also permitted to be implemented as RW. This field has no meaning for Switch USP and EP.</p> |

### 9.5.1.9 UCIe Link DVSEC - Register Locator 0, 1, 2, 3 Low (Offset 1Ch and when Register Locators 1, 2, 3 are present Offsets 24h, 2Ch, and 34h respectively)

The starting address of the MMIO-mapped register blocks for D2D/PHY, Compliance/Test and Implementation-specifics are located by SW via these registers.

**Note:** All register blocks start with a header section that indicates the size of the block in multiples of 4 KB.

**Table 9-13. UCIe Link DVSEC - Register Locator 0, 1, 2, 3 Low**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | RO        | <p><b>Register BIR</b><br/>           For UCIe DVSEC capability in host UiRB, Switch UiSRB and in UCIe Retimer, this field is reserved.<br/>           For others, its defined as follows:<br/>           Indicates which one of a Dev0/Fn0 Base Address Registers, located beginning at 10h in Configuration Space, or entry in the Enhanced Allocation capability with a matching BAR Equivalent Indicator (BEI), is used to map the UCIe Register blocks into Memory Space.<br/>           Defined encodings are:</p> <ul style="list-style-type: none"> <li>• 0 Base Address Register 10h</li> <li>• 1 Base Address Register 14h</li> <li>• 2 Base Address Register 18h</li> <li>• 3 Base Address Register 1Ch</li> <li>• 4 Base Address Register 20h</li> <li>• 5 Base Address Register 24h</li> </ul> <p>All other Reserved.<br/>           The Registers block must be wholly contained within the specified BAR. For a 64-bit Base Address Register, the Register BIR indicates the lower DWORD.</p> |
| 6:3   | RO        | <p><b>Register Block Identifier</b></p> <ul style="list-style-type: none"> <li>• Identifies the type of UCIe register blocks. Defined encodings are: 0h UCIe D2D/PHY Register Block</li> <li>• 1h UCIe Test/Compliance Register Block</li> <li>• 2h D2D Adapter Implementation specific register block</li> <li>• 3h PHY Implementation specific register block</li> <li>• All other encodings are reserved</li> </ul> <p>The same register block identifier value cannot be repeated in multiple Register Locator entries.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:7  | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:12 | RO        | <p><b>Register Block Offset</b><br/>           Addr[31:12] of the 4-KB aligned offset from the starting address of the Dev0/Fn0 BAR pointed to by the Register BIR field (for EP, Switch USP) or from the start of UiRB/UiSRB region (for hosts/Switch).<br/>           This field is reserved for retimers.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

### 9.5.1.10 UCIe Link DVSEC - Register Locator 0, 1, 2, 3 High (Offset 20h and when Register Locators 1, 2, 3 Are Present Offsets 28h, 30h, and 38h respectively)

Addr[63:32] of the starting address of the MMIO-mapped register blocks for D2D/PHY, Compliance/Test and Implementation-specifics are located by SW via these registers.

**Note:** All register blocks start with a header section that indicates the size of the block in multiples of 4 KB.

**Table 9-14. UCIe Link DVSEC - Register Locator 0, 1, 2, 3 High**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                       |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:32 | RO        | <b>Register Block Offset</b><br>Addr[63:32] of the 4-KB aligned offset from the starting address of the Dev0/Fn0 BAR pointed to by the Register BIR field (for EP, Switch USP) or from the start of UiRB/UiSRB region (for hosts/Switch).<br>This field is reserved for retimers. |

### 9.5.1.11 UCIe Link DVSEC - Sideband Mailbox Index Low (Offset is design dependent)

Mailbox registers are to be implemented by all hosts with UCIe Links. Switches with downstream UCIe Links and EP/USP, when paired with UCIe Retimer, should also implement this register. Note that accesses to mailbox are inherently non-atomic in nature and hence it is up to higher-level software to coordinate access to any mailbox-related register so that one agent does not step on another agent using the mailbox mechanism. Those mechanisms for software coordination are beyond the scope of this specification.

**Table 9-15. UCIe Link DVSEC - Sideband Mailbox Index Low**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                             |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | RW        | <b>Opcode</b><br>00000b 32b Memory Read<br>00001b 32b Memory Write<br>00100b 32b Configuration Read<br>00101b 32b Configuration Write<br>01000b 64b Memory Read<br>01001b 64b Memory Write<br>01100b 64b Configuration Read<br>01101b 64b Configuration Write<br>OthersReserved<br>Default 00100                        |
| 12:5  | RW        | <b>BE[7:0]</b><br>Default Fh                                                                                                                                                                                                                                                                                            |
| 31:13 | RW        | <b>Addr[18:0] of Sideband Accesses</b><br>Format for this field is as defined in the sideband interface definition in <a href="#">Chapter 7.0</a> .<br><b>Note:</b> The address offset defined as part of this address field is DWORD aligned for 32bit accesses and QWORD aligned for 64bit accesses.<br>Default is 0. |

### 9.5.1.12 UCIe Link DVSEC - Sideband Mailbox Index High (Offset is design dependent)

Mailbox registers are to be implemented by all hosts with UCIe Links. Switches with downstream UCIe Links and EP/USP, when paired with UCIe Retimer, should also implement this register. Note that accesses to mailbox are inherently non-atomic in nature and hence it is up to higher-level software to coordinate access to any mailbox-related register so that one agent does not step on another agent using the mailbox mechanism. Those mechanisms for software coordination are beyond the scope of this specification.

**Table 9-16. UCIe Link DVSEC - Sideband Mailbox Index High**

| Bit  | Attribute | Description                                                                                                                                          |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0  | RW        | <b>Addr[23:19] of Sideband Accesses</b><br>Format for this field is as defined in the sideband interface definition in Chapter 7.0.<br>Default is 0. |
| 31:5 | RsvdP     | Reserved                                                                                                                                             |

### 9.5.1.13 UCIe Link DVSEC - Sideband Mailbox Data Low (Offset is design dependent)

**Table 9-17. UCIe Link DVSEC - Sideband Mailbox Data Low**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW        | For sideband write opcodes, this carries the write data [31:0] to the destination.<br>For sideband read opcodes, this carries the data read from the destination when the Write/Read Trigger bit in the Mailbox Control register is cleared, after it was initially set. This field's value is undefined until the Write/Read trigger bit is cleared on reads. |

### 9.5.1.14 UCIe Link DVSEC - Sideband Mailbox Data High (Offset is design dependent)

**Table 9-18. UCIe Link DVSEC - Sideband Mailbox Data High**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW        | For sideband write opcodes, this carries the write data [63:32] to the destination.<br>For sideband read opcodes, this carries the data read from the destination when the Write/Read Trigger bit in the Mailbox Control register is cleared, after it was initially set. This field's value is undefined until the Write/Read trigger bit is cleared on reads.<br>For 32b Writes/Reads, this register does not carry valid data. |

### 9.5.1.15 UCIe Link DVSEC - Sideband Mailbox Control (Offset is design dependent)

**Table 9-19.** UCIe Link DVSEC - Sideband Mailbox Control

| Bit | Attribute           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW, with auto clear | <b>Write/Read trigger:</b> When this bit is written to a 1 from a value of 0, the mailbox generates traffic on the sideband interface, using the contents of the Mailbox Header and Data registers. This bit automatically clears when the write or read access triggered by this bit being set, is complete on the sideband bus. SW can poll this bit to know when the write/read has actually completed at the destination. It can then go read the Mailbox data register for the read data. |
| 7:1 | RsvdP               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 9.5.1.16 UCIe Link DVSEC - Sideband Mailbox Status (Offset is design dependent)

**Table 9-20.** UCIe Link DVSEC - Sideband Mailbox Status

| Bit | Attribute                                    | Description                                                                                                                                                                                               |
|-----|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW1C(RP/DSP), RW1C(EP/USP), when implemented | <b>Write/Read status</b><br>00b: CA received<br>01b: UR received<br>10b: Reserved<br>11b: Success<br>This bit has valid value only when the Write/Read Trigger bit is cleared from being a 1 prior to it. |
| 7:2 | RsvdZ                                        | Reserved                                                                                                                                                                                                  |

### 9.5.1.17 UCIe Link DVSEC - Requester ID (Offset is design dependent)

**Table 9-21.** UCIe Link DVSEC - Requester ID

| Bit   | Attribute             | Description                                                                                                                                                                                                                                                                                                                   |
|-------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:0  | RW(RP)/RsvdP (Others) | Applicable only for host side UCIe Links.<br>Segment No: Bus No: Dev No: Fn No for MSIs triggered on behalf of the associated UCIe Link<br><b>Note:</b> For MSIs issued on behalf of UCIe Links on downstream ports of switches, the Switch USP BDF is used.<br>UCIe Link DVSEC capabilities in UISRB implement this as RO 0. |
| 31:24 | RsvdP                 | Reserved                                                                                                                                                                                                                                                                                                                      |

### 9.5.1.18 UCIe Link DVSEC - Associated Port Numbers (Offset is design dependent)

These registers apply only to UCIe Link DVSEC capabilities present in UiSRB.

**Table 9-22. UCIe Link DVSEC - Associated Port Numbers**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0  | RO        | <b>Port Number 1</b> - 'Port number' of the 1st switch DSP associated with this UCIe. This value is from the Link Capabilities register of that switch DSP.                                                                                                                                                                                                                                                                                                                                                       |
| 15:8 | RO        | <b>Port Number 2</b> - 'Port number' of the 2nd switch DSP associated with this UCIe, if any. If there is no 2nd switch DSP associated with this UCIe Link, this field is treated as reserved and should not be included as part of the "length" field of the 'Designated Vendor specific Header 1' register and SW should not consider this as part of the DVSEC capability.<br><b>Note:</b> Only a maximum of two Port numbers can be associated with a UCIe Link in the current revision of the specification. |

### 9.5.1.19 Examples of setting the Length field in DVSEC for various Scenarios

Example#1: UCIe EP supporting 2 Register Locators and not associated with a UCIe-Retimer, would set the length field in DVSEC capability to indicate 48B.

Example#2: Host UiRB supporting 3 register locators would set the length to indicate 84B.

Example#3: Switch UiSRB supporting 3 register locators and associated with just 1 DSP port to a UCIe Link, would set the length to indicate 85B.

## 9.5.2 UCIe Switch Register Block (UiSRB) DVSEC Capability

This capability can only be present in the config space of the upstream port of a Switch. There can be multiple of these in the same USP config space.

### 9.5.2.1 PCI Express Extended Capability Header (Offset 0h)

Set as follows for UCIe Switch Register Block DVSEC. All bits in this register are RO.

**Table 9-23. UiSRB DVSEC - PCI Express Extended Capability Header**

| Field                  | Bit Location | Value            | Comments                                |
|------------------------|--------------|------------------|-----------------------------------------|
| Capability ID          | 15:0         | 0023h            | Value for PCI Express DVSEC capability  |
| Revision ID            | 19:16        | 1h               | Latest revision of the DVSEC capability |
| Next Capability Offset | 31:20        | Design Dependent |                                         |

### 9.5.2.2 Designated Vendor Specific Header 1, 2 (Offsets 4h and 8h)

A few things to note on the various fields described in Table 9-6. DVSEC Revision ID field represents the version of the DVSEC structure. The DVSEC Revision ID is incremented whenever the structure is extended to add more functionality. Backward compatibility shall be maintained during this process. For all values of n, DVSEC Revision ID n+1 structure may extend Revision ID n by replacing fields that are marked as reserved in Revision ID n, but must not redefine the meaning of existing fields. Software that was written for a lower Revision ID may continue to operate on UCIe DVSEC structures with a higher Revision ID, but will not be able to take advantage of new functionality.

All bits in this register are RO.

**Table 9-24. UiSRB DVSEC - Designated Vendor Specific Header 1, 2**

| Register                                         | Field           | Bit Location | Value |
|--------------------------------------------------|-----------------|--------------|-------|
| Designated Vendor-Specific Header 1 (offset 04h) | DVSEC Vendor ID | 15:0         | D2DEh |
|                                                  | DVSEC Revision  | 19:16        | 0h    |
|                                                  | Length          | 31:20        | 14h   |
| Designated Vendor-Specific Header 2 (offset 08h) | DVSEC ID        | 15:0         | 1h    |

### 9.5.2.3 UCIe Switch Register Block (UiSRB) Base Address (Offset Ch)

All bits in this register are RO.

**Table 9-25. UiSRB DVSEC - UiSRB Base Address**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RO         | <b>Register BIR</b><br>Indicates which one of a Switch USP Function's Base Address Registers, located beginning at 10h in Configuration Space, or entry in the Enhanced Allocation capability with a matching BAR Equivalent Indicator (BEI), is used to locate the UCIe Switch Register Block.<br>Defined encodings are: <ul style="list-style-type: none"> <li>• 0 Base Address Register 10h</li> <li>• 1 Base Address Register 14h</li> <li>• All other Reserved.</li> </ul> The Registers block must be wholly contained within the specified BAR. For a 64-bit Base Address Register, the Register BIR indicates the lower DWORD. |
| 11:1  | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 63:12 | RO         | <b>Register Block Offset</b><br>A 4-KB-aligned offset from the starting address of the Switch USP BAR indicated by the Register BIR field.<br>The BAR value + Offset indicated in this register is where the UCIe Switch Register Block (UiSRB) starts.<br>Ex: If this register is 100, UiSRB starts at the <64-bit BAR value + 100000h>                                                                                                                                                                                                                                                                                               |

## 9.5.3 D2D/PHY Register Block

These registers occupy 8 KB of register space. The first 4 KB are for the D2D Adapter, and the next 4 KB are for the Physical Layer. In the PHY register block, extended capabilities start at Offset 200h. If an implementation does not support any extended capabilities, it must implement a NULL capability at Offset 200h (which implements 0h for the DWORD at that offset). The D2D Adapter registers are enumerated below. The location of these registers in the system MMIO region is as described in Section 9.3.

### 9.5.3.1 UCIe Register Block Header

**Table 9-26. D2D/PHY Register Block - UCIe Register Block Header (Offset 0h)**

| Bit    | Attributes | Description                                                                                                                                    |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | RO         | <b>Vendor ID</b><br>Default is set to Vendor ID assigned for UCIe Consortium - D2DEh                                                           |
| 31:16  | RO         | <b>Vendor ID Register Block</b><br>Set to 0h to indicate D2D/PHY register block                                                                |
| 35:32  | RO         | <b>Vendor Register Block Version</b><br>Set to 0h                                                                                              |
| 63:36  | RsvdP      | Reserved                                                                                                                                       |
| 95:64  | RO         | <b>Vendor Register Block Length</b> - The number of bytes in the register block including the UCIe Register block header.<br>Default is 2000h. |
| 127:96 | RsvdP      | Reserved                                                                                                                                       |

### 9.5.3.2 Uncorrectable Error Status Register (Offset 10h)

**Table 9-27. Uncorrectable Error Status Register (Sheet 1 of 2)**

| Bit | Attribute                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW1CS                                         | <b>Adapter Timeout:</b> Set to 1b by hardware if greater than 8ms has elapsed for Adapter handshakes with its remote Link partner. The Header Log 2 register captures the reason for a timeout. This error will bring the main Link Down.<br>Default Value is 0b.                                                                                                                                                                             |
| 1   | RW1CS                                         | <b>Receiver Overflow:</b> Set to 1b by hardware if Receiver overflow errors are detected. The Header Log 2 register captures the encoding to indicate the type of Receiver overflow. This error will bring the Link Down.<br>Default Value is 0b.                                                                                                                                                                                             |
| 2   | RW1CS                                         | <b>Internal Error:</b> Set to 1b by hardware if an internal Data path error is detected or if LinkError state was detected on the RDI. Examples of such errors include (but not limited to) uncorrectable error correcting code (ECC) error in the Retry buffer, sideband parity errors etc. This error will bring the Link Down. It includes fatal error indicated by the Physical Layer that brought the Link Down.<br>Default Value is 0b. |
| 3   | RW1CS (RP/DSP/<br>Retimer),<br>RsvdZ (Others) | <b>Sideband Fatal Error Message received:</b> Set to 1b by hardware if the Adapter received a Fatal {ErrMsg} sideband message. Default Value is 0b.                                                                                                                                                                                                                                                                                           |

**Table 9-27. Uncorrectable Error Status Register (Sheet 2 of 2)**

| Bit  | Attribute                                   | Description                                                                                                                                                 |
|------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | RW1CS(RP/DSP/<br>Retimer),<br>RsvdZ(Others) | <b>Sideband Non-Fatal Error Message received:</b> Set to 1b by hardware if the Adapter received a Non-Fatal {ErrMsg} sideband message. Default Value is 0b. |
| 5    | RW1CS                                       | <b>Invalid Parameter Exchange:</b> Set to 1b if the Adapter was not able to determine a valid protocol or Flit Format for operation.                        |
| 31:6 | RsvdZ                                       | Reserved                                                                                                                                                    |

### 9.5.3.3 Uncorrectable Error Mask Register (Offset 14h)

The Uncorrectable Error Mask Register controls reporting of individual errors. When a bit is 1b in this register, the corresponding error status bit in the Uncorrectable Error Status register is not forwarded to the Protocol Layer for escalation/signaling but it does not impact error logging in the "First Fatal Error Indicator" field in the Header Log 2 register.

**Table 9-28. Uncorrectable Error Mask Register**

| Bit  | Attribute | Description                                                                   |
|------|-----------|-------------------------------------------------------------------------------|
| 0    | RWS       | <b>Adapter Timeout Mask</b><br>Default Value is 1b.                           |
| 1    | RWS       | <b>Receiver Overflow Mask</b><br>Default Value is 1b.                         |
| 2    | RWS       | <b>Internal Error Mask</b><br>Default Value is 1b.                            |
| 3    | RWS       | <b>Sideband Fatal Error Message received Mask</b><br>Default Value is 1b.     |
| 4    | RWS       | <b>Sideband Non-Fatal Error Message received Mask</b><br>Default Value is 1b. |
| 5    | RWS       | <b>Invalid Parameter Exchange Mask</b><br>Default Value is 1b.                |
| 31:6 | RsvdP     | Reserved                                                                      |

### 9.5.3.4 Uncorrectable Error Severity Register (Offset 18h)

The Uncorrectable Error Severity register controls whether an individual error is reported as a Non-fatal or Fatal error. An error is reported as a fatal uncorrectable error when the corresponding bit in the severity register is 1b. If the bit is 0b, the corresponding error is reported as a non-fatal uncorrectable error.

**Table 9-29. Uncorrectable Error Severity Register**

| Bit  | Attribute | Description                                                                       |
|------|-----------|-----------------------------------------------------------------------------------|
| 0    | RWS       | <b>Adapter Timeout Severity</b><br>Default Value is 1b.                           |
| 1    | RWS       | <b>Receiver Overflow Severity</b><br>Default Value is 1b.                         |
| 2    | RWS       | <b>Internal Error Severity</b><br>Default Value is 1b.                            |
| 3    | RWS       | <b>Sideband Fatal Error Message received Severity</b><br>Default Value is 1b.     |
| 4    | RWS       | <b>Sideband Non-Fatal Error Message received Severity</b><br>Default Value is 0b. |
| 5    | RWS       | <b>Invalid Parameter Exchange Severity</b><br>Default Value is 1b                 |
| 31:6 | RsVdP     | Reserved                                                                          |

### 9.5.3.5 Correctable Error Status Register (Offset 1Ch)

**Table 9-30. Correctable Error Status Register**

| Bit  | Attribute                                     | Description                                                                                                                                                                                                                                                                                                                  |
|------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | RW1CS                                         | <b>CRC Error Detected:</b> Set to 1b by hardware if the Adapter detected a CRC Error when Adapter Retry was negotiated with remote Link partner.<br>Default Value is 0b.                                                                                                                                                     |
| 1    | RW1CS                                         | <b>Adapter LSM transition to Retrain:</b> Set to 1b by hardware if the Adapter LSM transitioned to Retrain state.<br>Default Value is 0b.                                                                                                                                                                                    |
| 2    | RW1CS                                         | <b>Correctable Internal Error:</b> Set to 1b by hardware if an internal correctable Data path error is detected. Examples of such errors include (but are not limited to) correctable error correcting code (ECC) error in the Retry buffer, Physical Layer indicated correctable error on RDI, etc.<br>Default Value is 0b. |
| 3    | RW1CS (RP/DSP/<br>Retimer),<br>RsVdZ (Others) | <b>Sideband Correctable Error Message received:</b> Set to 1b by hardware if the Adapter received a Correctable {ErrMsg} sideband message with Device origin encoding in the message information.<br>Default Value is 0b.                                                                                                    |
| 4    | RW1CS                                         | <b>'Runtime Link Testing Parity' Error</b>                                                                                                                                                                                                                                                                                   |
| 31:5 | RsVdZ                                         | Reserved                                                                                                                                                                                                                                                                                                                     |

### 9.5.3.6 Correctable Error Mask Register (Offset 20h)

The Correctable Error Mask Register controls the reporting of individual errors. When a bit is 1b in this register, setting of the corresponding error status bit is not forwarded to the Protocol Layer for escalation/signaling.

**Table 9-31. Correctable Error Mask Register**

| Bit  | Attribute | Description                                                                   |
|------|-----------|-------------------------------------------------------------------------------|
| 0    | RWS       | <b>CRC Error Detected Mask</b><br>Default Value is 1b.                        |
| 1    | RWS       | <b>Adapter LSM transition to Retrain Mask</b><br>Default Value is 1b.         |
| 2    | RWS       | <b>Correctable Internal Error Mask</b><br>Default Value is 1b.                |
| 3    | RWS       | <b>Device Correctable Error Message received Mask</b><br>Default Value is 1b. |
| 4    | RWS       | <b>'Runtime Link Testing Parity' Error Mask</b><br>Default Value is 1b.       |
| 31:5 | RsvdP     | Reserved                                                                      |

### 9.5.3.7 Header Log 1 Register (Offset 24h)

This register is used to log the header on sideband register accesses that receive UR/CA error status.

**Table 9-32. Header Log 1 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | ROS       | <b>Header Log 1:</b> This logs the header for the sideband mailbox register access that received a completion with Completer Abort status or received a completion with Unsupported Request status. Note that register accesses that time out are not required to be logged at the requester.<br>If the Write/Read Status field in the 'Sideband Mailbox Status' register indicates 'Success' or the Write/Read trigger bit in the Sideband Mailbox Control register is set to 1, this field's value is undefined.<br>This register is rearmed for logging new errors every time the Write/Read Trigger bit in the Mailbox Control register sees a 0-to-1 transition.<br>Default Value is 0. |

### 9.5.3.8 Header Log 2 Register (Offset 2Ch)

This register is used to log syndrome of various sideband and mainband errors and specific status logging on link training.

**Table 9-33. Header Log 2 Register (Sheet 1 of 2)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | ROS       | <p><b>Adapter Timeout encoding:</b> Captures the reason for the first Adapter Timeout that was logged in Uncorrectable Error Status. Default Value is 0000b. The encodings are interpreted as follows:</p> <ul style="list-style-type: none"> <li>0001b: Parameter Exchange flow timed out</li> <li>0010b: Adapter LSM request to remote Link partner did not receive a response after 8 ms. Bits [9:7] capture the specific state request that did not receive a response. Bit 10 of this register captures which Adapter LSM timed out.</li> <li>0011b: Adapter LSM transition to Active timeout. This is recorded in case the Adapter never received Active Request from remote Link partner for 8 ms after sending an Active Request on sideband even though it received an Active Response. Bit 10 of this register captures which Adapter LSM timed out.</li> <li>0100b: Retry Timeout - no Ack or Nak received after 8 ms, when Retry was enabled. Timeout counter is only incremented while RDI is in Active and Adapter's Retry buffer is not empty.</li> <li>0101b: Local sideband access timeout</li> <li>0110b: Retimer credit return timeout - no Retimer credit received for greater than 8 ms if one or more Retimer credits have been consumed by the Adapter. This timer is only counting during Active state. If RDI moves to Retrain, this timer must be Reset since the Retimer credits are also Reset.</li> <li>0111b: Remote Register Access timeout. This is triggered when if the Adapter has observed N timeouts for Register Accesses where N is <math>\geq</math> register access timeout threshold.</li> <li>other encodings are reserved.</li> </ul> <p>If the Adapter Timeout status bit is cleared in the 'Uncorrectable Error Status' register, this field's value is undefined.</p> |
| 6:4   | ROS       | <p><b>Receiver Overflow encoding:</b> Captures the encoding for the first Receiver overflow error that occurred. Default value is 000b. The encodings are interpreted as follows:</p> <ul style="list-style-type: none"> <li>001b: Transmitter Retry Buffer overflow</li> <li>010b: Retimer Receiver Buffer overflow</li> <li>011b: FDI sideband buffer overflow</li> <li>100b: RDI sideband buffer overflow</li> <li>other encodings are reserved.</li> </ul> <p>If the Receiver overflow status bit is cleared in the 'Uncorrectable Error Status' register, this field's value is undefined.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9:7   | ROS       | <p><b>Adapter LSM response type</b></p> <ul style="list-style-type: none"> <li>001b: Active</li> <li>010b: L1</li> <li>011b: L2</li> <li>100b: LinkReset</li> <li>101b: Disable</li> <li>Other encodings are reserved</li> </ul> <p>If the Adapter Timeout status bit is cleared in the 'Uncorrectable Error Status' register, this field's value is undefined.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10    | ROS       | <p><b>Adapter LSM id</b></p> <ul style="list-style-type: none"> <li>0b : Adapter LSM 0 timed out</li> <li>1b : Adapter LSM 1 timed out</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:11 | RsvdZ     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 9-33. Header Log 2 Register (Sheet 2 of 2)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13    | RO        | <b>Parameter Exchange Successful</b> : Hardware updates this bit to 1b after successful Parameter exchange with remote Link partner, on every link training.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17:14 | ROS       | <p><b>Flit Format</b>: This field logs the negotiated Flit Format, it is the current snapshot of the format the Adapter is informing to the Protocol Layer. See <a href="#">Chapter 3.0</a> for the definitions of these formats. The encodings are:</p> <ul style="list-style-type: none"> <li>0001b - <i>Format 1</i></li> <li>0010b - <i>Format 2</i></li> <li>0011b - <i>Format 3</i></li> <li>0100b - <i>Format 4</i></li> <li>0101b - <i>Format 5</i></li> <li>0110b - <i>Format 6</i></li> </ul> <p>Other encodings are Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 22:18 | ROS       | <p><b>First Fatal Error Indicator</b>: 5-bit encoding that indicates which bit of Uncorrectable Error Status errors was logged first. The value of this field has no meaning if the corresponding status bit is cleared. The encoding of this field is as follows:</p> <ul style="list-style-type: none"> <li>00h if the error corresponding to Uncorrectable Error Status register[0] is the first fatal error.</li> <li>01h if the error corresponding to Uncorrectable Error Status register[1] is the first fatal error.</li> <li>...</li> </ul> <p>Because reserved bits may be repurposed in future versions of the specification, software might observe that this field points to a reserved bit (from its perspective) in the Uncorrectable Error Status register. This can happen when an older version of Software is run on newer hardware. Software must be aware that it still needs to clear the Status register bit if it desires to allow for continued error logging. How SW handles error status bits it does not understand is beyond the scope of the specification.</p> <p>Once set, the value of this field does not change until SW clears the corresponding Uncorrectable Error Status register bit. When SW clears the corresponding status bit, HW is rearmed to capture subsequent first fatal errors.</p> <p>Note that because of an inherent race condition between HW setting a new status bit and SW clearing an older status bit, SW must be aware that this field might not always indicate the first error amongst all the errors logged in the Uncorrectable Error Status register. For example, if the Uncorrectable Error Status bit 0 was set first by HW and in the time SW reads the status and cleared it, bit 1 in the Status register was set. So, after SW clears bit 0 if error corresponding to bit 0 recurs, it will be captured as the next first error even though the error corresponding to bit 1 occurred earlier. If multiple errors are encountered simultaneously, which error is logged as the First Fatal Error is implementation-dependent.</p> |
| 31:23 | RsvdZ     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 9.5.3.9 Error and Link Testing Control Register (Offset 30h)

**Table 9-34. Error and Link Testing Control Register (Sheet 1 of 2)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | RW        | <b>Remote Register Access Threshold:</b> Indicates the number of consecutive timeouts for remote register accesses that must occur before the Register Access timeout is logged and the error escalated to a Link_Status=Down condition.<br>Default Value is 0100b.                                                                                                                                                                                                                                              |
| 4     | RW        | <b>Runtime Link Testing Tx Enable:</b> Software writes to this bit to enable Parity byte injections in the data stream as described in <a href="#">Section 3.9</a> . Runtime Link Rx Enable must be set to 1b for remote Link Partner for successful enabling of this mode.<br>Default Value is 0b.                                                                                                                                                                                                              |
| 5     | RW        | <b>Runtime Link Testing Rx Enable:</b> Software writes to this bit to enable Parity byte checking in the data stream as described in <a href="#">Section 3.9</a> . Runtime Link Tx Enable must be set to 1b for remote Link Partner for successful enabling of this mode.<br>Default Value is 0b.                                                                                                                                                                                                                |
| 8:6   | RW        | <b>Number of 64 Byte Inserts:</b> Software writes to this to indicate the number 64 Byte inserts are done at a time for Runtime Link Testing. The encodings are:<br>000b: one 64B insert (for debug purposes only)<br>001b: two 64B inserts (for debug purposes only)<br>010b: four 64B inserts<br>Other encodings are reserved.<br>Default value is 000b.<br>See <a href="#">Section 3.9</a> for guidance on how Software should set this field.                                                                |
| 9     | RW1C      | <b>Parity Feature Nak received:</b> Hardware updates this bit if it receives a Nak from remote Link partner when attempting to enable Runtime Link Testing.                                                                                                                                                                                                                                                                                                                                                      |
| 12:10 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14:13 | RW        | <b>CRC Injection Enable :</b> Software writes to this bit to trigger CRC error injections, The error is injected by inverting 1, 2 or 3 bits in the CRC bytes. The specific bits inverted are implementation specific. The CRC injection must not happen for Flits that are already inverting CRC bits for Viral handling. The encodings are interpreted as :<br>00b : CRC Injection is Disabled.<br>01b : 1 bit is inverted<br>10b : 2 bits are inverted<br>11b : 3 bits are inverted.<br>Default Value is 00b. |

**Table 9-34. Error and Link Testing Control Register (Sheet 2 of 2)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:15 | RW        | <b>CRC Injection Count</b> : Software writes to this bit to program the number of CRC injections. It only takes effect if CRC injection Enable is not Disabled.<br>00b : Single Flit is corrupted. CRC Injection Busy is reset to 0b after single Flit corruption.<br>01b: A CRC error is injected every 8 Flits. Hardware continues to inject a CRC error every 8 Flits until CRC Injection Enable is 00b. CRC Injection Busy is reset to 0b only after CRC Injection Enable is 00b.<br>10b: A CRC error is injected every 16 Flits. Hardware continues to inject a CRC error every 16 Flits until CRC Injection Enable is 00b. CRC Injection Busy is reset to 0b only after CRC Injection Enable is 00b.<br>11b: A CRC error is injected every 64 Flits. Hardware continues to inject a CRC error every 64 Flits until CRC Injection Enable is 00b. CRC Injection Busy is reset to 0b only after CRC Injection Enable is 00b. |
| 17    | RO        | <b>CRC Injection Busy</b> : Hardware loads a 1b to this bit once it has begun CRC Injection. Software is permitted to poll on this bit. See CRC Injection Count description to see how this bit returns to 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:18 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**9.5.3.10 Runtime Link Testing Parity Log 0 (Offset 34h)****Table 9-35. Runtime Link Testing Parity Log 0 Register**

| Bit  | Attribute | Description                                                                                                                                                                                     |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Parity Log for Module 0</b> : Hardware updates the bit corresponding to the parity error byte with error over the period when Runtime Link Testing was enabled at Rx.<br>Default Value is 0. |

**9.5.3.11 Runtime Link Testing Parity Log 1 (Offset 3Ch)****Table 9-36. Runtime Link Testing Parity Log 1 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                               |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Parity Log for Module 1</b> : Hardware updates the bit corresponding to the parity error byte with error over the period when Runtime Link Testing was enabled at Rx.<br>Default Value is 0.<br>This register is only applicable if the Adapter is designed for handling two or more Physical Layer modules. It is reserved otherwise. |

**9.5.3.12 Runtime Link Testing Parity Log 2 (Offset 44h)****Table 9-37. Runtime Link Testing Parity Log 2 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                        |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Parity Log for Module 2</b> : Hardware updates the bit corresponding to the parity error byte with error over the period when Runtime Link Testing was enabled at Rx.<br>Default Value is 0.<br>This register is only applicable if the Adapter is designed for handling four Physical Layer modules. It is reserved otherwise. |

### 9.5.3.13 Runtime Link Testing Parity Log 3 (Offset 4Ch)

**Table 9-38.** Runtime Link Testing Parity Log 3 Register

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                   |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <p><b>Parity Log for Module 3:</b> Hardware updates the bit corresponding to the parity error byte with error over the period when Runtime Link Testing was enabled at Rx.<br/>Default Value is 0.</p> <p>This register is only applicable if the Adapter is designed for handling four Physical Layer modules. It is reserved otherwise.</p> |

### 9.5.3.14 Advertised Adapter Capability Log (Offset 54h)

**Table 9-39.** Advertised Adapter Capability Log Register

| Bit  | Attribute | Description                                                                                                                                                                     |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <p><b>Advertised Adapter Capability:</b> Hardware updates the bits corresponding to the data bits it sent in the {AdvCap.Adapter} sideband message.<br/>Default Value is 0.</p> |

### 9.5.3.15 Finalized Adapter Capability Log (Offset 5Ch)

**Table 9-40.** Finalized Adapter Capability Log Register

| Bit  | Attribute | Description                                                                                                                                                                                          |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <p><b>Finalized Adapter Capability:</b> Hardware updates the bits corresponding to the data bits it sent (DP) or received (UP) in the {FinCap.Adapter} sideband message.<br/>Default Value is 0.</p> |

### 9.5.3.16 Advertised CXL Capability Log (Offset 64h)

**Table 9-41.** Advertised CXL Capability Log Register

| Bit  | Attribute | Description                                                                                                                                                                                                 |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <p><b>Advertised CXL Capability:</b> Hardware updates the bits corresponding to the data bits it sent in the {AdvCap.CXL} sideband message, when it is sent with MsgInfo=0000h.<br/>Default Value is 0.</p> |

### 9.5.3.17 Finalized CXL Capability Log (Offset 6Ch)

**Table 9-42.** Finalized CXL Capability Log Register

| Bit  | Attribute | Description                                                                                                                                                                                                                      |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <p><b>Finalized CXL Capability:</b> Hardware updates the bits corresponding to the data bits it sent (DP) or received (UP) in the {FinCap.CXL} sideband message, when it is sent with MsgInfo=0000h.<br/>Default Value is 0.</p> |

### 9.5.3.18 Advertised Multi-Protocol Capability Log Register (Offset 78h)

This register is reserved for designs that do not implement the Enhanced Multi-protocol capability.

**Table 9-43. Advertised Multi-Protocol Capability Log Register**

| Bit  | Attribute | Description                                                                                                                                                                             |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Advertised Multi-Protocol Capability:</b> Hardware updates the bits corresponding to the data bits it sent in the {MultiProtAdvCap.Adapter} sideband message.<br>Default value is 0. |

### 9.5.3.19 Finalized Multi-Protocol Capability Log Register (Offset 80h)

This register is reserved for designs that do not implement the Enhanced Multi-protocol capability.

**Table 9-44. Finalized Multi-Protocol Capability Log Register**

| Bit  | Attribute | Description                                                                                                                                                                            |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Finalized Multi-Protocol Capability:</b> Hardware updates the bits corresponding to the data bits it sent in the {MultiProtFinCap.Adapter} sideband message.<br>Default value is 0. |

### 9.5.3.20 Advertised CXL Capability Log Register for Stack 1 (Offset 88h)

This register is reserved for designs that do not implement the Enhanced Multi-protocol capability.

**Table 9-45. Advertised CXL Capability Log Register for Stack 1**

| Bit  | Attribute | Description                                                                                                                                                                                        |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Advertised CXL Capability:</b> Hardware updates the bits corresponding to the data bits it sent in the {AdvCap.CXL} sideband message when it is sent with MsgInfo=0001h.<br>Default value is 0. |

### 9.5.3.21 Finalized CXL Capability Log Register for Stack 1 (Offset 90h)

This register is reserved for designs not implementing the Enhanced multi-protocol capability.

**Table 9-46. Finalized CXL Capability Log Register for Stack 1**

| Bit  | Attribute | Description                                                                                                                                                                                       |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW1C      | <b>Finalized CXL Capability:</b> Hardware updates the bits corresponding to the data bits it sent in the {FinCap.CXL} sideband message when it is sent with MsgInfo=0001h.<br>Default value is 0. |

### 9.5.3.22 PHY Capability (Offset 1000h)

This register is global, and not per module.

**Table 9-47. Physical Layer Capability Register**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3     | RO        | <b>Terminated Link:</b> If set to 1, the Receiver supports termination. This bit is always cleared to 0 in an Advanced Package.                                                                                                                                                                                                                                                                                                 |
| 4     | RO        | <b>TX Equalization support</b><br>0: TXEQ not supported<br>1: TXEQ supported                                                                                                                                                                                                                                                                                                                                                    |
| 9:5   | RO        | <b>Supported Tx Vswing encodings</b><br>01h: 0.4 V<br>02h: 0.45 V<br>03h: 0.5 V<br>04h: 0.55 V<br>05h: 0.6 V<br>06h: 0.65 V<br>07h: 0.7 V<br>08h: 0.75 V<br>09h: 0.8 V<br>0Ah: 0.85 V<br>0Bh: 0.9 V<br>0Ch: 0.95 V<br>0Dh: 1.0 V<br>0Eh: 1.05<br>0Fh: 1.1 V<br>10h: 1.15 V<br>All other encodings are reserved.<br>This field matches the value advertised by the UCIE Module in the 'Voltage swing' field during MBINIT.PARAM. |
| 10    | RsvdP     | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12:11 | RO        | <b>Rx Clock Mode support</b><br>00b: Supports both free running and strobe modes<br>10b: Free running mode only<br>All other encodings are reserved.<br>This corresponds to the local UCIE Module's capability.                                                                                                                                                                                                                 |
| 14:13 | RO        | <b>Rx Clock phase support</b><br>00b: Differential clock only (all data rates)<br>01b: Quadrature clock (24/32 GT/s);<br>Differential clock (16 GT/s and lower)<br>10b: Same as 01b (for backward compatibility)<br>This corresponds to the local UCIE Module's capability.                                                                                                                                                     |
| 15    | RO        | <b>Package type</b><br>0b: Advanced Package<br>1b: Standard Package                                                                                                                                                                                                                                                                                                                                                             |
| 16    | RO        | <b>Tightly coupled mode (TCM) support</b><br>0b: TCM not Supported<br>1b: TCM supported<br>This corresponds to the local UCIE Module's capability.                                                                                                                                                                                                                                                                              |
| 31:17 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 9.5.3.23 PHY Control (Offset 1004h)

This register is global, and not per module.

**Table 9-48. Physical Layer Control Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0  | RW/RO     | Reserved. Implementations are encouraged to implement this as an RO bit with a default value of 000b. However, for backward compatibility, implementations are permitted to implement this as an RW bit with a default value of 000b.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3    | RW        | <b>Rx Terminated Control</b><br>0b: Rx Termination disabled<br>1b: Rx Termination enabled<br>Default is same as 'Terminated Link' bit in PHY capability register. Note that this bit is always cleared to 0 for Advanced Packages. This control is provided for debug purposes only.                                                                                                                                                                                                                                                                                                                                                    |
| 4    | RW        | <b>Tx Eq Enable</b><br>0b: Eq Disabled<br>1b: Eq Enabled<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5    | RW        | <b>Rx Clock Mode Select</b><br>0: Strobe Mode<br>1: Free running mode<br>Default is 0 if the Rx of the local UCIE Module supports Strobe Mode; otherwise, the bit is set to 1.<br>This control is provided for debug purposes only. This bit is sent as the 'Clock Mode' bit in the {MBINIT.PARAM configuration req} sideband message.                                                                                                                                                                                                                                                                                                  |
| 6    | RW        | <b>Rx Clock phase support select</b><br>0: Differential clock only (all data rates)<br>1: Quadrature clock (24/32 GT/s);<br>Differential clock (16 GT/s and lower)<br>Default is 0.<br>This control is provided for debug purposes only. This bit is sent as the 'Clock Phase' bit in the {MBINIT.PARAM configuration req} sideband message.                                                                                                                                                                                                                                                                                            |
| 7    | RW/RsvdP  | <b>Force x32 Width Mode in x64 Module</b><br>This bit is used only for test and debug purposes. In normal operation, this bit should be reset to 0.<br>When set, this bit will force the x64 module to present "UCIE-A x32 bit =1" during the MBINIT.PARAM exchange phase independent of the value of bit 20, APMW, in the UCIE Link Capability register.<br>This bit applies to all modules in a multi-module link.<br>For x32 Advanced Package modules, this bit is reserved.                                                                                                                                                         |
| 8    | RW/RsvdP  | <b>Force x8 Width Mode in a UCIE-S x16 Module</b><br>This bit is used only for test and debug purposes. In normal operation, this bit should be reset to 0.<br>When set, this bit will force the x16 module to present "UCIE-S x8" bit =1 during the MBINIT.PARAM exchange phase independent of the value of bit 22, SPMW, in the UCIE Link Capability register. This feature can be used only when there is no lane reversal on the UCIE-S x16 link.<br>This bit applies only to Module 0 in a multi-module link. When set in a multi-module link, it trains only Module 0.<br>For a x8 Standard Package Module, this bit is reserved. |
| 31:9 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### 9.5.3.24 PHY Status (Offset 1008h)

This register is global and not per module.

**Table 9-49. Physical Layer Status Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0  | RO        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3    | RO        | <b>Rx Termination Status</b><br>0: Rx Termination disabled<br>1: Rx Termination enabled<br>Default is same as 'Terminated Link' bit in PHY capability register.<br>This is the current status of the local UCIe Module. Note that this is always 0 for Advanced Packages. For Standard packages, whether the Rx decides to terminate the Link could depend on several factors (including channel length in the Package, etc.), and that decision is implementation-specific. For Transmitter of a remote Link partner, it needs this information in order to know whether to Hi-Z the Data and Track Lanes during clock gating and when not performing Runtime Recalibration, respectively. It is expected that this information is known a priori at Package integration time, and the Transmitter is informed of this in an implementation-specific manner. |
| 4    | RO        | <b>Tx Eq Status</b><br>0: Eq Disabled<br>1: Eq Enabled<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5    | RO        | <b>Clock Mode Status</b><br>0: Strobe Mode<br>1: Free running mode<br>Default is 0.<br>This is remote partner's advertised value during MBINIT.PARAM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6    | RO        | <b>Clock phase Status</b><br>0: Differential clock only (all data rates)<br>1: Quadrature clock (24/32 GT/s);<br>Differential clock (16 GT/s and lower)<br>This is remote partner's advertised value during MBINIT.PARAM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7    | RO        | <b>Lane Reversal within Module:</b> Indicates if Lanes within a module are reversed<br>0: Lanes within module not reversed<br>1: Lanes within module are reversed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:8 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

### 9.5.3.25 PHY Initialization and Debug (Offset 100Ch)

This register is global, and not per module.

**Table 9-50. Phy Init and Debug Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0  | RW        | <p><b>Initialization control</b></p> <p>000b: Initialize to Active. This is the regular Link bring up.<br/>     001b: Initialize to MBINIT (Debug mode) (i.e., pause training after completing step-2 of MBINIT.PARAM).<br/>     010b: Initialize to MBTRAIN (Debug/compliance mode) (i.e., pause training after entering MBTRAIN after completing step-1 of MBTRAIN.VALVREF).<br/>     011b = Pause after completing step-1 of MBTRAIN.RXDESKEW; regardless of entering for initial bring up or from Retrain.<br/>     100b = Pause after completing step-1 of MBTRAIN.DATATRAINCENTER2; regardless of entering for initial bring up or from Retrain.<br/>     All other encodings are reserved.</p> <p>When training has paused, the corresponding state timeouts must be disabled, and hardware resumes training on any of the following triggers:</p> <ul style="list-style-type: none"> <li>• A 0b-to-1b transition on 'Resume Training' bit in this register</li> <li>• Sideband message for the corresponding state is received from remote link partner (e.g., if paused in MBINIT, receiving {MBINIT.CAL Done req} from remote link partner is also a trigger to move forward)</li> </ul> <p>A device that does not support the UCIe Test and Compliance register block is permitted to only implement encodings 000b through 010b.<br/>     Default is 000b.</p> |
| 4:3  | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5    | RW        | <p><b>Resume Training</b></p> <p>A 0b-to-1b transition on this bit triggers hardware to resume training from the last link training state, achieved via 'Initialization Control' field in this register until ACTIVE.<br/>     A device that does not support the UCIe Test and Compliance register block is permitted to hardwire this bit to 0b.<br/>     Default is 0b.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:6 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 9.5.3.26 Training Setup 1 (Offset 1010h)

This register is replicated per module. Offsets 1010h to 101Ch are used in 4B increments for multi-module scenarios

**Table 9-51. Training Setup 1 Register**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | RW        | <b>Data pattern used during training</b><br>000b: Per-Lane LFSR pattern<br>001b: Per-Lane ID pattern<br>010b: If @PHY-Compliance {Per-Lane Clock pattern AA pattern}<br>Else Reserved<br>011b: If @PHY-Compliance {Per-Lane all 0 pattern} Else Reserved<br>100b: If @PHY-Compliance {Per-Lane all 1 pattern} Else Reserved<br>101b: If {@PHY-Compliance Per-Lane inverted Clock pattern} Else Reserved<br>All other encodings are reserved<br>Default is 000b. |
| 5:3   | RW        | <b>Valid Pattern used during training</b><br>000b: Functional valid pattern (1111 0000 (lsb first))<br>All other encodings are reserved<br>Default is 000b.                                                                                                                                                                                                                                                                                                     |
| 9:6   | RW        | <b>Clock Phase control</b><br>0h: Clock PI center found by Transmitter<br>1h: Left edge found through Data to clock training<br>2h: Right edge found through Data to clock training<br>All other encodings are reserved<br>Default = 0                                                                                                                                                                                                                          |
| 10    | RW        | <b>Training mode</b><br>0b: Continuous mode<br>1b: Burst Mode<br>Default = 0                                                                                                                                                                                                                                                                                                                                                                                    |
| 26:11 | RW        | <b>Burst Count:</b> Indicates the duration of selected pattern (UI count)<br>Default = 4h                                                                                                                                                                                                                                                                                                                                                                       |
| 31:27 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 9.5.3.27 Training Setup 2 (Offset 1020h)

This register is replicated per module. Offsets 1020h to 102Ch are used in 4B offset increments for multi-module scenarios.

**Table 9-52. Training Setup 2 Register**

| Bit   | Attribute | Description                                                                                            |
|-------|-----------|--------------------------------------------------------------------------------------------------------|
| 15:0  | RW        | <b>Idle count:</b> Indicates the duration of low following the burst (UI count)<br>Default = 4h        |
| 31:16 | RW        | <b>Iterations:</b> Indicates the iteration count of bursts followed by idle (UI count)<br>Default = 4h |

### 9.5.3.28 Training Setup 3 (Offset 1030h)

This register is replicated per module. Offsets 1030h to 1048h are used in 8B offset increments for multi-module scenarios.

**Table 9-53. Training Setup 3 Register**

| Bit  | Attribute | Description                                                                                                                                 |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW        | <b>Lane mask:</b> Indicated the Lanes to mask during Rx comparison. Example 1h = Lane 0 is masked during comparison. Default = 0 (no mask). |

### 9.5.3.29 Training Setup 4 (Offset 1050h)

This register is replicated per module. Offsets 1050h to 105Ch are used in 4B offset increments for multi-module scenarios.

**Table 9-54. Training Setup 4 Register**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | RW        | <b>Repair Lane mask:</b> Indicated the Redundant Lanes to mask during Rx comparison. Example 1h = RD0 is masked during comparison 2h: RD1 mask. Default = 0 (no mask).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15:4  | RW        | <b>Max error Threshold in per Lane comparison:</b> Indicates threshold for error counting to start. For Tx-initiated tests, these values are sent in the corresponding {Start Tx Init D to C point test req} and {Start Tx Init D to C eye sweep req} sideband messages. The remote Link partner must use these values for checking errors against the threshold. For Rx-initiated tests, these values are sent in the corresponding {Start Rx Init D to C point test req} and {Start Rx Init D to C eye sweep req} sideband messages as an inform. The receiver uses these values for checking errors against the threshold. Default = 0 (all errors are counted).  |
| 31:16 | RW        | <b>Max error Threshold in aggregate comparison:</b> Indicates threshold for error counting to start. For Tx-initiated tests, these values are sent in the corresponding {Start Tx Init D to C point test req} and {Start Tx Init D to C eye sweep req} sideband messages. The remote Link partner must use these values for checking errors against the threshold. For Rx-initiated tests, these values are sent in the corresponding {Start Rx Init D to C point test req} and {Start Rx Init D to C eye sweep req} sideband messages as an inform. The receiver uses these values for checking errors against the threshold. Default = 0 (all errors are counted). |

### 9.5.3.30 Current Lane Map Module 0 (Offset 1060h)

**Table 9-55. Current Lane Map Module 0 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                               |
|------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW        | <b>Current Rx Lane map (CLM) for Module-0:</b> If a bit is 1 it indicates the corresponding physical Lane is operational. For Standard package modules, bits 63:16 of this register are not applicable. For UCIe-A x32 implementations (i.e., APMW bit in UCIe Link Capability register is set), bits 63:32 of this register are not applicable. Default Value is all 0s. |

### 9.5.3.31 Current Lane Map Module 1 (Offset 1068h)

**Table 9-56. Current Lane Map Module 1 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW        | <b>Current Rx Lane map (CLM) for Module-1:</b> If a bit is 1 it indicates the corresponding physical Lane is operational. For Standard package modules, bits 63:16 of this register are not applicable. For UCIe-A x32 implementations (i.e., APMW bit in UCIe Link Capability register is set), bits 63:32 of this register are not applicable. Default Value is all 0s.<br>This register is reserved if Module 1 is not present |

### 9.5.3.32 Current Lane Map Module 2 (Offset 1070h)

**Table 9-57. Current Lane Map Module 2 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW/RsvdP  | <b>Current Rx Lane map (CLM) for Module-2:</b> If a bit is 1 it indicates the corresponding physical Lane is operational. For Standard package modules, bits 63:16 of this register are not applicable. For UCIe-A x32 implementations (i.e., APMW bit in UCIe Link Capability register is set), bits 63:32 of this register are not applicable. Default Value is all 0s.<br>This register is reserved if Module 2 is not present |

### 9.5.3.33 Current Lane Map Module 3 (Offset 1078h)

**Table 9-58. Current Lane Map Module 3 Register**

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RW/RsvdP  | <b>Current Rx Lane map (CLM) for Module-3:</b> If a bit is 1 it indicates the corresponding physical Lane is operational. For Standard package modules, bits 63:16 of this register are not applicable. For UCIe-A x32 implementations (i.e., APMW bit in UCIe Link Capability register is set), bits 63:32 of this register are not applicable. Default Value is all 0s.<br>This register is reserved if Module 3 is not present |

### 9.5.3.34 Error Log 0 (Offset 1080h)

This register is replicated per module. Offsets 1080h to 108Ch are used in 4B offset increments for multi-module scenarios.

**Table 9-59. Error Log 0 Register**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | ROS       | <p><b>State N:</b> Captures the current Link training state machine status. State Encodings are given by:</p> <ul style="list-style-type: none"> <li>00h RESET</li> <li>01h SBINIT</li> <li>02h MBINIT.PARAM</li> <li>03h MBINIT.CAL</li> <li>04h MBINIT.REPAIRCLK</li> <li>05h MBINIT.REPAIRVAL</li> <li>06h MBINIT.REVERSALMB</li> <li>07h MBINIT.REPAIRMB</li> <li>08h MBTRAIN.VALVREF</li> <li>09h MBTRAIN.DATAVREF</li> <li>0Ah MBTRAIN.SPEEDIDLE</li> <li>0Bh MBTRAIN.TXSELFCAL</li> <li>0Ch MBTRAIN.RXSELFCAL</li> <li>0Dh MBTRAIN.VALTRAINCENTER</li> <li>0Eh MBTRAIN.VALTRAINVREF</li> <li>0Fh MBTRAIN.DATATRAINCENTER1</li> <li>10h MBTRAIN.DATATRAINVREF</li> <li>11h MBTRAIN.RXDESKEW</li> <li>12h MBTRAIN.DATATRAINCENTER2</li> <li>13h MBTRAIN.LINKSPEED</li> <li>14h MBTRAIN.REPAIR</li> <li>15h PHYRETRAIN</li> <li>16h LINKINIT</li> <li>17h ACTIVE</li> <li>18h TRAINERROR</li> <li>19h L1/L2</li> </ul> <p>All other encodings are reserved<br/>Default is 0</p> |
| 8     | ROS       | <b>Lane Reversal:</b> 1b indicates Lane Reversal within the module.<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9     | ROS       | <b>Width Degrade:</b> 1b indicates Module width Degrade. Applicable to Standard package only. Default is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:10 | RsvdZ     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23:16 | ROS       | <b>State (N-1):</b> Captures the state before State N was entered for Link training state machine. State encodings are the same as State N field.<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:24 | ROS       | <b>State (N-2):</b> Captures the state before State (N-1) was entered for Link training state machine. State encodings are the same as State N field.<br>Default is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 9.5.3.35 Error Log 1 (Offset 1090h)

This register is replicated per module. Offsets 1090h to 109Ch are used in 4B offset increments for multi-module scenarios.

**Table 9-60. Error Log 1 Register**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                      |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | ROS       | <b>State (N-3):</b> Captures the state status before State (N-2) was entered. State encodings are the same as State N field.<br>Default is 0                                                                                                                     |
| 8     | RW1CS     | <b>State Timeout Occurred:</b> Hardware sets this to 1b if a Link Training State machine state or sub-state timed out and it was escalated as a fatal error.<br>Default value is 0b.                                                                             |
| 9     | RW1CS     | <b>Sideband Timeout Occurred:</b> Hardware sets this to 1b if a sideband handshake timed out, for example, if a RDI request did not get a response for 8ms. Sideband handshakes related to Link Training messages are not included here.<br>Default value is 0b. |
| 10    | RW1CS     | <b>Remote LinkError received:</b> Hardware sets this to 1b if remote Link partner requested LinkError transition through RDI sideband.<br>Default value is 0b.                                                                                                   |
| 11    | RW1CS     | <b>Internal Error:</b> Hardware sets this to 1b if any implementation specific internal error occurred in the Physical Layer.<br>Default value is 0b.                                                                                                            |
| 31:12 | RsvdZ     | Reserved                                                                                                                                                                                                                                                         |

### 9.5.3.36 Runtime Link Test Control (Offset 1100h)

**Table 9-61. Runtime Link Test Control (Sheet 1 of 2)**

| Bit | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW/RO     | Implementations are encouraged to implement this as an RO bit with a default value of 0. However, for backward compatibility, implementations are permitted to implement this as an RW bit with a default value of 0.                                                                                                                                                                                                     |
| 1   | RW/RO     | Implementations are encouraged to implement this as an RO bit with a default value of 0. However, for backward compatibility, implementations are permitted to implement this as an RW bit with a default value of 0.                                                                                                                                                                                                     |
| 2   | RW        | <b>Apply Module 0 Lane Repair:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical module id at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 0, if possible and relevant.<br>Default value is 0.                                                        |
| 3   | RW        | <b>Apply Module 1 Lane Repair:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical module id at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 1, if possible and relevant.<br>Default value is 0.<br>These bits are reserved if Module 1 is not present. |

**Table 9-61. Runtime Link Test Control (Sheet 2 of 2)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4     | RW        | <b>Apply Module 2 Lane Repair:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical module id at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 2, if possible and relevant.<br>Default value is 0.<br>These bits are reserved if Module 2 is not present.                                                                                             |
| 5     | RW        | <b>Apply Module 3 Lane Repair:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical module id at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 3, if possible and relevant.<br>Default value is 0.<br>These bits are reserved if Module 3 is not present.                                                                                             |
| 6     | RW        | <b>Start:</b> Software writes to this bit before setting Link Retrain bit to inform hardware that the contents of this register are valid. HW clears this bit to 0 after the Busy bit in the Runtime Link Test Status register is set to 1.                                                                                                                                                                                                                                                                           |
| 7     | RW        | <b>Inject Stuck-at fault:</b> Software writes 1b to this bit to indicate hardware must inject a stuck at fault for the Lane id identified in Lane Repair id (the specific Module's lane(s) in which the fault is injected is indicated by the 'Apply Module x Lane Repair' bits) for the corresponding field. Injecting the fault at Tx or Rx is implementation specific.<br>This bit takes effect during the next link retraining (see <a href="#">Section 4.5.3.7</a> for further details).<br>Default value is 0b. |
| 14:8  | RW        | <b>Module 0 Lane repair id:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical transmit Lane id in logical Module 0 at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 0, if possible and relevant.<br>Default is 0.<br>These bits are reserved if Module 0 is not present.                                                                           |
| 21:15 | RW        | <b>Module 1 Lane repair id:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical transmit Lane id in logical Module 1 at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 1, if possible and relevant.<br>Default is 0.<br>These bits are reserved if Module 1 is not present.                                                                           |
| 28:22 | RW        | <b>Module 2 Lane repair id:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical transmit Lane id in logical Module 2 at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 2, if possible and relevant.<br>Default is 0.<br>These bits are reserved if Module 2 is not present.                                                                           |
| 35:29 | RW        | <b>Module 3 Lane repair id:</b> For Advanced Package, software programs this bit to inform Physical Layer hardware to apply Lane repair for this logical transmit Lane id in logical Module 3 at the next Retrain cycle, if this Module is operational. For Standard Package, this bit will trigger a width degrade for logical Module 3, if possible and relevant.<br>Default is 0.<br>These bits are reserved if Module 3 is not present.                                                                           |
| 63:36 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 9.5.3.37 Runtime Link Test Status (Offset 1108h)

**Table 9-62.** Runtime Link Test Status Register

| Bit  | Attribute | Description                                                                                                                                                                                                                    |
|------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | RO        | <b>Busy:</b> Hardware loads 1b to this bit once Start bit is written by software. Hardware loads 0b to this bit once it has attempted to complete the actions requested in Runtime Link Test Control register.<br>Default is 0 |
| 31:1 | RsvdZ     | Reserved                                                                                                                                                                                                                       |

### 9.5.3.38 Mainband Data Repair (Offset 110Ch)

This register is replicated per advanced module. For Standard package, this register is not applicable. Offsets 110Ch to 1124h are used in 8B offset increments for multi-module scenarios.

**Table 9-63.** Mainband Data Repair Register (Sheet 1 of 2)

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | RO        | <b>Repair Address for TRD_P[0]:</b> Indicates the physical Lane repaired when TRD_P[0] is used in remapping scheme<br>00h: TD_P[0] Repaired<br>01h: TD_P[1] Repaired<br>02h: TD_P[2] Repaired<br>.....<br>1Eh: TD_P[30] Repaired<br>1Fh: TD_P[31] Repaired<br>F0h: Repair attempt failed<br>FFh: No Repair                                                                     |
| 15:8  | RO        | <b>Repair Address for TRD_P[1]:</b> Indicates the physical Lane repaired when TRD_P[1] is used in remapping scheme<br>00h: Invalid<br>01h: TD_P[1] Repaired<br>02h: TD_P[2] Repaired<br>.....<br>1Eh: TD_P[30] Repaired<br>1Fh: TD_P[31] Repaired<br>F0h: Repair attempt failed<br>FFh: No Repair                                                                              |
| 23:16 | RO        | <b>Repair Address for TRD_P[2]:</b> Indicates the physical Lane repaired when TRD_P[2] is used in remapping scheme<br>20h: TD_P[32] Repaired<br>21h: TD_P[33] Repaired<br>22h: TD_P[34] Repaired<br>.....<br>3Eh: TD_P[62] Repaired<br>3Fh: TD_P[63] Repaired<br>F0h: Repair attempt failed<br>FFh: No Repair<br>This field is reserved for UCIe-A x32 module implementations. |

**Table 9-63. Mainband Data Repair Register (Sheet 2 of 2)**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO        | <p><b>Repair Address for TRD_P[3]:</b> Indicates the physical Lane repaired when TRD_P[3] is used in remapping scheme</p> <p>20h: Invalid<br/>21h: TD_P[33] Repaired<br/>22h: TD_P[34] Repaired<br/>.....<br/>3Eh: TD_P[62] Repaired<br/>3Fh: TD_P[63] Repaired<br/>F0h: Repair attempt failed<br/>FFh: No Repair</p> <p>This field is reserved for UCIE-A x32 module implementations.</p>           |
| 39:32 | RO        | <p><b>Repair Address for RRD_P[0]:</b> Indicates the physical Lane repaired when RRD_P[0] is used in remapping scheme</p> <p>00h: RD_P[0] Repaired<br/>01h: RD_P[1] Repaired<br/>02h: RD_P[2] Repaired<br/>.....<br/>1Eh: RD_P[30] Repaired<br/>1Fh: RD_P[31] Repaired<br/>F0h: Repair attempt failed<br/>FFh: No Repair</p>                                                                         |
| 47:40 | RO        | <p><b>Repair Address for RRD_P[1]:</b> Indicates the physical Lane repaired when RRD_P[1] is used in remapping scheme</p> <p>00h: RD_P[0] Repaired<br/>01h: RD_P[1] Repaired<br/>02h: RD_P[2] Repaired<br/>.....<br/>1Eh: RD_P[30] Repaired<br/>1Fh: RD_P[31] Repaired<br/>F0h: Repair attempt failed<br/>FFh: No Repair</p>                                                                         |
| 55:48 | RO        | <p><b>Repair Address for RRD_P[2]:</b> Indicates the physical Lane repaired when RRD_P[2] is used in remapping scheme</p> <p>20h: RD_P[32] Repaired<br/>21h: RD_P[33] Repaired<br/>22h: RD_P[34] Repaired<br/>.....<br/>3Eh: RD_P[62] Repaired<br/>3Fh: RD_P[63] Repaired<br/>F0h: Repair attempt failed<br/>FFh: No Repair</p> <p>This field is reserved for UCIE-A x32 implementations.</p>        |
| 63:56 | RO        | <p><b>Repair Address for RRD_P[3]:</b> Indicates the physical Lane repaired when RRD_P[3] is used in remapping scheme</p> <p>20h: RD_P[32] Repaired<br/>21h: RD_P[33] Repaired<br/>22h: RD_P[34] Repaired<br/>.....<br/>3Eh: RD_P[62] Repaired<br/>3Fh: RD_P[63] Repaired<br/>F0h: Repair attempt failed<br/>FFh: No Repair</p> <p>This field is reserved for UCIE-A x32 module implementations.</p> |

### 9.5.3.39 Clock, Track, Valid and Sideband Repair (Offset 1134h)

This register is replicated per module. Offsets 1134h to 1140h are used in 4B offset increments for multi-module scenarios.

**Table 9-64. Clock, Track, Valid and Sideband Repair Register**

| Bit   | Attribute | Description                                                                                                                                                                                                                                                                                          |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | RO        | <b>Repair Address for TRDCK_P:</b> Indicates the physical Lane repaired when <b>TRDCK_P</b> is used in remapping scheme<br>0h: <b>TCKP_P</b> Repaired<br>1h: <b>TCKN_P</b> Repaired<br>2h: <b>TTRK_P</b> Repaired<br>7h: Repair attempt failed<br>Fh: No Repair<br>All other encodings are reserved. |
| 7:4   | RO        | <b>Repair Address for RRDCK_P:</b> Indicates the physical Lane repaired when <b>RRDCK_P</b> is used in remapping scheme<br>0h: <b>RCKP_P</b> Repaired<br>1h: <b>RCKN_P</b> Repaired<br>2h: <b>RTRK_P</b> Repaired<br>7h: Repair attempt failed<br>Fh: No Repair<br>All other encodings are reserved. |
| 9:8   | RO        | <b>Repair Address for TRDVLD_P:</b> Indicates the physical Lane repaired when <b>TRDVLD_P</b> is used in remapping scheme<br>00b: <b>TVLD_P</b> Repaired<br>01b: Repair attempt failed<br>10b: Reserved<br>11b: No Repair                                                                            |
| 11:10 | RO        | <b>Repair Address for RRDVLD_P:</b> Indicates the physical Lane repaired when <b>RRDVLD_P</b> is used in remapping scheme<br>00b: <b>RVLD_P</b> Repaired<br>01b: Repair attempt failed<br>10b: Reserved<br>11b: No Repair                                                                            |
| 15:12 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                             |
| 19:16 | RO        | <b>Repair Address for Sideband Transmitter:</b> Indicates sideband repair result for the Transmitter<br>Result[3:0]                                                                                                                                                                                  |
| 23:20 | RO        | <b>Repair Address for Sideband Receiver:</b> Indicates sideband repair result for the Transmitter<br>Result[3:0]                                                                                                                                                                                     |
| 31:24 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                             |

### 9.5.3.40 UCIe Link Health Monitor (UHM) DVSEC

This DVSEC is an extended Capability. It is required for all devices that support Compliance testing (as indicated by the presence of Compliance/Test Register Locator) and optional otherwise. This DVSEC contains the required registers for SW to read eye margin values per lane. SW Flow for Eye Margining is as follows:

- SW ensures that the Eye Margin Valid (EMV) bit in UHM\_STS register is cleared
- SW triggers a retrain of the link
  - When the retrain completes (as indicated by bit 16 in the UCIe Link Status register) and the EMV bit is set in the UHM\_STS register, SW can read the EM\*\_Ln\*\_Mod\* registers in UHM DVSEC to know the margins. Receive margins are logged in the Tx UHM registers.

Note that HW may also measure Eye Margins during HW-autonomous retraining and/or initial training and if measured, is permitted to report it in the Eye Margin registers whenever the EMV bit is cleared.

For x32 Advanced Packaging implementations, EML\* and EMR\* registers for Lanes 63:32 are RsvdP.

**Figure 9-5. UCIe Link Health Monitor (UHM) DVSEC**

|                                        |                                     |              |              |  |  |
|----------------------------------------|-------------------------------------|--------------|--------------|--|--|
| PCI Express Extended Capability Header |                                     |              |              |  |  |
| Designated Vendor Specific Header 1    |                                     |              |              |  |  |
| Reserved                               | Designated Vendor Specific Header 2 |              |              |  |  |
| UHM_STS                                | Reserved                            |              |              |  |  |
| Reserved                               |                                     |              |              |  |  |
| Reserved                               |                                     |              |              |  |  |
| EMR_Ln1_Mod0                           | EML_Ln1_Mod0                        | EMR_Ln0_Mod0 | EML_Ln0_Mod0 |  |  |
| EMR_Ln3_Mod0                           | EML_Ln3_Mod0                        | EMR_Ln2_Mod0 | EML_Ln2_Mod0 |  |  |
| ...                                    |                                     |              |              |  |  |
| ...                                    |                                     |              |              |  |  |
| EMR_Ln1_Mod1                           | EML_Ln1_Mod1                        | EMR_Ln0_Mod1 | EML_Ln0_Mod1 |  |  |
| EMR_Ln3_Mod1                           | EML_Ln3_Mod1                        | EMR_Ln2_Mod1 | EML_Ln2_Mod1 |  |  |
| ...                                    |                                     |              |              |  |  |
| ...                                    |                                     |              |              |  |  |

**Table 9-65. UHM DVSEC - Designated Vendor Specific Header 1, 2 (Offsets 04h and 08h)**

| Register                                            | Field           | Bit Location | Value            |
|-----------------------------------------------------|-----------------|--------------|------------------|
| Designated Vendor-Specific Header 1<br>(offset 04h) | DVSEC Vendor ID | 15:0         | D2DEh            |
|                                                     | DVSEC Revision  | 19:16        | 0h               |
|                                                     | Length          | 31:20        | Design dependent |
| Designated Vendor-Specific Header 2<br>(offset 08h) | DVSEC ID        | 15:0         | 1h               |

### 9.5.3.40.1 UHM Status (Offset Eh)

**Table 9-66.** UHM Status

| Bit  | Attribute | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0  | RO        | <b>Step Count</b><br>Step count used in the reporting of margin information. A value of 0 indicates 256. For example, a value of 32 indicates that the UI is equally divided into 32 steps and Eye Margin registers provide the left and right margins in multiples of UI/32.                                                                                                                                                                                                                                                                                                                                                      |
| 8    | RW1C      | <b>Eye Margin Valid (EMV)</b><br>This bit, when set, indicates that margin registers carry valid information from the last retrain. SW must clear this bit before initiating link retrain, if it intends to measure eye margins during the retrain. On a SW-initiated link retrain, if after retrain, this bit is cleared, then SW should infer that there was some error in margin measurement.<br>Note that HW logs any new Eye Margin measurements (whether it is measured during SW-initiated retrain, during HW-autonomous retraining, or during initial training) in the Eye Margin registers only when this bit is cleared. |
| 15:9 | RsvdP     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 9.5.3.40.2 Eye Margin (Starting Offset 18h)

**Table 9-67.** EML\_Lnx\_Mody

| Bit | Attribute | Description                                                                                                                          |
|-----|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RO        | <b>Eye Margin Left for Lane x and Module y</b><br>Provides the left eye margin relative to the PI center, in units of UI/Step Count. |

**Table 9-68.** EMR\_Lnx\_Mody

| Bit | Attribute | Description                                                                                                                            |
|-----|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RO        | <b>Eye Margin Right for Lane x and Module y</b><br>Provides the right eye margin relative to the PI center, in units of UI/Step Count. |

### 9.5.4 Test/Compliance Register Block

The Test/Compliance register block is 8 KB in size with first 4 KB from base address (as enumerated via register locator with Register Block Identifier of 1h) used for D2D Adapter-related Test/Compliance registers and the second 4 KB used for PHY-related Test/Compliance registers. For future extensibility, these offsets are enumerable via the associated Register Block Offset registers, as shown in [Figure 9-6](#).

**Figure 9-6. UCIE Test/Compliance Register Block**



### 9.5.4.1 UCIe Register Block Header

**Table 9-69. UCIe Register Block Header (Offset 0h)**

| Bit    | Attributes | Description                                                                                                                                     |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | RO         | <b>Vendor ID</b><br>Default is set to Vendor ID assigned for UCIe Consortium - D2DEh.                                                           |
| 31:16  | RO         | <b>Vendor ID Register Block</b><br>Set to 1h to indicate Test Compliance register block.                                                        |
| 35:32  | RO         | <b>Vendor Register Block Version</b><br>Set to 0h.                                                                                              |
| 63:36  | RsvdP      | Reserved                                                                                                                                        |
| 95:64  | RO         | <b>Vendor Register Block Length</b><br>The number of bytes in the register block including the UCIe register block header.<br>Default is 2000h. |
| 127:96 | RsvdP      | Reserved                                                                                                                                        |

### 9.5.4.2 D2D Adapter Test/Compliance Register Block Offset

**Table 9-70. D2D Adapter Test/Compliance Register Block Offset (Offset 10h)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                        |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | RO         | <b>D2D Adapter Test/Compliance Register Block Offset (D2DOFF)</b><br>4-KB granular offset from Test/Compliance Register Block base address for D2D Adapter Test/Compliance registers. This field should be set to 0. However, SW must read this field to know the actual offset, for future compatibility reasons. |
| 15:8  | RO         | <b>D2D Adapter Test/Compliance Register Block Length</b><br>4-KB granular length of the D2D Adapter Test/Compliance registers. This field should be set to 1 to indicate 4-KB length. However, SW must read this field to know the actual length, for future compatibility reasons.                                |
| 31:16 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                           |

### 9.5.4.3 PHY Test/Compliance Register Block Offset

**Table 9-71. PHY Test/Compliance Register Block Offset (Offset 14h)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | RO         | <b>PHY Test/Compliance Register Block Offset (PHYOFF)</b><br>4-KB granular offset from Test/Compliance Register Block base address for PHY Adapter Test/Compliance registers. This field should be set to 1, indicating that the registers start at 4 KB from the base address. However, SW must read this field to know the actual offset, for future compatibility reasons. |
| 15:8  | RO         | <b>PHY Test/Compliance Register Block Length</b><br>4-KB granular length of the PHY Test/Compliance registers. This field should be set to 1 to indicate 4-KB length. However, SW must read this field to know the actual length, for future compatibility reasons.                                                                                                           |
| 31:16 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                      |

## 9.5.4.4 D2D Adapter Test/Compliance Register Block

### 9.5.4.4.1 Adapter Compliance Control

**Table 9-72. Adapter Compliance Control (Offset 20h from D2DOFF)**

| Bit  | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | RW         | <p><b>Compliance Mode</b><br/>           Any write to this register takes effect after the next entry of RDI state status to Retrain.</p> <ul style="list-style-type: none"> <li>• 00b = Normal mode of operation</li> <li>• 01b = PHY only Link Training or Retraining               <ul style="list-style-type: none"> <li>— Adapter performs the necessary RDI handshakes to bring RDI to Active but does not perform Parameter exchanges or Adapter vLSM handshakes and keeps FDI in Reset to prevent mainband traffic.</li> <li>— Adapter must still trigger RDI to Retrain if software programmed the Retrain bit in Link Control.</li> <li>— Sideband Register Access requests and completions are operational in this mode.</li> </ul> </li> <li>• 10b = Adapter Compliance               <ul style="list-style-type: none"> <li>— Adapter performs the necessary RDI handshakes to bring RDI to Active but does not perform Parameter exchanges or Adapter vLSM handshakes (unless triggered by software) and keeps FDI in Reset.</li> <li>— Adapter only performs actions based on the triggers and setup according to the registers defined in <a href="#">Section 9.5.4.4.2</a> to <a href="#">Section 9.5.4.4.6</a>.</li> <li>— Adapter must still trigger RDI to Retrain if software programmed the Retrain bit in Link Control.</li> <li>— Sideband Register Access requests and completions are operational in this mode.</li> </ul> </li> <li>• 11b = Reserved</li> </ul> <p>Any RDI transition to LINKERROR when this field is either 01b or 10b does not reset any registers.<br/>           Default is 00b.</p> |
| 2    | RW         | <p><b>Force Link Reset</b><br/>           If set to 1b, Adapter transitions RDI to LinkError state.<br/>           This bit is used by Compliance software to re-initialize the DUT anytime during Compliance testing. If SW expectation is that the DUT reinitializes to normal mode at the end of link reset, the Compliance Mode field in this register must be 00b and the Compliance Enable for PHY bit in the PHY Compliance Control Register must be 0b.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:3 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 9.5.4.4.2 Flit Tx Injection Control

**Table 9-73. Flit Tx Injection Control (Offset 28h from D2DOFF) (Sheet 1 of 2)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RW         | <b>Flit Tx Injection Enable</b><br>Setting this bit to 1b starts Flit injection from the Adapter to the PHY at the Transmitter. Clearing this bit to 0b stops Flit injection on the Link.<br>Default is 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3:1   | RW         | <b>Flit Type</b><br>Type of Flit injected. <ul style="list-style-type: none"> <li>• 000b = Adapter NOP Flits. These bypass TX retry buffer.</li> <li>• 001b = Test Flits.</li> <li>• 010b = Alternate between NOP Flits and Test Flits.</li> <li>• All other encodings are reserved.</li> </ul> Default is 000b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5:4   | RW         | <b>Injection mode</b> <ul style="list-style-type: none"> <li>• 00b = Continuous injection of Flits as specified by Flit Type field.</li> <li>• 01b = Inject 'Flit Inject Number' of Flits contiguously without any intervening Protocol Flits.</li> <li>• 10b = Inject 'Flit Inject Number' of Flits while interleaving with Protocol Flits. If Protocol Flits are available, alternate between Protocol Flits and Injected Flits. If no Protocol Flits are available then, inject consecutively.</li> <li>• 11b = Reserved.</li> </ul> Default is 00b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13:6  | RW         | <b>Flit Inject Number</b><br>If the Injection mode is not 00b, this field indicates the number of Flits injected.<br>Default is 00h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17:14 | RW         | <b>Payload Type</b><br>This field determines the payload type used if Test Flits are injected. Payload includes all bits in the Flit with the exception of Flit Header, CRC, and Reserved bits. <ul style="list-style-type: none"> <li>• 0h = Fixed 4B pattern picked up from 'Payload Fixed Pattern' field of this register, inserted so as to cover all the Payload bytes (with the same pattern replicated in incrementing 4B chunks)</li> <li>• 1h = Random 4B pattern picked up from a 32b LFSR (linear feedback shift register used for pseudo random pattern generation), inserted so as to cover all the Payload bytes (with the same pattern replicated in incrementing 4B chunks)</li> <li>• 2h = Fixed 4 byte pattern picked up from 'Payload Fixed Pattern' field of this register, inserted once at the 'Flit Byte Offset' location within the Flit</li> <li>• 3h = Random 4B pattern picked up from a 32b LFSR, inserted once at the 'Flit Byte Offset' location within the Flit and the rest of the payload is assigned 0b</li> <li>• 4h = Same as 2h, except the 4B pattern is injected every 'Pattern Repetition' bytes starting with 'Flit Byte Offset'</li> <li>• 5h = Same as 3h, except the 4B pattern is injected every 'Pattern Repetition' bytes starting with 'Flit Byte Offset' and the rest of the payload is assigned 0b</li> <li>• All other encodings are reserved</li> </ul> Default is 0h.<br>LFSR seed and primitive polynomial choice is implementation specific.<br><b>Note:</b> While in mission mode, because scrambling is always enabled, changing the Payload Type may have no benefit. This may, however, be useful during compliance testing with scrambling disabled. |

**Table 9-73. Flit Tx Injection Control (Offset 28h from D2DOFF) (Sheet 2 of 2)**

| Bit   | Attributes | Description                                                                                                                                   |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 25:18 | RW         | <b>Flit Byte Offset</b><br>See 'Payload Type'. Default is 00h.                                                                                |
| 31:26 | RW         | <b>Pattern Repetition</b><br>See 'Payload Type'. A value of 00h or 01h must be interpreted as a single pattern occurrence.<br>Default is 00h. |
| 63:32 | RW         | <b>Payload Fixed Pattern</b><br>See 'Payload Type'. Default is 0000 0000h.                                                                    |

**9.5.4.4.3 Adapter Test Status (Offset 30h from D2DOFF)****Table 9-74. Adapter Test Status (Sheet 1 of 2)**

| Bit | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RO         | <b>Compliance Status</b><br>If Adapter is in 'PHY only Link Training or Retraining' or 'Adapter Compliance' mode, it is set to 1b; otherwise, it is 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2:1 | RO         | <b>Flit Tx Injection Status</b> <ul style="list-style-type: none"> <li>00b = No Flits injected.</li> <li>01b = At least one Flit was injected, but not completed. For Continuous Injection mode, this will be the status until Flit Injection Enable transitions from 1b to 0b.</li> <li>10b = Completed Flit Injection, for cases in which a finite number of Flit injections was set up.</li> <li>11b = Flit Injection Enable transitioned from 1b to 0b before Flit injections were complete.</li> </ul> <p>This field is cleared to 00b on a 0b-to-1b transition of Flit Injection Enable bit. Default is 00b.</p> |
| 4:3 | RW1C       | <b>Flit Rx Status</b> <ul style="list-style-type: none"> <li>00b = No Test Flits received</li> <li>01b = Received at least one Test Flit without CRC error</li> <li>All other encodings are reserved</li> </ul> <p>Default is 00b.</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| 5   | RO         | <b>Link State Request Injection Status for Stack 0</b> <ul style="list-style-type: none"> <li>0b = No request injected</li> <li>1b = Completed Request Injection</li> </ul> <p>This bit is cleared to 0b on a 0b-to-1b transition of 'Link State Request or Response Injection Enable'.</p>                                                                                                                                                                                                                                                                                                                            |
| 6   | RO         | <b>Link State Response Injection Status for Stack 0</b> <ul style="list-style-type: none"> <li>0b = No response injected</li> <li>1b = Completed Response Injection</li> </ul> <p>This bit is cleared to 0b on a 0b-to-1b transition of 'Link State Request or Response Injection Enable'.</p>                                                                                                                                                                                                                                                                                                                         |
| 7   | RO         | <b>Link State Request Injection Status for Stack 1</b> <ul style="list-style-type: none"> <li>0b = No request injected</li> <li>1b = Completed Request Injection</li> </ul> <p>This bit is cleared to 0b on a 0b-to-1b transition of 'Link State Request or Response Injection Enable'.</p>                                                                                                                                                                                                                                                                                                                            |

**Table 9-74. Adapter Test Status (Sheet 2 of 2)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8     | RO         | <b>Link State Response Injection Status for Stack 1</b> <ul style="list-style-type: none"> <li>0b = No response injected</li> <li>1b = Completed Response Injection</li> </ul> This bit is cleared to 0b on a 0b-to-1b transition of 'Link State Request or Response Injection Enable'.                                                                                       |
| 10:9  | RO         | <b>Retry Injection Status</b> <ul style="list-style-type: none"> <li>00b = No errors injected on Transmitted Flits</li> <li>01b = Injected error on at least one transmitted Flit</li> <li>10b = Finished error injection sequence on transmitted Flits</li> <li>11b = Reserved</li> </ul> This field is cleared to 00b on a 0b-to-1b transition of 'Retry Injection Enable'. |
| 11    | RO         | <b>Number of Retries Exceeded Threshold</b> Set to 1b if the number of independent retry events exceed the threshold defined in 'Tx Retry Error Threshold'.           This bit is cleared to 0b on a 0b-to-1b transition of 'Retry Injection Enable'.                                                                                                                         |
| 31:12 | RsvdZ      | Reserved                                                                                                                                                                                                                                                                                                                                                                      |

#### 9.5.4.4.4 Link State Injection Control Stack 0 (Offset 34h from D2DOFF)

As mentioned in [Section 11.2](#), this register only takes effect when the Adapter is in Adapter Compliance Mode.

**Table 9-75. Link State Injection Control Stack 0**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                          |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RW         | <b>Link State Request or Response Injection Enable at Tx</b> <ul style="list-style-type: none"> <li>0b = Link State Request or Response Injection not enabled at Tx</li> <li>1b = Link State Request or Response Injection enabled at Tx</li> </ul>                                                  |
| 1     | RW         | <b>Injection Type</b> <ul style="list-style-type: none"> <li>0b = Inject a request packet with the request matching "Link Request" field</li> <li>1b = Inject a response packet with the response matching "Link Response" field when a request matching "Link Request" field is received</li> </ul> |
| 5:2   | RW         | <b>Link Request</b><br>The encodings match the State request encodings of FDI.                                                                                                                                                                                                                       |
| 9:6   | RW         | <b>Link Response</b><br>The encodings match the State response encodings of FDI.                                                                                                                                                                                                                     |
| 31:10 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                             |

#### 9.5.4.4.5 Link State Injection Control Stack 1 (Offset 38h from D2DOFF)

As mentioned in Section 11.2, this register only takes effect when the Adapter is in Adapter Compliance Mode.

**Table 9-76. Link State Injection Control Stack 1**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                          |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RW         | <b>Link State Request or Response Injection Enable at Tx</b> <ul style="list-style-type: none"> <li>0b = Link State Request or Response Injection not enabled at Tx</li> <li>1b = Link State Request or Response Injection enabled at Tx</li> </ul>                                                  |
| 1     | RW         | <b>Injection Type</b> <ul style="list-style-type: none"> <li>0b = Inject a request packet with the request matching "Link Request" field</li> <li>1b = Inject a response packet with the response matching "Link Response" field when a request matching "Link Request" field is received</li> </ul> |
| 5:2   | RW         | <b>Link Request</b><br>The encodings match the State request encodings of FDI.                                                                                                                                                                                                                       |
| 9:6   | RW         | <b>Link Response</b><br>The encodings match the State response encodings of FDI.                                                                                                                                                                                                                     |
| 31:10 | RsVdP      | Reserved                                                                                                                                                                                                                                                                                             |

#### 9.5.4.4.6 Retry Injection Control (Offset 40h from D2DOFF)

**Table 9-77. Retry Injection Control (Sheet 1 of 2)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RW         | <b>Retry Injection Enable</b><br>Setting this bit to 1b enables and starts error injections at Tx to force Retry on the UCIE Link.<br>Clearing this bit to 0b stops Flit injection on the Link.<br>Default is 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:1   | RW         | <b>Error Injection Type on Transmitted Flits</b> <ul style="list-style-type: none"> <li>000b = No errors injected on Transmitted Flits</li> <li>001b = 1-bit error injected in 'Byte Offset' of the Flit, it is permitted to invert any bit in the corresponding byte position</li> <li>010b = 2-bit error injected in 'Byte Offset' of the Flit, it is permitted to invert any two bits in the corresponding byte position</li> <li>011b = 3-bit error injected in 'Byte Offset' of the Flit, it is permitted to invert any three bits in the corresponding byte position</li> <li>All other encodings are reserved</li> </ul> Default is 000b. |
| 11:4  | RW         | <b>Byte Offset</b><br>See 'Error Injection Type on Transmitted Flits'.<br>00h means error is injected on Byte 0, 01h means error is injected in Byte 1, and so on.<br>Default is 00h.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19:12 | RW         | <b>Number of Flits between Injected Errors</b><br>A nonzero value indicates the exact number of Flits after which a subsequent error is injected. A value of 0 will inject errors after a pseudo-random number of Flits between 1 and 31, chosen from a 32b LFSR output.<br>Default is 00h.                                                                                                                                                                                                                                                                                                                                                      |

**Table 9-77. Retry Injection Control (Sheet 2 of 2)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:20 | RW         | <p><b>Number of Errors Injected</b><br/>           Represents the number of errors injected on the Transmitted Flits. A value of 0 indicates that the error injection continues until the Retry Injection Enable is disabled.<br/>           Default is 00h.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30:28 | RW         | <p><b>Flit Type for Error Injection</b></p> <ul style="list-style-type: none"> <li>• 000b = Inject errors on any Flit type.</li> <li>• 001b = Only inject errors on NOP Flits.</li> <li>• 010b = Only inject errors on Payload Flits (Protocol Flits or Test Flits).</li> <li>• 011b = Only inject errors on Test Flits.</li> <li>• 100b = Only inject errors on Payload Flits. Subsequent errors injected on the same sequence number ('Number of Flits between Injected Errors' is ignored for this case).</li> </ul> <p><b>Note:</b> The 100b value can be used to test Replay number Rollover rules.</p> <ul style="list-style-type: none"> <li>• All other encodings are reserved</li> </ul> <p>Default value is 000b.</p> |
| 31    | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 35:32 | RW         | <p><b>Tx Retry Error Threshold</b><br/>           If the number of independent retry events exceeds this threshold, Adapter must log this in 'Number of Retries Exceeded Threshold' and trigger Retrain on RDI. RDI state status going to Retrain also clears the internal count of independent retry events.<br/>           Default value is 0h.</p>                                                                                                                                                                                                                                                                                                                                                                           |
| 63:36 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 9.5.4.5 PHY Test/Compliance Register Block

Certain register bits described in this section take effect only when the PHY enters "PHY Compliance" mode. This mode is entered when bit 0 of 'Physical Layer Compliance Control 1' register is written and PHY subsequently enters PHYRETRAIN state. The latter happens when SW retrains the link. These register bits are tagged with @PHY-Compliance for easy readability and intuitive understanding.

Transition to TRAINERROR @PHY-Compliance does not reset any registers.

SW is required to place the Adapter in one of the Compliance modes (defined in the Adapter Compliance Control register) before enabling @PHY-Compliance.

All modules of a Link must be in @PHY-Compliance at the same time. The Link behavior is undefined if a subset of modules of a Link are in @PHY-Compliance and others are not. All registers in this section are replicated, one per module, as follows:

- Module 0 registers start at Offset 000h from PHYOFF
- Module 1 registers start at Offset 400h from PHYOFF
- Module 2 registers start at Offset 800h from PHYOFF
- Module 3 registers start at Offset C00h from PHYOFF

If certain modules are not implemented, those registers become reserved (as shown with gray boxes in Figure 9-6).

#### 9.5.4.5.1 Physical Layer Compliance Control 1 (Offsets 000h, 400h, 800h, and C00h from PHYOFF)

**Table 9-78. Physical Layer Compliance Control 1 (Sheet 1 of 2)**

| Bit | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW         | <b>Compliance Enable for Physical Layer</b><br>Setting this bit to 1b puts the Physical Layer in "PHY Compliance" on the next entry into PHYRETRAIN state. Even if RDI status moves to Active, it does not assert <b>p1_trdy</b> to the Adapter in this mode.<br>Default is 0b.                                                                                                                                                                                                |
| 1   | RW         | <b>Scrambling Disabled</b><br>@PHY-Compliance, when set to 1b, Physical Layer disables scrambling.<br>Default is 0b.                                                                                                                                                                                                                                                                                                                                                           |
| 2   | RW         | <b>PHY Compliance Operation Trigger</b><br>@PHY-Compliance, transitioning this bit from 0b-to-1b starts one iteration of the Link training basic operations set by 'PHY Compliance Operation Type'.<br>'PHY Compliance Operation Type' field identifies which of the Link training basic operations is performed. 'Training Setup 1', 'Training Setup 2', 'Training Setup 3', and 'Training Setup 4' registers determine the parameters to be used for this.<br>Default is 0b. |

**Table 9-78. Physical Layer Compliance Control 1 (Sheet 2 of 2)**

| Bit   | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:3   | RW         | <p><b>PHY Compliance Operation Type</b><br/>           @PHY-Compliance, where the Link training basic operation (see <a href="#">Section 4.5.1</a>) is performed when 'PHY Compliance Operation Trigger' transitions from 0b to 1b</p> <ul style="list-style-type: none"> <li>• 000b = No operation</li> <li>• 001b = Transmitter initiated Data-to-Clock point test (see <a href="#">Section 4.5.1.1</a>)</li> <li>• 010b = Transmitter initiated Data-to-Clock eye width sweep (see <a href="#">Section 4.5.1.2</a>)</li> <li>• 011b = Receiver initiated Data-to-Clock point training (see <a href="#">Section 4.5.1.3</a>)</li> <li>• 100b = Receiver initiated Data-to-Clock width sweep training (see <a href="#">Section 4.5.1.4</a>)</li> <li>• All other encodings are reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                    |
| 7:6   | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9:8   | RW         | <p><b>Rx Vref Offset Enable</b><br/>           @PHY-Compliance:</p> <ul style="list-style-type: none"> <li>• 00b = No change to trained Rx Vref value</li> <li>• 01b = Add Rx Vref offset to trained Rx Vref value (up to maximum permitted Vref value)</li> <li>• 10b = Subtract Rx Vref offset to trained Rx Vref value (down to minimum permitted Rx Vref, any negative value to be terminated at 0)</li> <li>• 11b = Reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17:10 | RW         | <p><b>Rx Vref Offset</b><br/>           @PHY-Compliance, when 'Rx Vref Offset Enable' is set to 01b or 10b, this is the value that needs to be added or subtracted as defined in 'Rx Vref Offset Enable'.<br/>           The Rx Vref value, after applying the Rx Vref offset, is expected to be monotonically increasing/decreasing with increasing/decreasing values of Rx Vref offset relative to the trained value and must have sufficient range to cover the input eye mask range defined in <a href="#">Chapter 5.0</a>.<br/>           Rx Vref Offset will be applied during Tx or Rx Data to Point Training and the Physical Layer must compare the per Lane errors with 'Max error Threshold in per-Lane comparison', and aggregate Lane errors with 'Max Error Threshold in Aggregate Comparison' in the 'Training Setup 4' register. If the errors measured are greater than the corresponding threshold, then the device must set the Rx Vref offset status register to "failed".<br/>           Software must increase or decrease the Rx Vref Offset by one from the previous value.<br/>           Default is 00h.</p> |
| 63:18 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 9.5.4.5.2 Physical Layer Compliance Control 2 (Offsets 008h, 408h, 808h, and C08h from PHYOFF)

**Table 9-79. Physical Layer Compliance Control 2**

| Bit  | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | RW         | <p><b>Even UI Compare Mask</b><br/>           @PHY-Compliance, if this bit is set, any compare results for even UIs are masked (i.e., not counted toward error in per Lane or aggregate comparison (see <a href="#">Section 4.4</a>)), where Even UI refers as to a Unit Interval data eye, the first data UI and every subsequent alternate UI.</p> <ul style="list-style-type: none"> <li>• 0b = No even UI compare result masking</li> <li>• 1b = Even UI compare result masked</li> </ul> Default is 0b.    |
| 1    | RW         | <p><b>Odd UI Compare Mask</b><br/>           @PHY-Compliance, if this bit is set, any compare results for odd UIs are masked (i.e., not counted toward error in per Lane or aggregate comparison (see <a href="#">Section 4.4</a>)), where Odd UI refers as to a Unit Interval data eye, the second data UI and every subsequent alternate UI).</p> <ul style="list-style-type: none"> <li>• 0b = No odd UI compare result masking</li> <li>• 1b = Odd UI compare results masked</li> </ul> Default is 0b.      |
| 2    | RW         | <p><b>Track Enable</b><br/>           If @PHY-Compliance {<br/>           If this bit is set, Track Transmission is enabled during one of the operations set by 'PHY compliance operation type'. Track transmission complies with descriptions in <a href="#">Section 5.5.1</a>.<br/>           }<br/>           Else {<br/>           The appropriate sideband handshakes as described in <a href="#">Section 4.6</a> needs to be followed irrespective of the value of this bit<br/>           }         </p> |
| 3    | RW         | <p><b>Compare Setup</b></p> <ul style="list-style-type: none"> <li>• 0b = Aggregate comparison</li> <li>• 1b = Per Lane comparison</li> </ul> Default is 0b. See <a href="#">Section 4.4</a> for more details.                                                                                                                                                                                                                                                                                                  |
| 31:4 | RsvdP      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 9.5.4.5.3 Physical Layer Compliance Status 1 (Offsets 010h, 410h, 810h, and C10h from PHYOFF)

**Table 9-80. Physical Layer Compliance Status 1**

| Bit  | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | RO         | <b>PHY in Compliance mode</b><br>If (@PHY-Compliance) 1b.<br>Else 0b.                                                                                                                                                                                                                                                                                                                                                              |
| 1    | RO         | <b>PHY Compliance operation status</b><br>If (@PHY-Compliance) {<br>This bit is set to 1b if 'PHY compliance operation type' in 'Physical Layer Compliance Control 1' register is 001b, 010b, 011b, or 100b and hardware has performed the required operation.<br>Else the bit is cleared to 0b.<br>}                                                                                                                              |
| 3:2  | RW1C       | <b>Rx Vref Offset Operation Status</b><br>@PHY-Compliance: <ul style="list-style-type: none"> <li>• 00b = Device does not support applying any Rx Vref Offset value</li> <li>• 01b = 'Rx Vref Offset' has not been applied</li> <li>• 10b = Rx Vref Offset has been successfully applied</li> <li>• 11b = Did not apply 'Rx Vref Offset' as the resulting value exceeds the value supported by hardware</li> </ul> Default is 00b. |
| 31:4 | RsvdZ      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 9.5.4.5.4 Physical Layer Compliance Status 2 (Offsets 018h, 418h, 818h, and C18h from PHYOFF)

**Table 9-81. Physical Layer Compliance Status 2**

| Bit   | Attributes | Description                                                                                                                                                                                                     |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | RW1C       | <b>Aggregate Error Count</b><br>@PHY-Compliance, this is the Error count of aggregate error comparison when 'PHY Compliance Operation Type' is 001b or 011b (performing point tests).<br>Default is 0000 0000h. |
| 39:32 | RO         | <b>Supported Rx Vref Range Up</b><br>Max step count supported up from the trained Rx Vref value for Vref margining.                                                                                             |
| 47:40 | RO         | <b>Supported Rx Vref Range Down</b><br>Max step count supported down from the trained Rx Vref value for Vref margining.                                                                                         |
| 55:48 | RO         | <b>Trained Value for Rx Vref</b><br>Rx Vref as trained, in resolution counts.                                                                                                                                   |
| 63:56 | RO         | <b>Vref Step Count Resolution</b><br>Increase in Vref value in mV between two consecutive encodings in ascending order.                                                                                         |

### 9.5.4.5.5 Physical Layer Compliance Status 3 (Offsets 020h, 420h, 820h, and C20h from PHYOFF)

**Table 9-82. Physical Layer Compliance Status 3**

| Bit  | Attributes | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63:0 | RO         | <p><b>Per Lane Comparison Result</b><br/>           Per Lane comparison result in PHY Compliance when 'PHY Compliance Operation Type' is 001b or 011b (performing point tests) and 'Comparison Setup' is 1b (Per Lane comparison)</p> <p>[63:0]: Compare Results of all Logical Data Lanes (0h Fail (Errors &gt; Max Error Threshold), 1h Pass (Errors &lt;= Max Error Threshold))</p> <p>UCIE-A {RD_L[63], RD_L[62], ..., RD_L[1], RD_L[0]}</p> <p>UCIE-A x32 {32'h0, RD_L[31], RD_L[30], ..., RD_L[1], RD_L[0]}</p> <p>UCIE-S {48'h0, RD_L[15], RD_L[14], ..., RD_L[1], RD_L[0]}</p> <p>Default is all 0s.</p> |

## 9.5.5 Implementation Specific Register Blocks

These are left to be vendor defined. There is a separate implementation specific register Block for D2D Adapter and PHY. These register blocks should carry the same header as defined in [Table 9-26](#), at offset 0h of the register block. And the VendorID should be set to the specific vendor's ID and the 'VendorID register block' field set to 2h or 3h to indicate that it is a vendor specific register block. The other fields in that header are set by the vendor to track their revision number and the block length. Max length cannot exceed 1MB in size and length is always in multiples of 4KB. Implementations are highly encouraged to pack registers and reduce length of the region as much as possible.

## 9.6

## UCIE Link Registers in Streaming Mode and System SW/FW Implications

### IMPLEMENTATION NOTE

While the SW view of Protocol Layer for streaming protocols is implementation-specific, it is strongly recommended that UCIE link-related registers defined in this chapter be implemented as-is for streaming mode solutions as well. If a streaming mode solution chooses to support the industry-standard PCIe hierarchical tree model for enumeration/control, it must be compliant with the enumeration model and registers defined in this chapter. A UCIE port in such an implementation would expose UCIE link registers consistent with the RP/DSP or EP/USP functionality it represents.

In some streaming mode solutions, it might be desirable to implement UCIE link as a fully symmetric link, such as in a Symmetric Multi-Processing system that uses UCIE as a D2D interconnect. In such solutions, there is no notion of Upstream Port or Downstream Port on a UCIE link and also typically system firmware knows the D2D link connections a priori and it is able to configure them without requiring any "link discovery" mechanisms. It is recommended that both ends of the link implement UCIE registers defined for a Root Port, in such streaming mode solutions. Note that in this model, several link-related features become fully symmetric as well. For example, link training, mailbox trigger, and direct link-event/error reporting to Software are now possible from either end of the link. Whether such symmetric UCIE links are exposed to OS for native management, or system FW fully manages these links, is a system-architecture choice. Exposing such links natively to the OS could be in the form of exposing each side as an ACPI device or in the form of an FW intermediary that emulates a traditional PCIe hierarchical tree model for the symmetric link. Such choices are implementation-specific and could depend on the extent of OS support for symmetric topology.

## 9.7 MSI and MSI-X Capability in Hosts/Switches for UCIe Interrupt

Follow the base spec for details, but MSI/MSI-X capability implemented in host and switch must request 2 vectors for UCIe usage - 1 for Link status events and 1 for Link error events. Note that in MSI scenario, OS might not always allot both the requested vectors and in that case both the Link Status and Link error events use the same MSI vector number. The MSI designs must also support the Pending and Mask bits. MSI capability in UiRB must always set the 'Next Capability Pointer' field to 0h. SW must check for a value of 0005h in Bytes 0 and 1 of a capability to infer that it is an MSI capability. SW must terminate the capability linked list in UiRB when it sees the MSI Capability.

## 9.8 UCIe Early Discovery Table (UEDT)

**Table 9-83. UEDT Header**

| Field             | Byte Offset | Length in Bytes | Description                                                                                                                                                                        |
|-------------------|-------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signature         | 00h         | 4               | Signature for the UCIe Early Discovery Table (UEDT).                                                                                                                               |
| Length            | 04h         | 4               | Length, in bytes, of the entire UEDT.                                                                                                                                              |
| Revision          | 08h         | 1               | Value is 1h for the first UCIe instance.                                                                                                                                           |
| Checksum          | 09h         | 1               | Entire table must sum to 0.                                                                                                                                                        |
| OEM ID            | 0Ah         | 6               | OEM ID                                                                                                                                                                             |
| OEM Table ID      | 10h         | 8               | Manufacturer Model ID                                                                                                                                                              |
| OEM Revision      | 18h         | 4               | OEM Revision                                                                                                                                                                       |
| Creator ID        | 1Ch         | 4               | Vendor ID of the utility that created this table.                                                                                                                                  |
| Creator Revision  | 20h         | 4               | Revision of the utility that created this table.                                                                                                                                   |
| UEDT Structure[n] | 24h         | Varies          | A list of UEDT structures for this implementation. <ul style="list-style-type: none"> <li>• 0h = UCIe Link structure (UCLS)</li> <li>• All other encodings are reserved</li> </ul> |

**Table 9-84. UCIe Link Structure (UCLS) (Sheet 1 of 2)**

| Field           | Byte Offset | Length in Bytes | Description                                                                                                                                                                                     |
|-----------------|-------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Type            | 00h         | 1               | Signature for the UCIe Early Discovery Table (UEDT).                                                                                                                                            |
| Revision        | 01h         | 1               | Value is 1h for the first UCLS definition.                                                                                                                                                      |
| Record Length   | 02h         | 2               | Length of this record, in bytes.                                                                                                                                                                |
| UID             | 04h         | 4               | Host Bridge Unique ID. Used to associate a UCLS instance with a Host Bridge instance. The value of this field shall match the output of UID under the associated Host Bridge in ACPI namespace. |
| UCIe Stack Size | 08h         | 4               | <ul style="list-style-type: none"> <li>• 1h = One RP</li> <li>• 2h = Two RPs</li> </ul>                                                                                                         |
| Reserved        | 0Ch         | 4               | Reserved                                                                                                                                                                                        |
| Base            | 10h         | 8               | Base address of UiRB, aligned to a 4-KB boundary.                                                                                                                                               |

**Table 9-84. UCIe Link Structure (UCLS) (Sheet 2 of 2)**

| Field  | Byte Offset | Length in Bytes | Description                                                                                    |
|--------|-------------|-----------------|------------------------------------------------------------------------------------------------|
| Length | 18h         | 8               | Can range anywhere from 12 KB to 2 MB, in multiples of 4 KB.                                   |
| DF1    | 20h         | 1               | Device Function of the PCIe/CXL RP 1 associated with the UCLS.                                 |
| DF2    | 21h         | 1               | Device Function of the PCIe/CXL RP 2 (if multi-stack implementation) associated with the UCLS. |

§ §

## 10.0 Interface Definitions

---

This chapter will cover the details of interface operation and signal definitions for the Raw Die-to-Die Interface (RDI), as well as the Flit-Aware Die-to-Die Interface (FDI). Common rules across RDI and FDI are covered as a separate section. The convention used in this chapter is that “assertion” of a signal is for 0b to 1b transition, and “de-assertion” of a signal is for 1b to 0b transition. A “pulse” of “n” cycles for a signal is defined as an event where the signal transitions from 0b to 1b, stays 1b for “n” clock cycles, and subsequently returns to 0b. A receiver sampling this signal on the same clock as the transmitter will see it being asserted for “n” clock cycles. If a value of “n” is not specified, it is interpreted as a value of one. In the context of error signals defined as pulses, the receiving logic for error logging must treat the rising edge as a new event indication and not rely on the length of the pulse.

In this chapter, interface reset/domain reset also applies to all forms of Conventional Reset defined in *PCIe Base Specification*, if the Protocol is PCIe or CXL. In the sections that follow, “UCIE Flit mode” refers to scenarios in which the Link is not operating in Raw Format, and “UCIE Raw Format” or “Raw Format” refers to scenarios in which the Link is operating in Raw Format.

### 10.1 Raw Die-to-Die Interface (RDI)

This section defines the signal descriptions and functionality associated with a single instance of Raw Die-to-Die Interface (RDI). A single instance could be used for a configuration associated with a single Die-to-Die module (i.e., one Die-to-Die Adapter for one module), or a single instance is also applicable for configurations where multiple modules are grouped together for a single logical Die-to-Die Link (i.e., one Die-to-Die Adapter for multiple modules). [Figure 10-1](#) shows example configurations using RDI.

**Figure 10-1. Example configurations using RDI**

Table 10-1 lists the RDI signals and their descriptions. All signals are synchronous with **lclk**.

In Table 10-1:

- **pl\_\*** indicates that the signal is driven away from the Physical Layer to the Die-to-Die Adapter.
- **lp\_\*** indicates that the signal is driven away from the Die-to-Die Adapter to the Physical Layer.

**Table 10-1. RDI signal list (Sheet 1 of 5)**

| Signal Name                     | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>lclk</b>                     | The clock at which RDI operates.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>lp_irdy</b>                  | Adapter to Physical Layer signal indication that the Adapter has data to send. This must be asserted if <b>lp_valid</b> is asserted and the Adapter wants the Physical Layer to sample the data.<br><br><b>lp_irdy</b> must not be presented by the Adapter when <b>pl_state_sts</b> is Reset except when the status transitions from LinkError to Reset. On a LinkError to Reset transition, it is permitted for <b>lp_irdy</b> to be asserted for a few clocks but it must be de-asserted eventually. Physical Layer must ignore <b>lp_irdy</b> when status is Reset. |
| <b>lp_valid</b>                 | Adapter to Physical Layer indication that data is valid on the corresponding <b>lp_data</b> bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>lp_data[NBYTES-1:0][7:0]</b> | Adapter to Physical Layer data, where 'NBYTES' equals number of bytes determined by the data width for the RDI instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>lp_retimer_crd</b>           | When asserted at a rising clock edge, it indicates a single credit return from the Adapter to the Physical Layer for the Retimer Receiver buffers. Each credit corresponds to 256B of mainband data. This signal must NOT assert for dies that are not UCIE Retimers.                                                                                                                                                                                                                                                                                                   |
| <b>pl_trdy</b>                  | The Physical Layer is ready to accept data. Data is accepted by the Physical Layer when <b>pl_trdy</b> , <b>lp_valid</b> , and <b>lp_irdy</b> are asserted at the rising edge of <b>lclk</b> .<br><br>This signal must only be asserted if <b>pl_state_sts</b> is Active or when performing the <b>pl_stallreq/lp_stallack</b> handshake when the <b>pl_state_sts</b> is LinkError (see Section 10.3.3.7).                                                                                                                                                              |

**Table 10-1. RDI signal list (Sheet 2 of 5)**

| Signal Name                     | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_valid</b>                 | Physical Layer to Adapter indication that data is valid on <b>pl_data</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>pl_data[NBYTES-1:0][7:0]</b> | Physical Layer to Adapter data, where NBYTES equals the number of bytes determined by the data width for the RDI instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>pl_retimer_crd</b>           | When asserted at a rising clock edge, it indicates a single credit return from the Retimer to the Adapter. Each credit corresponds to 256B of mainband data. This signal must NOT assert if the remote Link partner is not a Retimer.                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>lp_state_req[3:0]</b>        | Adapter request to Physical Layer to request state change.<br>Encodings as follows:<br>0000b: NOP<br>0001b: Active<br>0100b: L1<br>1000b: L2<br>1001b: LinkReset<br>1011b: Retrain<br>1100b: Disabled<br>All other encodings are reserved.                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>lp_linkerror</b>             | Adapter to Physical Layer indication that an error has occurred which requires the Link to go down. Physical Layer must move to LinkError state and stay there as long as <b>lp_linkerror=1</b> . The reason for having this be an indication decoupled from regular state transitions is to allow immediate action on part of the Adapter and Physical Layer in order to provide the quickest path for error containment when applicable (for example, a viral error escalation must map to the LinkError state).<br>The Adapter must OR internal error conditions with <b>lp_linkerror</b> received from Protocol Layer on FDI. |
| <b>pl_state_sts[3:0]</b>        | Physical Layer to Adapter Status indication of the Interface.<br>Encodings as follows:<br>0000b: Reset<br>0001b: Active<br>0011b: Active.PMNAK<br>0100b: L1<br>1000b: L2<br>1001b: LinkReset<br>1010b: LinkError<br>1011b: Retrain<br>1100b: Disabled<br>All other encodings are reserved.<br>The status signal is permitted to transition from Physical Layer autonomously when applicable. For example the Physical Layer asserts the Retrain status when it decides to enter retraining either autonomously or when requested by remote agent.                                                                                 |
| <b>pl_inband_pres</b>           | Physical Layer to the Adapter indication that the Die-to-Die Link has finished training and is ready for RDI transition to Active and Stage 3 of bring up.<br>Once it transitions to 1b, this must stay 1b until Physical Layer determines the Link is down (i.e., the Link Training State Machine transitions to TrainError or Reset).                                                                                                                                                                                                                                                                                           |

**Table 10-1. RDI signal list (Sheet 3 of 5)**

| Signal Name          | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_error</b>      | <p>Physical Layer to the Adapter indication that it has detected a framing related error which is recoverable through Link Retrain. An example is where the Physical Layer received an invalid encoding on the Valid Lane. It is a pulse of one or more cycles that must occur only when RDI is in Active state. It is permitted to de-assert at the same clock edge where the state transitions away from Active state.</p> <p>It is pipelined with the receive data path such that the error indication reaches the Adapter before or at the same time as the corrupted data. Physical Layer is expected to go through Retrain flow after this signal has been asserted and it must not send valid data to Adapter until the Link has retrained.</p> <p>It is permitted for the Physical Layer to squash the <b>pl_valid</b> internally for the corrupted data. Once <b>pl_error</b> is asserted, <b>pl_valid</b> should not be asserted (without <b>pl_error</b> assertion in the same cycle) until the state status has transitioned to Active after completing a successful Retrain entry and exit.</p> <p>If <b>pl_error=1</b> and <b>pl_valid=1</b> in the same clock cycle, the Adapter must discard the corresponding Flit (even if it is only partially received when <b>pl_error</b> asserted). In UCIE Flit mode, when retry is enabled, it is the responsibility of the Adapter to ensure data integrity for Flits forwarded to FDI, and that they are canceled following the rules of <b>pl_filit_cancel</b> if they are suspected of corruption (see <a href="#">Section 10.2</a>). A couple of examples are given below:</p> <ul style="list-style-type: none"> <li>• For 68B Flit Format, the Adapter could discard partially received Flits, but in 256B Latency optimized modes, it could have processed one half correctly, and the error may have happened on the other half, and so it has to track that and process future flits accordingly.</li> <li>• Another example is if it is not doing store/forward and only received 64B of a 128B half, and <b>pl_error</b> happened before receiving the remaining 64B of the 128B half, it needs to send dummy data for the second 64B and do a <b>pl_filit_cancel</b> for that half of the Flit.</li> </ul> <p>In UCIE Flit mode with Retry enabled for the Adapter, Retrain exit would naturally result in a Replay of any partially received Flits eventually (see <a href="#">Section 3.8</a>).</p> <p>In UCIE Flit mode with Retry disabled, the Adapter must map <b>pl_error</b> assertion to an Uncorrectable Internal Error and escalate it accordingly.</p> <p>If the Link is operating in Raw Format, the Adapter forwards <b>pl_error</b> to the Protocol Layer such that it is pipeline matched to the data bus, and Protocol Layer handles it in an implementation-specific manner.</p> |
| <b>pl_cerror</b>     | <p>Physical Layer to the Adapter indication that a correctable error was detected that does not affect the data path and will not cause Retrain on the Link. In UCIE Flit mode with Retry enabled, the Adapter must OR the <b>pl_error</b> and <b>pl_cerror</b> signals for Correctable Internal Error Logging.</p> <p>In UCIE Flit mode with Retry disabled or when the Link is operating in Raw Format, the Adapter must only use <b>pl_cerror</b> for Correctable Internal Error Logging.</p> <p>It is a pulse of one or more cycles which can occur in any RDI state. If it is a state in which clock gating is permitted, it is the responsibility of the Physical Layer to perform the clock gating exit handshake with the Adapter before asserting this signal. Clock gating can resume once <b>pl_cerror</b> de-asserts and all other conditions permitting clock gating are satisfied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>pl_nferror</b>    | <p>Physical Layer to the Adapter indication that a non-fatal error was detected. There is no architecturally defined error condition for the Physical Layer currently asserting this signal; however, the signal is provided on the interface for any implementation-specific non-fatal errors. The Adapter treats this in the same manner as when it received a Sideband Non-Fatal Error Message from the remote Link partner.</p> <p>It is a pulse of one or more cycles that can occur in any RDI state. If it is a state where clock gating is permitted, it is the responsibility of the Physical Layer to perform the clock gating exit handshake with the Adapter before asserting this signal. Clock gating can resume after <b>pl_nferror</b> is de-asserted and all other conditions permitting clock gating have been met.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>pl_trainerror</b> | <p>Indicates a fatal error from the Physical Layer. Physical Layer must transition <b>pl_state_sts</b> to LinkError if not already in LinkError state.</p> <p>This must be escalated to upper Protocol Layers based on the mask and severity programming of Uncorrectable Internal Error in the Adapter. Implementations are permitted to map any fatal error to this signal that require upper layer escalation (or interrupt generation) depending on system-level requirements.</p> <p>It is a level signal that can assert in any RDI state but remains asserted until RDI exits the LinkError state to Reset state.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 10-1. RDI signal list (Sheet 4 of 5)**

| Signal Name              | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_physinrecenter</b> | Physical Layer indication to Adapter that the Physical Layer is training or retraining. If this is asserted during a state where clock gating is permitted, the <b>pl_clk_req</b> / <b>lp_clk_ack</b> handshake must be performed with the upper layer. The upper layers are permitted to use this to update the "Link Training/Retraining" bit in the PCIe Link Status register.                                                                                                                                                                                                                                                                               |
| <b>pl_stallreq</b>       | Physical Layer request to Adapter to align Transmitter at Flit boundary and not send any new Flits to prepare for state transition. See <a href="#">Section 10.3.2</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>lp_stallack</b>       | Adapter to Physical Layer indication that the Flits are aligned and stalled (if <b>pl_stallreq</b> was asserted). It is strongly recommended that this response logic be on a global free running clock, so the Adapter can respond to <b>pl_stallreq</b> with <b>lp_stallack</b> even if other significant portions of the Adapter are clock gated. See <a href="#">Section 10.3.2</a> .                                                                                                                                                                                                                                                                       |
| <b>pl_speedmode[2:0]</b> | Current Link speed. The following encodings are used:<br>000b: 4GT/s<br>001b: 8GT/s<br>010b: 12GT/s<br>011b: 16GT/s<br>100b: 24GT/s<br>101b: 32GT/s<br>other encodings are reserved.<br>The Adapter must only consider this signal to be relevant when the RDI state is Active or Retrain. For multi-module configurations, all modules must operate at the same speed.                                                                                                                                                                                                                                                                                         |
| <b>pl_lnk_cfg[2:0]</b>   | Current Link Configuration. Indicates the current operating width of a module.<br>000b: x4<br>001b: x8<br>010b: x16<br>011b: x32<br>100b: x64<br>101b: x128<br>110b: x256<br>other encodings are reserved.<br>This is the width of the PCIe physical die-to-die Link which may be composed of one to four modules. For PCIe-S the maximum encoding would be x64, for PCIe-A the maximum encoding would be x128 for PCIe-A x32 and x256 for PCIe-A x64.<br>The Adapter must only consider this signal to be relevant when the RDI state is Active or Retrain. This signal indicates the total width across all Active Modules corresponding to the RDI instance. |
| <b>pl_clk_req</b>        | Request from the Physical Layer to remove clock gating from the internal logic of the Adapter. This is an asynchronous signal relative to <b>lclk</b> from the Adapter's perspective since it is not tied to <b>lclk</b> being available in the Adapter. Together with <b>lp_clk_ack</b> , it forms a four-way handshake to enable dynamic clock gating in the Adapter.<br>When dynamic clock gating is supported, the Adapter must use this signal to exit clock gating before responding with <b>lp_clk_ack</b> .<br>If dynamic clock gating is not supported, it is permitted for the Physical Layer to tie this signal to 1b.                               |
| <b>lp_clk_ack</b>        | Response from the Adapter to the Physical Layer acknowledging that its clocks have been un gated in response to <b>pl_clk_req</b> . This signal is only asserted when <b>pl_clk_req</b> is asserted, and de-asserted after <b>pl_clk_req</b> has de-asserted.<br>When dynamic clock gating is not supported by the Adapter, it must stage <b>pl_clk_req</b> internally for one or more clock cycles and turn it around as <b>lp_clk_ack</b> . This way it will still participate in the handshake even though it does not support dynamic clock gating.                                                                                                         |

**Table 10-1. RDI signal list (Sheet 5 of 5)**

| Signal Name                 | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>lp_wake_req</code>    | <p>Request from the Adapter to remove clock gating from the internal logic of the Physical Layer. This is an asynchronous signal from the Physical Layer's perspective since it is not tied to <code>lclk</code> being available in the Physical Layer. Together with <code>pl_wake_ack</code>, it forms a four-way handshake to enable dynamic clock gating in the Physical Layer.</p> <p>When dynamic clock gating is supported, the Physical Layer must use this signal to exit clock gating before responding with <code>pl_wake_ack</code>.</p> <p>If dynamic clock gating is not supported, it is permitted for the Adapter to tie this signal to 1b.</p>                                                                                                                                                                                                                                                                                                                           |
| <code>pl_wake_ack</code>    | <p>Response from the Physical Layer to the Adapter acknowledging that its clocks have been un gated in response to <code>lp_wake_req</code>. This signal is only asserted after <code>lp_wake_req</code> has asserted, and is de-asserted after <code>lp_wake_req</code> has de-asserted.</p> <p>When dynamic clock gating is not supported by the Physical Layer, it must stage <code>lp_wake_req</code> internally for one or more clock cycles and turn it around as <code>pl_wake_ack</code>. This way it will still participate in the handshake even though it does not support dynamic clock gating.</p>                                                                                                                                                                                                                                                                                                                                                                           |
| <code>pl_cfg[NC-1:0]</code> | <p>This is the sideband interface from the Physical Layer to the Adapter. See <a href="#">Chapter 7.0</a> for packet format details. NC is the width of the interface. Supported values are 8, 16, and 32.</p> <p>Register accesses must be implemented by hardware to be atomic regardless of the width of the interface (i.e., all 32 bits of a register must be updated in the same cycle for a 32-bit register write, and similarly all 64 bits of a register must be updated in the same cycle for a 64-bit register write).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <code>pl_cfg_vld</code>     | When asserted, indicates that <code>pl_cfg</code> has valid information that should be consumed by the Adapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <code>pl_cfg_crd</code>     | <p>Credit return for sideband packets from the Physical Layer to the Adapter for sideband packets. Each credit corresponds to 64 bits of header and 64 bits of data. Even transactions that do not carry data or carry 32 bits of data consume the same credit and the Physical Layer returns the credit once the corresponding transaction has been processed or deallocated from its internal buffers. See <a href="#">Section 7.1.3.1</a> for additional flow control rules. A value of 1 sampled at a rising clock edge indicates a single credit return.</p> <p>Because the advertised credits are design parameters, the Adapter transmitter updates the credit counters with initial credits on domain reset exit, and no initialization credits are returned over the interface.</p> <p>Credit returns must follow the same rules of clock gating exit handshakes as the sideband packets to ensure that no credit returns are dropped by the receiver of the credit returns.</p> |
| <code>lp_cfg[NC-1:0]</code> | <p>This is the sideband interface from Adapter to the Physical Layer. See <a href="#">Chapter 7.0</a> for details. NC is the width of the interface. Supported values are 8, 16, and 32.</p> <p>Register accesses must be implemented by hardware to be atomic regardless of the width of the interface (i.e., all 32 bits of a register must be updated in the same cycle for a 32-bit register write, and similarly all 64 bits of a register must be updated in the same cycle for a 64-bit register write).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <code>lp_cfg_vld</code>     | When asserted, indicates that <code>lp_cfg</code> has valid information that should be consumed by the Physical Layer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <code>lp_cfg_crd</code>     | <p>Credit return for sideband packets from the Adapter to the Physical Layer for sideband packets. Each credit corresponds to 64 bits of header and 64 bits of data. Even transactions that do not carry data or carry 32 bits of data consume the same credit and the Adapter returns the credit once the corresponding transaction has been processed or deallocated from its internal buffers. See <a href="#">Section 7.1.3.1</a> for additional flow control rules. A value of 1 sampled at a rising clock edge indicates a single credit return.</p> <p>Because the advertised credits are design parameters, the Physical Layer transmitter updates the credit counters with initial credits on domain reset exit, and no initialization credits are returned over the interface.</p> <p>Credit returns must follow the same rules of clock gating exit handshakes as the sideband packets to ensure that no credit returns are dropped by the receiver of the credit returns.</p> |

Signals in Table 10-2 apply only when supporting MPM over sideband. The choice for whether these signals run on the **lclk** or the **Mgmt\_Clk** is implementation-specific.

**Table 10-2. RDI Config interface extensions for Management Transport (Sheet 1 of 3)**

| Signal Name                         | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pm_param_done</b>                | Management transport negotiation phase completed. Signal de-asserts after being asserted for two clocks.<br>This signal asserts when MBINIT.PARAM management transport negotiation phase completes. Note that this signal is asserted even if MBINIT.PARAM Configuration or SBFE exchanges indicate no support for management transport in the partner chiplet.                                                                                                                                                                                                                                                                                                            |
| <b>pm_param_local_count[N-1:0]</b>  | Number of modules that successfully negotiated Management transport on transmit side. This field is sampled only when <b>pm_param_done</b> signal is asserted.<br>000b: 0 modules<br>001b: 1 module<br>010b: 2 modules<br>011b: 3 modules<br>100b: 4 modules<br>Others: Reserved<br>N=2 for 1, 2, or 3 modules scenarios, and N=3 for 4 modules scenario.                                                                                                                                                                                                                                                                                                                  |
| <b>pm_param_remote_count[N-1:0]</b> | Number of modules that successfully negotiated Management transport on receive side. This field is sampled only when <b>pm_param_done</b> signal is asserted.<br>000b: 0 modules<br>001b: 1 module<br>010b: 2 modules<br>011b: 3 modules<br>100b: 4 modules<br>Others: Reserved<br>N=2 for 1, 2, or 3 modules scenarios, and N=3 for 4 modules scenario.                                                                                                                                                                                                                                                                                                                   |
| <b>mp_mgmt_init_done</b>            | Indication from Management Port Gateway that initialization phase completed (successfully or unsuccessfully). This signal is used by the PHY to advance the state machine state beyond MBINIT.PARAM, if other conditions allow. Signal de-asserts after being asserted for two clocks. The PHY should not depend on this signal for advancing the state machine when the management path is already up or when the partner chiplet indicated no support for management transport.                                                                                                                                                                                          |
| <b>mp_mgmt_init_start</b>           | A two-clock trigger pulse from Management Port Gateway to PHY to start negotiation on the sideband links. Management Port Gateway must ensure that the <b>mp_mgmt_up</b> signal is de-asserted when this signal is pulsed. This signal forces the link state machine to RESET state (if it is not already there) and hence can bring the mainband link down from link up state. The standard TRAINERROR flow applies here as well for transitioning the state machine to RESET if the state machine is not already in that state when this signal is pulsed.                                                                                                               |
| <b>mp_mgmt_up</b>                   | Indication from Management Port Gateway that is signaled along with <b>mp_mgmt_init_done</b> , that Management Transport Initialization Phase completed successfully ( <b>mp_mgmt_up=1</b> ) or unsuccessfully ( <b>mp_mgmt_up=0</b> ). This is used by PHY to set the SB_MGMT_UP flag.                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>mp_mgmt_port_gateway_ready</b>   | Indication to PHY that Management Port Gateway is ready for management transport path initialization. The PHY uses this as one of the conditions to trigger or respond to a trigger for Management Transport path initialization.<br>This asserts after the Management Port Gateway is ready for management path setup after Management Reset. Once asserted, this signal de-asserts on a Management Port Gateway reset (either because of management domain reset or after a heartbeat timeout or an 'Init Done' Timeout or any fatal error on sideband) condition.                                                                                                       |
| <b>mp_stall_after_mbinit_param</b>  | Management Port Gateway asserts this signal concurrent with asserting <b>mp_mgmt_port_gateway_ready</b> to indicate to the PHY that it must stall the training on the receive side using an {MBINIT.PARAM SBFE resp} sideband message stall encoding as described in <a href="#">Section 4.5.3.3.1.2</a> . This signal remains asserted until the MPG determines that stalling is no longer necessary (i.e., that it is okay for link initialization to proceed). When de-asserted, the receive side training does not cause a "stall". When a sideband-only link is negotiated, this signal is not used by the PHY to determine the Link training state machine progress. |

**Table 10-2. RDI Config interface extensions for Management Transport (Sheet 2 of 3)**

| Signal Name                       | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>pm_cfg_credit[N-1:0]</code> | This is credit return for the Flow control buffers over RDI (see <a href="#">Section 8.2.5.1.1</a> ) used by the Management Port Gateway to transmit management packets to the remote Management Port Gateway.<br>Each credit corresponds to 64 bits of buffer space. Physical Layer returns the credit once the corresponding transaction has been deallocated from its internal buffers. See <a href="#">Section 8.2.5.1.1</a> for additional flow control rules. Because the advertised credits are design parameters, the Management Port Gateway transmitter updates the credit counters with initial credits on Management reset exit or on 'Heartbeat timeout', and no initialization credits are returned over the interface for these conditions. Credit returns must follow the same rules of clock gating exit handshakes as the sideband packets to ensure that no credit returns are dropped by the receiver of the credit returns.<br>There is a signal per RxQ-ID in the design and hence N can be 1, 2, 3, or 4. |
| <code>mp_rxqid[N-1:0]</code>      | RxQ-ID associated with the message. Has meaning when <code>mp_mgmt_pkt</code> signal is asserted on a RDI transfer. Used by PHY to steer the packet to the correct SB link. On encapsulated MTPs and PM Req messages, this carries the far-end Rx queue's RxQ-ID. On Credit return, Init Done and PM Ack messages this carries the RxQ-ID of the local Rx queue associated with the message.<br>N is either 2 (for 4 modules links scenarios) or 1 (1 or 2 modules links scenarios). There is a fixed mapping in the PHY between this value and a physical SB link and the mapping is determined post successful completion of management transport negotiation on the transmit side. The chosen SB link for a given RxQ-ID must be one of the SB links that successfully trained for management transport on the transmit side.                                                                                                                                                                                                 |
| <code>pm_rxqid[N-1:0]</code>      | RxQ-ID associated with the message. Has meaning when <code>pm_mgmt_pkt</code> signal is asserted on a RDI transfer. Used by Management Port Gateway to internally steer the packet to the correct RxQ.<br>N is either 2 (for 4 modules/sideband-only links scenarios) or 1 (1 or 2 modules/sideband-only links scenarios). Valid for all MPM config bus transmissions. PHY uses the RxQ-ID from the first credit return message received from a given sideband link to drive these signals on config interface. These signals are undefined for SoC Capabilities message. The captured RxQ-ID value is reset only when the management path is reinitialized.                                                                                                                                                                                                                                                                                                                                                                     |
| <code>mp_wake_req</code>          | Request from the Management Port Gateway to remove clock gating from the internal logic of the Physical Layer that handles management transport traffic. This is an asynchronous signal from the Physical Layer's perspective since it is not tied to lclk being available in the Physical Layer. Together with <code>pm_wake_ack</code> , it forms a four-way handshake to enable dynamic clock gating in the Physical Layer for logic that handles management transport traffic.<br>When dynamic clock gating is supported, the Physical Layer must use this signal to exit clock gating before responding with <code>pm_wake_ack</code> .<br>If dynamic clock gating is not supported, Management Port Gateway must tie this signal to 1.                                                                                                                                                                                                                                                                                     |
| <code>pm_wake_ack</code>          | Response from the Physical Layer to the Management Port Gateway acknowledging that its clocks have been un gated in response to <code>mp_wake_req</code> . This signal is only asserted after <code>mp_wake_req</code> has asserted, and is de-asserted after <code>mp_wake_req</code> has de-asserted.<br>When dynamic clock gating is not supported by the Physical Layer, it must stage <code>mp_wake_req</code> internally for one or more clock cycles and turn it around as <code>pm_wake_ack</code> . This way it will still participate in the handshake even though it does not support dynamic clock gating.                                                                                                                                                                                                                                                                                                                                                                                                           |
| <code>pm_clk_req</code>           | Request from the Physical Layer to remove clock gating from the internal logic of the Management Port Gateway. This is an asynchronous signal relative to <code>lclk/Mgmt_clk</code> from the Management Port Gateway perspective because it is not tied to <code>lclk/Mgmt_clk</code> being available in the Management Port Gateway.<br>Together with <code>mp_clk_ack</code> , it forms a four-way handshake to enable dynamic clock gating in the Management Port Gateway. When dynamic clock gating is supported, the Management Port Gateway must use this signal to exit clock gating before responding with <code>mp_clk_ack</code> . If dynamic clock gating is not supported, Physical Layer must tie this signal to 1.                                                                                                                                                                                                                                                                                                |

**Table 10-2. RDI Config interface extensions for Management Transport (Sheet 3 of 3)**

| Signal Name           | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>mp_clk_ack</b>     | Response from the Management Port Gateway to the PHY acknowledging that its clocks have been un gated in response to <b>pm_clk_req</b> . This signal is asserted only when <b>pm_clk_req</b> is asserted, and de-asserted after <b>pm_clk_req</b> has de-asserted. When dynamic clock gating is not supported by the Management Port Gateway, it must stage <b>pm_clk_req</b> internally for one or more clock cycles and turn it around as <b>mp_clk_ack</b> . This way it will still participate in the handshake even though it does not support dynamic clock gating.<br>When supporting dynamic clock gating of the Management Port Gateway, PHY must ensure that pulsed signals (e.g., <b>pm_param_done</b> ), are delivered only after the <b>mp_clk_ack</b> is set to ensure that the Management Port Gateway saw those pulses. |
| <b>mp_mgmt_pkt</b>    | During a valid RDI data transfer to PHY, this signal indicates whether the transfer is for an MPM.<br>0: Link management packet.<br>1: MPM. Used by PHY to steer the packet to the correct RDI credit buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>pm_mgmt_pkt</b>    | During a valid RDI data transfer from PHY, this signal indicates whether the transfer is for an MPM.<br>0: Link management packet.<br>1: MPM. Used by the Management Port Gateway to steer the packet to RxQ buffers or to D2D Adapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>pm_so</b>          | When asserted, indicates to Management Port Gateway that SO mode was negotiated. On ports that have sideband-only link physically present, this can be tied off to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Mgmt_clk</b>       | Optional clock used for the Configuration interface on the RDI for implementations in which the main RDI clock is not available for Management Transport path initialization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>pm_fatal_error</b> | Set by any sideband link fatal error indication, such as parity error on a sideband packet. Cleared by a Management Reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>mp_fatal_error</b> | Used by Management Port Gateway to instruct the PHY to transition to TRAINERROR state. This is a two-clock pulse.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 10.1.1 Interface reset requirements

RDI does not define a separate interface signal for reset; however, it is required that the logic entities on both sides of RDI are in the same reset domain and the reset for each side is derived from the same source. Because reset may be staggered due to SoC routing, all signals coming out of reset must be driven to 0, unless otherwise specified.

### 10.1.2 Interface clocking requirements

RDI requires both sides of the interface to be on the same clock domain. The clock domain for the sideband interface (**\*cfg\***) is the same as the mainband signals when Management Transport is not supported. When Management Transport is supported, the sideband interface is permitted to be on a separate **Mgmt\_clk** domain.

Each side is permitted to internally instantiate clock-crossing FIFOs if needed, as long as it does not violate the requirements at the interface itself.

It is important to note that back pressure is not possible from the Adapter to the Physical Layer on the main data path. So any clock-crossing-related logic internal to the Adapter must take this into consideration.

For example, for a 64-Lane module with a maximum speed of 16 GT/s, the RDI could be 64B wide running at 2 GHz to be exactly bandwidth matched.

### 10.1.3 Dynamic clock gating

Dynamic coarse clock gating is permitted in the Adapter and Physical Layer when `pl_state_sts` is Reset, LinkReset, Disabled, or PM. This section defines the rules around entry and exit of clock gating. Note that clock gating is not permitted in LinkError state; it is expected that for UCIe usages, error handlers will be enabled to make sure the Link is not stuck in LinkError state if the intent is save power for Links in error state.

#### 10.1.3.1 Rules and description for `lp_wake_req/pl_wake_ack` handshake

Adapter can request removal of clock gating of the Physical Layer by asserting `lp_wake_req` (asynchronous to `lclk` availability in the Physical Layer). All Physical Layer implementations must respond with a `pl_wake_ack` (synchronous to `lclk`). The extent of internal clock ungating when `pl_wake_ack` is asserted is implementation-specific, but `lclk` must be available by this time to enable RDI signal transitions from the Adapters. The Wake Req/Ack is a full handshake and it must be used for state transition requests (on `lp_state_req` or `lp_linkerror`) when moving away from a state in which clock gating is permitted. It must also be used for sending packets on the sideband interface.

Rules for this handshake:

1. Adapter asserts `lp_wake_req` to request ungating of clocks by the Physical Layer.
2. The Physical Layer asserts `pl_wake_ack` to indicate that clock gating has been removed. There must be at least one clock cycle bubble between `lp_wake_req` assertion and `pl_wake_ack` assertion.
3. `lp_wake_req` must de-assert before `pl_wake_ack` de-asserts. It is the responsibility of the Adapter to control the specific scenario of de-assertion. As an example, when performing the handshake for a state request, it is permitted to keep `lp_wake_req` asserted until it observes the desired state status. Adapter is also permitted to keep `lp_wake_req` asserted through states where clock gating is not permitted in the Physical Layer (i.e., Active, LinkError, or Retrain).
4. `lp_wake_req` should not be the only consideration for Physical Layer to perform clock gating, it must take into account `pl_state_sts` and other internal or Link requirements before performing global and/or local clock gating.
5. When performing `lp_wake_req/pl_wake_ack` handshake for `lp_state_req` transitions or `lp_linkerror` transition, the Adapter is permitted to not wait for `pl_wake_ack` before changing `lp_state_req` or `lp_linkerror`.
6. When performing `lp_wake_req/pl_wake_ack` handshake for `lp_cfg` transitions, Adapter must wait for `pl_wake_ack` before changing `lp_cfg` or `lp_cfg_vld`. Because `lp_cfg` can have multiple transitions for a single packet transfer, it is necessary to make sure that the Physical Layer clocks are up before transfer begins.

#### 10.1.3.2 Rules and description for `pl_clk_req/lp_clk_ack` handshake

Physical Layer is permitted to initiate `pl_clk_req/lp_clk_ack` handshake at any time and the Adapter must respond.

Rules for this handshake:

1. Physical Layer asserts `pl_clk_req` to request removal of clock gating by the Adapter. This can be done anytime, and independent of current RDI state.
2. The Adapter asserts `lp_clk_ack` to indicate that clock gating has been removed. There must be at least one clock cycle bubble between `pl_clk_req` assertion and `lp_clk_ack` assertion.

3. **pl\_clk\_req** must de-assert before **lp\_clk\_ack**. It is the responsibility of the Physical Layer to control the specific scenario of de-assertion, after the required actions for this handshake are completed.
4. **pl\_clk\_req** should not be the only consideration for the Adapter to perform clock gating, it must take into account **pl\_state\_sts** and other protocol-specific requirements before performing trunk and/or local clock gating.
5. The Physical Layer must use this handshake to ensure transitions of **pl\_inband\_pres** have been observed by the Adapter. Since **pl\_inband\_pres** is a level oriented signal (once asserted it stays asserted during the lifetime of Link operation), the Physical Layer is permitted to let the signal transition without waiting for **lp\_clk\_ack**. When this is done during initial Link bring up, it is strongly recommended for the Physical Layer to keep **pl\_clk\_req** asserted until the state status transitions away from Reset to a state where clock gating is not permitted.

**Figure 10-2. Example Waveform Showing Handling of Level Transition**



6. The Physical Layer must also perform this handshake before transition to LinkError state from Reset or PM state (when the LinkError transition occurs by the Physical Layer without being directed by the Adapter). It is permitted to assert **pl\_clk\_req** before the state change, in which case it must stay asserted until the state status transitions. It is also permitted to assert **pl\_clk\_req** after the state status transition, but in this case Physical Layer must wait for **lp\_clk\_ack** before performing another state transition.
7. The Physical Layer must also perform this handshake when the status is PM and remote Link partner is requesting PM exit. For exit from Reset or PM states to a state that is not LinkError, it is required to assert **pl\_clk\_req** before the status change, and in this case it must stay asserted until the state status transitions away from Reset or PM.
8. When clock-gated in RESET states, Adapters that rely on dynamic clock gating to save power must wait in clock gated state for **pl\_inband\_pres**=1. The Physical Layer will request clock gating exit when it transitions **pl\_inband\_pres**, and the Adapter must wait for **pl\_inband\_pres** assertion before requesting **lp\_state\_req** = ACTIVE. If **pl\_inband\_pres** de-asserts while **pl\_state\_sts** = RESET, then the Adapter is permitted to return to clock-gated state after moving **lp\_state\_req** to NOP.
9. Physical Layer must also perform this handshake for sideband traffic to Adapter. When performing the handshake for **pl\_cfg** transitions, Physical Layer must wait for **lp\_clk\_ack** before changing **pl\_cfg** or **pl\_cfg\_vld**. Because **pl\_cfg** can have multiple transitions for a single packet transfer, it is necessary to make sure that the Adapter clocks are up before transfer begins.

### 10.1.4 Data Transfer

As indicated in the signal list descriptions, when Adapter is sending data to the Physical Layer, data is transferred when **lp\_irdy**, **pl\_trdy**, and **lp\_valid** are asserted. Figure 10-3 shows an example waveform for data transfer from the Adapter to the Physical Layer. Data is transmitted on clock cycles 1, 2, and 5. No assumption should be made by Adapter about when **pl\_trdy** can de-assert or for how many cycles it remains de-asserted before it is asserted again, unless explicitly guaranteed by the Physical Layer. If a Flit transfer takes multiple clock cycles, the Adapter is not permitted to insert bubbles in the middle of a Flit transfer. This means that **lp\_valid** and **lp\_irdy** must be asserted continuously until the Flit transfer is complete. Of course, data transfer can stall because of **pl\_trdy** de-assertion.

**Figure 10-3. Data Transfer from Adapter to Physical Layer**



As indicated in the signal list descriptions, when the Physical Layer is sending data to the Adapter, there is no backpressure mechanism, and data is transferred whenever **pl\_valid** is asserted. The Physical Layer is permitted to insert bubbles in the middle of a Flit transfer and the Adapter must be able to handle that.

#### IMPLEMENTATION NOTE

For the transmit side of the Physical Layer for data sent over the UCIe Link, it must ensure that if the Adapter has a continuous stream of packets to transmit (**lp\_irdy** and **lp\_valid** do not de-assert), it does not insert bubbles in valid frames on the Physical Link.

For the Runtime Link Testing feature with parity insertion, the Adapter as a receiver of parity bytes is permitted to issue a {ParityFeature.Nak} if software sets up a number of parity byte insertions ("Number of 64 Byte Inserts" field in the "Error and Link Testing Control" register) that does not amount to 256B or a multiple of the RDI width (to save the implementation cost of barrel shifting the parity bytes). For example, if the RDI width is 64B then either 64B, 128B, or 256B of inserted parity bytes are okay, but if the RDI width is 256B or larger, then it is better to always have 256B of inserted parity bytes so that it matches the data transfer granularity of Flits.

### IMPLEMENTATION NOTE

It is permitted to use **lp\_irdy** as an early indication that the valid data will be resuming imminently, and the Physical Layer needs to ungate clocks and assert **pl\_trdy** when it is ready to receive data. A couple of examples are shown in [Figure 10-4](#) and [Figure 10-5](#). Note that **pl\_trdy** could have asserted as early as Clock Cycle 1 in [Figure 10-4](#).

**Figure 10-4.** **lp\_irdy** asserting two cycles before **lp\_valid**



**Figure 10-5.** **lp\_irdy** asserting at the same cycle as **lp\_valid**



### 10.1.5 RDI State Machine

Figure 10-6 shows the RDI state machine.

**Figure 10-6. RDI State Machine**



### 10.1.6 RDI bring up flow

Figure 10-7 shows an example flow for Stage 2 of the Link bring up highlighting the transitions on RDI. This stage requires sequencing on RDI that coordinates the state transition from Reset to Active.

1. Once Physical Layer has completed Link training, it must do the `pl_clk_req` handshake with the Adapter and reflect `pl_inband_pres=1` on RDI. Note that the `pl_clk_req` handshake is not shown in the example flow in Figure 10-7
2. This is the trigger for Adapter to request Active state. It must perform the `lp_wake_req` handshake as described in Section 10.1.3. Note that the `lp_wake_req` handshake is not shown in the example flow in Figure 10-7.
3. Only after sampling `lp_state_req = Active`, the Physical Layer must send the `{LinkMgmt.RDI.Req.Active}` sideband message to remote Link partner's Physical Layer.
4. The Physical Layer must respond to the `{LinkMgmt.RDI.Req.Active}` sideband message with a `{LinkMgmt.RDI.Rsp.Active}` sideband message. The `{LinkMgmt.RDI.Rsp.Active}` sideband message must only be sent after the Physical Layer has sampled `lp_state_req = Active` from its local RDI.
5. Once the Physical Layer has sent and received the `{LinkMgmt.RDI.Rsp.Active}` sideband message, it must transition `pl_state_sts` to Active.
6. This opens up the Adapter to transition to Stage 3 of the bring up flow.

Steps 3 to 5 are referred to as the “Active Entry handshake” and must be performed for every entry to Active state. Active.PMNAK to Active transition is not considered here because Active.PMNAK is only a sub-state of Active.

**Figure 10-7. Example flow of Link bring up on RDI**



### 10.1.7 RDI PM flow

This section defines the rules for PM entry, exit and abort flows as they apply to handshakes on the RDI. The rules for L1 and L2 are the same, except that exit from L2 is to Reset state, whereas exit from L1 is to Retrain state. This section uses PM to denote L1 or L2. A “PM Request” sideband message is {LinkMgmt.RDI.Req.L1} or {LinkMgmt.RDI.Req.L2}. A “PM Response” sideband message is {LinkMgmt.RDI.Rsp.L1} or {LinkMgmt.RDI.Rsp.L2}.

- Regardless of protocol, the PM entry or exit flow is symmetric on RDI. Both Physical Layer must issue PM entry request through a sideband message once the conditions of PM entry have been satisfied. PM entry is considered successful and complete once both sides have received a valid “PM Response” sideband message. [Figure 10-8](#) shows an example flow for L1. Once the RDI status is PM, the Physical Layer can transition itself to a power savings state (turning off the PLL for example). Note that the sideband logic and corresponding PLL needs to stay on even during L1 state.
- All the Adapter state machines (Adapter LSMs) in the Adapter must have moved to the corresponding PM state before the Adapter requests PM entry from remote Link partner. Adapter LSM in PM implies the retry buffer of the Adapter must be empty, and it must not have any new Flits (or Ack/Nak) pending to be scheduled. Essentially there should be no traffic on mainband when PM entry is requested by the Adapter to the Physical Layer. The Adapter is permitted to clock gate its sideband logic once RDI status is PM and there are no outstanding transactions or responses on sideband. Physical Layer must do `p1_clk_req` handshake (if `p1_clk_req` is not already asserted or status is not Active) before forwarding sideband requests from the Link to the Adapter.
- Adapter requests PM entry by transitioning `lp_state_req` to the corresponding PM encoding. Once requested, the Adapter cannot change this request until it observes PM, Active.PMNAK, Retrain, or LinkError state on `lp_state_sts`. While requesting PM state, if the Adapter receives Active request from the Protocol Layer, or a PM exit request for the Adapter LSM on sideband, it must sink the message but delay processing it until `lp_state_sts` has resolved. Once the RDI state is resolved, the Adapter must first bring it back to Active before processing the other requests.
  - If the resolution is PM (upon successful PM entry) and the Protocol Layer needs to exit PM (or there is a pending Protocol Layer Active request from remote Link partner), then the Adapter must initiate PM exit flow on RDI by requesting `lp_state_req` = Active. All PM entry-related handshakes must have finished prior to this (this is when the Physical Layer on both sides of the Link have received a valid “PM Response” sideband message).
  - If the resolution is Active.PMNAK, the Adapter must initiate a request of Active on RDI. Once the status moves to Active, the Adapter is permitted to re-request PM entry (if all conditions of PM entry are still met). [Figure 10-9](#) shows an example of PM abort flow. The PM request could have been from either side.
  - If the resolution is LinkError, then the Adapter must propagate this to Protocol Layers. This also resets any outstanding PM handshakes.
- Physical Layer initiates a “PM Request” sideband message once it samples the corresponding PM encoding on `lp_state_req` and has completed the StallReq/Ack handshake with its Adapter.
- Once a Physical Layer receives a “PM request” sideband message, it must respond to it within 2 us:
  - If its local Adapter is requesting the corresponding PM state, it must respond with the corresponding “PM Response” sideband message. If the current status is not PM, it must transition `lp_state_sts` to PM after responding to the sideband message.
  - If the current `lp_state_sts` = PM, it must respond with “PM Response” sideband message.

- If **p1\_state\_sts** = Active and **lp\_state\_req** = Active and it remains this way for 1us after receiving the “PM Request” sideband message, it must respond with {LinkMgmt.RDI.Rsp.PMNAK} sideband message.
- If a Physical Layer receives a “PM Response” sideband message in response to a “PM Request” sideband message, it must transition **p1\_state\_sts** on its local RDI to PM (if it is currently in Active state). If the current state is not Active, no action needs to be taken.
- If a Physical Layer receives a {LinkMgmt.RDI.Rsp.PMNAK} sideband message in response to a “PM Request” sideband message, it must transition **p1\_state\_sts** on its local RDI to Active.PMNAK state if it is currently in Active state. If it is not in Active state, no action needs to be taken. The Physical Layer is permitted to retry PM entry handshake (if all conditions of PM entry are satisfied) at least 2 us after receiving the {LinkMgmt.RDI.Rsp.PMNAK} sideband message OR if it received a corresponding “PM Request” sideband message from the remote Link partner.
- PM exit is initiated by the Adapter requesting Active on RDI. This triggers the Physical Layer to initiate PM exit by sending a {LinkMgmt.RDI.Req.Active} sideband message. Physical Layer must make sure it has finished any Link retraining steps before it responds with the {LinkMgmt.RDI.Rsp.Active} sideband message. [Figure 10-10](#) shows an example flow of PM exit on RDI.
  - PM exit handshake completion requires both Physical Layers to send as well as receive a {LinkMgmt.RDI.Rsp.Active} sideband message. Once this has completed, the Physical Layer is permitted to transition **p1\_state\_sts** to Active on RDI.
  - If **p1\_state\_sts** = PM and a {LinkMgmt.RDI.Req.Active} sideband message is received, the Physical Layer must initiate **p1\_clk\_req** handshake with the Adapter, and transition **p1\_state\_sts** to Retrain. This must trigger the Adapter to request Active on **lp\_state\_req** (if not already doing so), and this in turn triggers the Physical Layer to send {LinkMgmt.RDI.Req.Active} sideband message to the remote Link partner. [Figure 10-11](#) shows an example of the L1 exit flow on RDI and its interaction with the LTSM in the Physical Layer. It is permitted for the LTSM to begin the Link PM exit and retraining flow when a {LinkMgmt.RDI.Req.Active} sideband message is received or when the Adapter requests Active on RDI. The timeout counters for the Active Request sideband message handshake must begin only after LTSM is in the LINKINIT state. L2 exit follows a similar flow for cases in which graceful exit is required without domain reset; however, the L2 exit is via Reset state on RDI, and not Retrain. Exit conditions from Reset state apply for L2 exit (i.e., a NOP -> Active transition is required on **lp\_state\_req** for the Physical Layer to exit Reset state on RDI).

Note that the following figures are examples for L1, and do not show the **lp\_wake\_req**, **p1\_clk\_req** handshakes. Implementations must follow the rules outlined for these handshakes in previous sections.

**Figure 10-8. Successful PM entry flow****Figure 10-9. PM Abort flow**

**Figure 10-10. PM Exit flow****Figure 10-11. RDI PM Exit Example Showing Interactions with LTSM**

## 10.2 Flit-Aware Die-to-Die Interface (FDI)

This section defines the signal descriptions and functionality associated with a single instance of Flit-Aware Die-to-Die Interface (FDI). A single instance is used for a Protocol Layer to Adapter connection. However, a single Adapter can host multiple protocol stacks using multiple instances of FDI.

[Figure 10-12](#) shows example configurations using multiple instances of FDI.

**Figure 10-12. Example configurations using FDI**



[Table 10-3](#) lists the FDI signals and their descriptions. All signals are synchronous with `lclk`.

In [Table 10-3](#):

- `p1_*` indicates that the signal is driven away from the Die-to-Die Adapter to the Protocol Layer.
- `lp_*` indicates that the signal is driven away from the Protocol Layer to the Die-to-Die Adapter.

**Note:** The same signal-naming convention as RDI is used to highlight that RDI signal list is a proper subset of FDI signal list.

Signal encodings pertaining to ‘Management Transport protocol’ are applicable only when Management Transport protocol was successfully negotiated on the mainband. Otherwise, those encodings are reserved. Also, `dm_*` signals in [Table 10-3](#) are applicable only when supporting Management Transport path over the mainband (“dm” is an abbreviation for “d2d\_adapter-to-management\_port\_gateway”).

**Table 10-3. FDI signal list (Sheet 1 of 8)**

| Signal Name                     | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>lclk</b>                     | The clock at which FDI operates.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>lp_irdy</b>                  | Signal indicating that the Protocol Layer potentially has data to send. This must be asserted if lp_valid is asserted and the Protocol Layer wants the Adapter to sample the data.<br><b>lp_irdy</b> must not be presented by the Protocol Layer when <b>pl_state_sts</b> is Reset except when the status transitions from LinkError to Reset. On a LinkError to Reset transition, it is permitted for <b>lp_irdy</b> to be asserted for a few clocks but it must be deasserted eventually. Physical Layer must ignore <b>lp_irdy</b> when status is Reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>lp_valid</b>                 | Protocol Layer to Adapter indication that data is valid on the corresponding <b>lp_data</b> bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>lp_data[NBYTES-1:0][7:0]</b> | Protocol Layer to Adapter data, where 'NBYTES' equals number of bytes determined by the data width for the FDI instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>lp_retimer_crd</b>           | When asserted at a rising clock edge, it indicates a single credit return for the Retimer Receiver buffer. Each credit corresponds to 256B of mainband data (including Flit header and CRC, etc.). This signal must NOT assert if a Retimer is not present.<br>On FDI, this is an optional signal. It is permitted to have the Receiver buffers in the Protocol Layer for Raw Format only. If this is not exposed to Protocol Layer, Adapter must track credit at 256B granularity even for Raw Format and return credits to Physical Layer on RDI.<br>When this is exposed on FDI, the Adapter must have the initial credits knowledge through other implementation specific means in order to advertise this to the remote Link partner during parameter exchanges.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>lp_corrupt_crc</b>           | This signal is only applicable for CXL.cachemem in UCIE Flit Mode (i.e., the Adapter doing Retry) for CXL 256B Flit Mode. It is meant as a latency optimization that enables detection and containment for viral or poison using the Adapter to corrupt CRC of outgoing Flit. It is recommended to corrupt CRC by performing a bitwise XOR of the computed CRC with the syndrome 138EH. The syndrome was computed such that no 1-bit or 2-bit errors alias to this syndrome, and it has the least probability of aliasing with 3-bit errors.<br>For Standard 256B Flits, Protocol Layer asserts this along with <b>lp_valid</b> for the last chunk of the Flit that needs containment. Adapter corrupts CRC for both of the 128B halves of the Flit which had this set. It also must make sure to overwrite this flit (with the next flit sent by the Protocol Layer) in the Tx Retry buffer.<br>For Latency-Optimized 256B Flits, Protocol Layer asserts this along with <b>lp_valid</b> for the last chunk of the 128B Flit half that needs containment. If <b>lp_corrupt_crc</b> is asserted on the first 128B half of the Flit, Protocol Layer must assert it on the second 128B half of the Flit as well. The very next Flit from the Protocol Layer after this signal has been asserted must carry the information relevant for viral, as defined in the CXL specification. If this was asserted on the second 128B half of the Flit only, it is the responsibility of the Protocol Layer to send the first 128B half exactly as before, and insert the viral information in the second half of the Flit. Adapter corrupts CRC for the 128B half of the Flit which had this set. It also must make sure to overwrite this flit (with the next flit sent by the Protocol Layer) in the Tx Retry buffer. |
| <b>lp_dllp[NDLLP-1:0]</b>       | Protocol Layer to Adapter transfer of DLLP bytes. This is not used for 64B Flit Mode, CXL.cachemem or Streaming protocols. For a 64B data path on <b>lp_data</b> , it is recommended to assign <b>NDLLP</b> >= 8, so that 1 DLLP per Flit can be transferred from the Protocol Layer to the Adapter on average. The Adapter is responsible for inserting DLLP into DLP bytes 2:5 if the Flit packing rules permit it. See <a href="#">Section 10.2.4.1</a> for additional rules.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>lp_dllp_valid</b>            | Indicates valid DLLP transfer on <b>lp_dllp</b> . DLLP transfers are not subject to backpressure by <b>pl_trdy</b> (the Adapter must have storage for different types of DLLP and this can be overwritten so that the latest DLLPs are sent to remote Link partner). DLLP transfers are subject to backpressure by <b>pl_stallreq</b> - Protocol Layer must stop DLLP transfers at DLLP Flit aligned boundary before giving <b>lp_stallack</b> or requesting PM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>lp_dllp_ofc</b>              | Indicates that the corresponding DLLP bytes on <b>lp_dllp</b> follow the Optimized_Update_FC format. It must stay asserted for the entire duration of the DLLP transfer on <b>lp_dllp</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**Table 10-3. FDI signal list (Sheet 2 of 8)**

| Signal Name                      | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>lp_stream[7:0]</b>            | Protocol Layer to Adapter signal that indicates the stream ID to use with data. Each stream ID maps to a unique protocol and stack. It is relevant only when <b>lp_valid</b> is 1.<br>00h: Reserved<br>01h: Stack 0: PCIe<br>02h: Stack 0: CXL.io<br>03h: Stack 0: CXL.cachemem<br>04h: Stack 0: Streaming protocol<br>05h: Stack 0: Management Transport protocol<br>11h: Stack 1: PCIe<br>12h: Stack 1: CXL.io<br>13h: Stack 1: CXL.cachemem<br>14h: Stack 1: Streaming protocol<br>15h: Stack 1: Management Transport protocol<br>Other encodings are Reserved.                                                                                                                                                                                           |
| <b>pl_trdy</b>                   | The Adapter is ready to accept data. Data is accepted by the Adapter when <b>pl_trdy</b> , <b>lp_valid</b> , and <b>lp_irdy</b> are asserted at the rising edge of <b>lclk</b> .<br>This signal must be asserted only if <b>pl_state_sts</b> is Active or when performing the <b>pl_stallreq</b> / <b>lp_stallack</b> handshake when the <b>pl_state_sts</b> is LinkError (see <a href="#">Section 10.3.3.7</a> ).                                                                                                                                                                                                                                                                                                                                           |
| <b>pl_valid</b>                  | Adapter to Protocol Layer indication that data is valid on <b>pl_data</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>pl_data[NBYTES-1:0] [7:0]</b> | Adapter to Protocol Layer data, where NBYTES equals the number of bytes determined by the data width for the FDI instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>pl_retimer_crd</b>            | When asserted at a rising clock edge, it indicates a single credit return from the Retimer. Each credit corresponds to 256B of mainband data (including Flit header and CRC, etc.). This signal must NOT assert if a Retimer is not present.<br>On FDI, this is an optional signal. It is permitted to expose these credits to Protocol Layer for Raw Format only. If this is not exposed to Protocol Layer, Adapter must track credit at 256B granularity even for Raw Format and back-pressure the Protocol Layer using <b>pl_trdy</b> .<br>When this is exposed on FDI, the Adapter converts the initial credits received from the Retimer over sideband to credit returns to the Protocol Layer on this bit after Adapter LSM has moved to Active state. |
| <b>pl_dllp[NDLLP-1:0]</b>        | Adapter to Protocol Layer transfer of DLLP bytes. This is not used for 68B Flit mode, CXL.cachemem or Streaming protocols. For a 64B data path on <b>pl_data</b> , it is recommended to assign NDLLP >= 8, so that 1 DLLP per Flit can be transferred from the Adapter to the Protocol Layer, on average. The Adapter is responsible for extracting DLLP from DLP Bytes 2:5 if a Flit Marker is not present. The Adapter is also responsible for indicating Optimized_Update_FC format by setting <b>pl_dllp_ofc</b> = 1 for the corresponding transfer on FDI.                                                                                                                                                                                              |
| <b>pl_dllp_valid</b>             | Indicates valid DLLP transfer on <b>pl_dllp</b> . DLLPs can be transferred to the Protocol Layer whenever valid Flits can be transferred on <b>pl_data</b> . There is no backpressure and the Protocol Layer must always sink DLLPs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>pl_dllp_ofc</b>               | Indicates that the corresponding DLLP bytes on <b>pl_dllp</b> follow the Optimized_Update_FC format. It must stay asserted for the entire duration of the DLLP transfer on <b>pl_dllp</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**Table 10-3. FDI signal list (Sheet 3 of 8)**

| Signal Name              | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_stream[7:0]</b>    | Adapter to Protocol Layer signal that indicates the stream ID to use with data. Each stream ID maps to a unique protocol. It is relevant only when <b>pl_valid</b> is 1.<br>00h: Reserved<br>01h: Stack 0: PCIe<br>02h: Stack 0: CXL.io<br>03h: Stack 0: CXL.cachemem<br>04h: Stack 0: Streaming protocol<br>05h: Stack 0: Management Transport protocol<br>11h: Stack 1: PCIe<br>12h: Stack 1: CXL.io<br>13h: Stack 1: CXL.cachemem<br>14h: Stack 1: Streaming protocol<br>15h: Stack 1: Management Transport protocol<br>Other encodings are Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>pl_flit_cancel</b>    | Adapter to Protocol Layer indication to dump a Flit. This enables latency optimizations on the Receiver data path when CRC checking is enabled in the Adapter. It is not applicable for Raw Format or 68B Flit Format.<br>For Standard 256B Flit, it is required to have a fixed number of clock cycle delay between the last chunk of a Flit transfer and the assertion of <b>pl_flit_cancel</b> . This delay is fixed to be 1 cycle (i.e., the cycle after the last chunk transfer of a Flit). When this signal is asserted, Protocol Layer must not consume the associated Flit.<br>For Latency-Optimized 256B Flits, it is required to have a fixed number of clock cycle delay between the last chunk of a 128B half Flit transfer and the assertion of <b>pl_flit_cancel</b> . This delay is fixed to be 1 cycle (i.e., the cycle after the last transfer of the corresponding 128B chunk).<br>When this signal is asserted, Protocol Layer must not consume the associated Flit half.<br>When this mode is supported, Protocol Layer must support it for all applicable Flit Formats associated with the corresponding protocol. Adapter must guarantee this to be a single cycle pulse when dumping a Flit or Flit half. It is the responsibility of the Adapter to ensure that the canceled Flits or Flit halves are eventually replayed on the interface without cancellation in the correct order once they pass CRC after Retry etc. See <a href="#">Section 10.2.5</a> for examples.<br>When operating in UCIe Flit mode, it is permitted to use this signal to also cancel valid NOP Flits for the Protocol Layer to prevent forwarding these to the Protocol Layer.<br>However for interoperability, if a Protocol Layer receives a NOP Flit without a corresponding <b>pl_flit_cancel</b> , it must discard these Flits. |
| <b>lp_state_req[3:0]</b> | Protocol Layer request to Adapter to request state change.<br>Encodings as follows:<br>0000b: NOP<br>0001b: Active<br>0100b: L1<br>1000b: L2<br>1001b: LinkReset<br>1011b: Retrain<br>1100b: Disabled<br>All other encodings are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>lp_linkerror</b>      | Protocol Layer to Adapter indication that an error has occurred which requires the Link to go down. Adapter must propagate this request to RDI, and move the Adapter LSMs (and CXL vLSMs if applicable) to LinkError state once RDI is in LinkError state. It must stay there as long as <b>lp_linkerror=1</b> . The reason for having this be an indication decoupled from regular state transitions is to allow immediate action on part of the Protocol Layer and Adapter in order to provide the quickest path for error containment when applicable (for example, a viral error escalation could map to the LinkError state)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Table 10-3. FDI signal list (Sheet 4 of 8)**

| Signal Name              | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_state_sts[3:0]</b> | <p>Adapter to Protocol Layer Status indication of the Interface. Encodings as follows:</p> <ul style="list-style-type: none"> <li>0000b: Reset</li> <li>0001b: Active</li> <li>0011b: Active.PMNAK</li> <li>0100b: L1</li> <li>1000b: L2</li> <li>1001b: LinkReset</li> <li>1010b: LinkError</li> <li>1011b: Retrain</li> <li>1100b: Disabled</li> </ul> <p>All other encodings are reserved.</p> <p>The status signal is permitted to transition from Adapter autonomously when applicable. For example the Adapter asserts the Retrain status when it decides to enter retraining either autonomously or when requested by remote agent.</p> <p>For PCIe/Streaming protocols, the Adapter LSM is exposed as <b>pl_state_sts</b> to the Protocol Layer. For CXL protocol, the ARB/MUX vLSM is exposed as <b>pl_state_sts</b> to the Protocol Layer.</p> <p>The Link Status is considered to be Up from Protocol Layer perspective when FDI status is Active, Active.PMNAK, Retrain, L1, or L2. The Link Status is considered Down for other states of FDI.</p>                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>pl_inband_pres</b>    | <p>Adapter to the Protocol Layer indication that the Die-to-Die Link has finished negotiation of parameters with remote Link partner and is ready for transitioning the FDI Link State Machine (LSM) to Active.</p> <p>Once it transitions to 1b, this must stay 1b until FDI moves to Active or LinkError. It stays asserted while FDI is in Retrain, Active, Active.PMNAK, L1, or L2. It must de-assert during LinkReset, Disabled or LinkError states.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>pl_error</b>          | <p>Adapter to the Protocol Layer indication that it has detected a framing related error. It is pipeline matched with the receive data path. It must also assert if <b>pl_error</b> was asserted on RDI by the Physical Layer for a Flit which the Adapter is forwarding to the Protocol Layer.</p> <p>In UCIe Flit Mode, it is permitted for Protocol Layer to use <b>pl_error</b> indication to log correctable errors when Retry is enabled from the Adapter. The Adapter must finish any partial Flits sent to the Protocol Layer and assert <b>pl_filit_cancel</b> in order to prevent consumption of that Flit by the Protocol Layer. Adapter must initiate Link Retrain on RDI following this, if it was a framing error detected by the Adapter.</p> <p>In UCIe Flit Mode, if Retry is disabled, the Adapter is responsible for mapping internally detected framing errors or Physical Layer received <b>pl_error</b> to an Uncorrectable Internal Error and escalate it as <b>pl_trainerror</b> if the mask and severity registers permit the escalation.</p> <p>If the Link is operating in Raw Format, the Adapter has no internal detection of framing errors, it just forwards any <b>pl_error</b> indication received from the Physical Layer on FDI such that it is pipeline matched to the data path.</p> <p>It is a pulse indication that can occur only when FDI receiver is Active (i.e. <b>pl_rx_active_req = 1</b> &amp; <b>pl_rx_active_sts = 1</b>).</p> |
| <b>pl_cerror</b>         | <p>Adapter to the Protocol Layer indication that a correctable error was detected that does not affect the data path. The Protocol Layer must OR the <b>pl_error</b> and <b>pl_cerror</b> signals for Correctable Error Logging.</p> <p>Errors logged in the Correctable Error Status register are mapped to this signal if the corresponding mask bit in the Correctable Error Mask register is cleared to 0.</p> <p>It is a pulse of one or more cycles that can occur in any FDI state. If it is a state in which clock gating is permitted, it is the responsibility of the Adapter to perform the clock gating exit handshake with the Protocol Layer before asserting this signal. Clock gating can resume after <b>pl_cerror</b> is de-asserted and all other conditions permitting clock gating have been met.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**Table 10-3. FDI signal list (Sheet 5 of 8)**

| Signal Name                     | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_nferror</b>               | Adapter to the Protocol Layer indication that a non-fatal error was detected. This is used by Protocol Layer for error logging and corresponding escalation to software. The Adapter must OR any internally detected errors with <b>pl_nferror</b> on RDI and forward the result on FDI. Errors logged in Uncorrectable Error Status Register are mapped to this signal if the corresponding Severity and Mask bits are cleared to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>pl_trainerror</b>            | It is a pulse of one or more cycles that can occur in any FDI state. If it is a state in which clock gating is permitted, it is the responsibility of the Adapter to perform the clock gating exit handshake with the Protocol Layer before asserting this signal. Clock gating can resume after <b>pl_nferror</b> is de-asserted and all other conditions permitting clock gating have been met.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>pl_rx_active_req</b>         | Indicates a fatal error from the Adapter. Adapter must transition <b>pl_state_sts</b> to LinkError if not already in LinkError state. (Note that the Adapter first takes RDI to LinkError, and that LinkError is eventually propagated to all the FDI states). Implementations are permitted to map any fatal error to this signal that require upper layer escalation (or interrupt generation) depending on system level requirements. Errors logged in Uncorrectable Error Status Register are mapped to this signal if the corresponding Severity is set to 1 and the corresponding Mask bit is cleared to 0.                                                                                                                                                                                                                                                                                                                                                                              |
| <b>lp_rx_active_sts</b>         | It is a level signal that can assert in any FDI state but stays asserted until FDI exits the LinkError state to Reset state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>pl_protocol[3:0]</b>         | Adapter asserts this signal to request the Protocol Layer to open its Receiver's data path and get ready for receiving protocol data or Flits. The rising edge of this signal must be when <b>pl_state_sts</b> is Reset, Retrain or Active. Together with <b>lp_rx_active_sts</b> , it forms a four way handshake. See <a href="#">Section 10.2.7</a> for rules related to this handshake.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>pl_protocol_flitfmt[3:0]</b> | Protocol Layer responds to <b>pl_rx_active_req</b> after it is ready to receive and parse protocol data or Flits. Together with <b>pl_rx_active_req</b> , it forms a four way handshake. See <a href="#">Section 10.2.7</a> for rules related to this handshake.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                 | Adapter indication to Protocol Layer of the protocol that was negotiated during training.<br>0000b: PCIe without Management Transport<br>0011b: CXL.1 [Single protocol, i.e., CXL.io] without Management Transport<br>0100b: CXL.2 [Multi-protocol, Type 1 device] without Management Transport<br>0101b: CXL.3 [Multi-protocol, Type 2 device] without Management Transport<br>0110b: CXL.4 [Multi-protocol, Type 3 device] without Management Transport<br>0111b: Streaming protocol without Management Transport<br><br>1000b: PCIe with Management Transport<br>1001b: Management Transport<br>1011b: CXL.1 [Single protocol, i.e., CXL.io] with Management Transport<br>1100b: CXL.2 [Multi-protocol, Type 1 device] with Management Transport<br>1101b: CXL.3 [Multi-protocol, Type 2 device] with Management Transport<br>1110b: CXL.4 [Multi-protocol, Type 3 device] with Management Transport<br>1111b: Streaming protocol with Management Transport<br>Other encodings are Reserved |
|                                 | This indicates the negotiated Format. See <a href="#">Chapter 3.0</a> for the definitions of these formats.<br>0001b: <i>Format 1</i> : Raw Format<br>0010b: <i>Format 2</i> : 68B Flit Format<br>0011b: <i>Format 3</i> : Standard 256B End Header Flit Format<br>0100b: <i>Format 4</i> : Standard 256B Start Header Flit Format<br>0101b: <i>Format 5</i> : Latency-Optimized 256B without Optional Bytes Flit Format<br>0110b: <i>Format 6</i> : Latency-Optimized 256B with Optional Bytes Flit Format<br>Other encodings are Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**Table 10-3. FDI signal list (Sheet 6 of 8)**

| Signal Name                    | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>pl_protocol_vld</code>   | Indication that <code>pl_protocol</code> , and <code>pl_protocol_fmt</code> have valid information. This is a level signal, asserted when the Adapter has determined the appropriate protocol, but must only de-assert again after subsequent transitions to LinkError or Reset state depending on the Link state machine transitions.<br>Protocol Layer must sample and store <code>pl_protocol</code> and <code>pl_protocol_fmt</code> when <code>pl_protocol_vld</code> = 1 and <code>pl_state_sts</code> = Reset and <code>pl_inband_pres</code> = 1. It must treat this saved value as the negotiated protocol until <code>pl_state_sts</code> = Reset and <code>pl_inband_pres</code> = 0.<br>The Adapter must ensure that if <code>pl_inband_pres</code> = 1, <code>pl_protocol_vld</code> = 1 and <code>pl_state_sts</code> = Reset, then <code>pl_protocol</code> and <code>pl_protocol_fmt</code> are the correct values that can be sampled by the Protocol Layer. |
| <code>pl_stallreq</code>       | Adapter request to Protocol Layer to flush all Flits for state transition and not prepare any new Flits.<br>See <a href="#">Section 10.2.6</a> for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <code>lp_stallack</code>       | Protocol Layer to Adapter indication that the Flits are aligned and stalled (if <code>pl_stallreq</code> was asserted). It is strongly recommended that this response logic be on a global free running clock, so the Protocol Layer can respond to <code>pl_stallreq</code> with <code>lp_stallack</code> even if other significant portions of the Protocol Layer are clock gated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <code>pl_phyinrecenter</code>  | Adapter indication to Protocol Layer that the Link is doing training or retraining (i.e., RDI has <code>pl_phyinrecenter</code> asserted or the Adapter LSM has not moved to Active yet). If this is asserted during a state where clock gating is permitted, the <code>pl_clk_req</code> / <code>lp_clk_ack</code> handshake must be performed with the upper layer. The upper layers are permitted to use this to update the "Link Training/Retraining" bit in the UCIe Link Status register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <code>pl_phyinl1</code>        | Adapter indication to Protocol Layer that the Physical Layer is in L1 power management state (i.e., RDI is in L1 state).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <code>pl_phyinl2</code>        | Adapter indication to Protocol Layer that the Physical Layer is in L2 power management state (i.e., RDI is in L2 state).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <code>pl_speedmode[2:0]</code> | Current Link speed. The following encodings are used:<br>000b: 4GT/s<br>001b: 8GT/s<br>010b: 12GT/s<br>011b: 16GT/s<br>100b: 24GT/s<br>101b: 32GT/s<br>other encodings are reserved.<br>The Protocol Layer must only consider this signal to be relevant when the FDI state is Active or Retrain. For multi-module configurations, all modules must operate at the same speed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <code>pl_lnk_cfg[2:0]</code>   | Current Link Configuration. Indicates the current operating width of a module.<br>000b: x4<br>001b: x8<br>010b: x16<br>011b: x32<br>100b: x64<br>101b: x128<br>110b: x256<br>other encodings are reserved.<br>The Protocol Layer must only consider this signal to be relevant when the FDI state is Active or Retrain. This is the total width across all Active modules for the corresponding FDI instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 10-3. FDI signal list (Sheet 7 of 8)**

| Signal Name           | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pl_clk_req</b>     | <p>Request from the Adapter to remove clock gating from the internal logic of the Protocol Layer. This is an asynchronous signal from the Protocol Layer's perspective since it is not tied to <b>lclk</b> being available in the Protocol Layer. Together with <b>lp_clk_ack</b>, it forms a four-way handshake to enable dynamic clock gating in the Protocol Layer.</p> <p>When dynamic clock gating is supported, the Protocol Layer must use this signal to exit clock gating before responding with <b>lp_clk_ack</b>.</p> <p>If dynamic clock gating is not supported, it is permitted for the Adapter to tie this signal to 1b.</p>                                                                                                                                                                                                                                                                                                                                                 |
| <b>lp_clk_ack</b>     | <p>Response from the Protocol Layer to the Adapter acknowledging that its clocks have been un gated in response to <b>pl_clk_req</b>. This signal is only asserted when <b>pl_clk_req</b> is asserted, and de-asserted after <b>pl_clk_req</b> has de-asserted.</p> <p>When dynamic clock gating is not supported by the Protocol Layer, it must stage <b>pl_clk_req</b> internally for one or more clock cycles and turn it around as <b>lp_clk_ack</b>. This way it will still participate in the handshake even though it does not support dynamic clock gating.</p>                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>lp_wake_req</b>    | <p>Request from the Protocol Layer to remove clock gating from the internal logic of the Adapter. This is an asynchronous signal relative to <b>lclk</b> from the Adapter's perspective since it is not tied to <b>lclk</b> being available in the Adapter. Together with <b>pl_wake_ack</b>, it forms a four-way handshake to enable dynamic clock gating in the Adapter.</p> <p>When dynamic clock gating is supported, the Adapter must use this signal to exit clock gating before responding with <b>pl_wake_ack</b>.</p> <p>If dynamic clock gating is not supported, it is permitted for the Protocol Layer to tie this signal to 1b.</p>                                                                                                                                                                                                                                                                                                                                            |
| <b>pl_wake_ack</b>    | <p>Response from the Adapter to the Protocol Layer acknowledging that its clocks have been un gated in response to <b>lp_wake_req</b>. This signal is only asserted after <b>lp_wake_req</b> has asserted, and is de-asserted after <b>lp_wake_req</b> has de-asserted.</p> <p>When dynamic clock gating is not supported by the Adapter, it must stage <b>lp_wake_req</b> internally for one or more clock cycles and turn it around as <b>pl_wake_ack</b>. This way it will still participate in the handshake even though it does not support dynamic clock gating.</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>pl_cfg[NC-1:0]</b> | <p>This is the sideband interface from the Adapter to the Protocol Layer. See <a href="#">Chapter 7.0</a> for details. NC is the width of the interface. Supported values are 8, 16, and 32.</p> <p>Register accesses must be implemented by hardware to be atomic regardless of the width of the interface (i.e., all 32 bits of a register must be updated in the same cycle for a 32-bit register write, and similarly all 64 bits of a register must be updated in the same cycle for a 64-bit register write).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>pl_cfg_vld</b>     | When asserted, indicates that <b>pl_cfg</b> has valid information that should be consumed by the Protocol Layer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>pl_cfg_crd</b>     | <p>Credit return for sideband packets from the Adapter to the Protocol Layer for sideband packets. Each credit corresponds to 64 bits of header and 64 bits of data. Even transactions that do not carry data or carry 32 bits of data consume the same credit and the Receiver returns the credit once the corresponding transaction has been processed or de-allocated from its internal buffers. See <a href="#">Section 7.1.3.1</a> for additional flow control rules. A value of 1 sampled at a rising clock edge indicates a single credit return.</p> <p>Because the advertised credits are design parameters, the Protocol Layer transmitter updates the credit counters with initial credits on domain reset exit, and no initialization credits are returned over the interface.</p> <p>Credit returns must follow the same rules of clock gating exit handshakes as the sideband packets to ensure that no credit returns are dropped by the receiver of the credit returns.</p> |
| <b>lp_cfg[NC-1:0]</b> | <p>This is the sideband interface from Protocol Layer to the Adapter. See <a href="#">Chapter 7.0</a> for details. NC is the width of the interface. Supported values are 8, 16, and 32.</p> <p>Register accesses must be implemented by hardware to be atomic regardless of the width of the interface (i.e., all 32 bits of a register must be updated in the same cycle for a 32-bit register write, and similarly all 64 bits of a register must be updated in the same cycle for a 64-bit register write).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>lp_cfg_vld</b>     | When asserted, indicates that <b>lp_cfg</b> has valid information that should be consumed by the Adapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 10-3. FDI signal list (Sheet 8 of 8)**

| Signal Name                              | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>lp_cfg_crd</code>                  | Credit return for sideband packets from the Protocol Layer to the Adapter for sideband packets. Each credit corresponds to 64 bits of header and 64 bits of data. Even transactions that do not carry data or carry 32 bits of data consume the same credit and the Receiver returns the credit once the corresponding transaction has been processed or de-allocated from its internal buffers. See <a href="#">Section 7.1.3.1</a> for additional flow control rules. A value of 1 sampled at a rising clock edge indicates a single credit return.<br>Because the advertised credits are design parameters, the Adapter transmitter updates the credit counters with initial credits on domain reset exit, and no initialization credits are returned over the interface.<br>Credit returns must follow the same rules of clock gating exit handshakes as the sideband packets to ensure that no credit returns are dropped by the receiver of the credit returns. |
| <code>dm_param_exchange_done</code>      | Signal resets to 0 on a Domain Reset.<br>In single stack management transport implementations, this signal is asserted when adapter parameter exchange has completed between both sides and flit format/protocol have been finalized. It is reset whenever the link status=down.<br>In multi-stack management transport implementations, this signal is asserted only when both stacks have completed their individual adapter parameter exchanges and protocol has been finalized (successfully or unsuccessfully) across both stacks. If at run time one of the active stacks enters link status=down condition, this signal de-asserts and asserts again only when the above condition is again met.                                                                                                                                                                                                                                                               |
| <code>dm_param_stack_count[N-1:0]</code> | Number of stacks that successfully negotiated Management Transport protocol. This field is sampled only when <code>dm_param_exchange_done</code> signal is asserted. If 68B Flit format was finalized, this field must be cleared to 00b.<br>00b: 0 stack<br>01b: 1 stack<br>10b: 2 stacks<br>Others: reserved<br>N=1 for single stack and 2 for 2 stacks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 10.2.1 Interface reset requirements

FDI does not define a separate interface signal for reset; however, it is required that the logic entities on both sides of FDI are in the same reset domain and the reset for each side is derived from the same source. Because reset may be staggered due to SoC routing, all signals coming out of reset must be driven to 0, unless otherwise specified. `lp_stream` and `p1_stream` are exceptions to this rule if they are tied off to their expected values at the time of integration. If `lp_stream` and `p1_stream` are not tied off, they must be driven to 0 when coming out of reset.

### 10.2.2 Interface clocking requirements

FDI requires both sides of the interface to be on the same clock domain. Moreover, the clock domain for sideband interface (`*cfg*`) is the same as the mainband signals.

Each side is permitted to instantiate clock crossing FIFOs internally if needed, as long as it does not violate the requirements at the interface itself.

It is important to note that there is no back pressure possible from the Protocol Layer to the Adapter on the main data path. So any clock crossing related logic internal to the Protocol Layer must take this into consideration.

### 10.2.3 Dynamic clock gating

Dynamic coarse clock gating is permitted in the Adapter and Protocol Layer when `p1_state_sts` is Reset, LinkReset, Disabled or PM states. This section defines the rules around entry and exit of clock gating. Note that clock gating is not permitted in LinkError states - it is expected that the UCIe usages

will enable error handlers to make sure the Link is not stuck in a LinkError state, if the intent is to save power when a Link is in an error state.

### 10.2.3.1 Rules and description for lp\_wake\_req/pl\_wake\_ack handshake

Protocol Layer can request removal of clock gating of the Adapter by asserting `lp_wake_req` (asynchronous to `lclk` availability in the Adapter). All Adapter implementations must respond with a `pl_wake_ack` (synchronous to `lclk`). The extent of internal clock ungating when `pl_wake_ack` is asserted is implementation-specific, but lclk must be available by this time to enable FDI transitions from the Protocol Layers. The Wake Req/Ack is a full handshake and it must be used for state transition requests (on `lp_state_req` or `lp_linkerror`) when moving away from a state in which clock gating is permitted. It must also be used for sending packets on the sideband interface.

Rules for this handshake:

1. Protocol Layer asserts `lp_wake_req` to request ungating of clocks by the Adapter.
2. The Adapter asserts `pl_wake_ack` to indicate that clock gating has been removed. There must be at least one clock cycle bubble between `lp_wake_req` assertion and `pl_wake_ack` assertion.
3. `lp_wake_req` must de-assert before `pl_wake_ack` de-asserts. It is the responsibility of the Protocol Layer to control the specific scenario of de-assertion. As an example, when performing the handshake for a state request, it is permitted to keep `lp_wake_req` asserted until it observes the desired state status. Protocol Layer is also permitted to keep `lp_wake_req` asserted through states where clock gating is not permitted in the Adapter (i.e., Active, LinkError or Retrain).
4. `lp_wake_req` should not be the only consideration for Adapter to perform clock gating, it must take into account `pl_state_sts` and other internal or Link requirements before performing global and/or local clock gating.
5. When performing `lp_wake_req/pl_wake_ack` handshake for `lp_state_req` transitions or `lp_linkerror` transition, the Protocol Layer is permitted to not wait for `pl_wake_ack` before changing `lp_state_req` or `lp_linkerror`.
6. When performing `lp_wake_req/pl_wake_ack` handshake for `lp_cfg` transitions, Protocol Layer must wait for `pl_wake_ack` before changing `lp_cfg` or `lp_cfg_vld`. Because `lp_cfg` can have multiple transitions for a single packet transfer, it is necessary to make sure that the Adapter clocks are up before transfer begins.

### 10.2.3.2 Rules and description for pl\_clk\_req/lp\_clk\_ack handshake

Adapter is allowed to initiate `pl_clk_req/lp_clk_ack` handshake at any time and the Protocol Layer must respond.

Rules for this handshake:

1. Adapter asserts `pl_clk_req` to request removal of clock gating by the Protocol Layer. This can be done anytime, and independent of current FDI state.
2. The Protocol Layer asserts `lp_clk_ack` to indicate that clock gating has been removed. There must be at least one clock cycle bubble between `pl_clk_req` assertion and `lp_clk_ack` assertion.
3. `pl_clk_req` must de-assert before `lp_clk_ack`. It is the responsibility of the Adapter to control the specific scenario of de-assertion, after the required actions for this handshake are completed.

4. `pl_clk_req` should not be the only consideration for the Protocol Layer to perform clock gating, it must take into account `pl_state_sts` and other protocol-specific requirements before performing trunk and/or local clock gating.
5. The Adapter must use this handshake to ensure transitions of `pl_inband_pres`, `pl_physin11`, `pl_physin12`, `pl_physinrecenter`, and `pl_rx_active_req` have been observed by the Protocol Layer. Since these are level oriented signals, the Adapter is permitted to let the signal transition without waiting for `lp_clk_ack`. When this is done during initial Link bring up, it is strongly recommended for the Adapter to keep `pl_clk_req` asserted until the state status transitions away from Reset to a state where clock gating is not permitted or until the state status is Reset and `pl_inband_pres` de-asserts.

**Figure 10-13. Example Waveform Showing Handling of Level Transition**



6. The Adapter must also perform this handshake before transition to LinkError state from Reset, LinkReset, Disabled or PM state (especially when the LinkError transition occurs by the Adapter without being directed by the Protocol Layer). It is permitted to assert `pl_clk_req` before the state change, in which case it must stay asserted until the state status transitions. It is also permitted to assert `pl_clk_req` after the state status transition, but in this case Adapter must wait for `lp_clk_ack` before performing another state transition.
7. The Adapter must also perform this handshake when the status is PM and remote Link partner is requesting PM exit. For exit from Reset, LinkReset, Disabled or PM states to a state that is not LinkError, it is required to assert `pl_clk_req` before the status change, and in this case it must stay asserted until the state status transitions away from Reset or PM.
8. The Adapter must also perform this handshake for sideband transfers from the Adapter to the Protocol Layer. When performing the handshake for `pl_cfg` transitions, Adapter must wait for `lp_clk_ack` before changing `pl_cfg` or `pl_cfg_vld`. Because `pl_cfg` can have multiple transitions for a single packet transfer, it is necessary to make sure that the Protocol Layer clocks are up before transfer begins.

When clock-gated in Reset states, Protocol Layers that rely on dynamic clock gating to save power must wait in clock gated state for `pl_inband_pres`=1. The Adapter will request clock gating exit when it transitions `pl_inband_pres`, and the Protocol Layer must wait for `pl_inband_pres` assertion before requesting `lp_state_req` = ACTIVE. If `pl_inband_pres` de-asserts while `pl_state_sts` = Reset, then the Protocol Layer is permitted to return to clock-gated state after moving `lp_state_req` to NOP.

#### 10.2.4 Data Transfer

As indicated in the signal list descriptions, when Protocol Layer is sending data to the Adapter, data is transferred when `lp_irdy`, `pl_trdy` and `lp_valid` are asserted. Figure 10-14 shows an example waveform for data transfer from the Protocol Layer to the Adapter. Data is transmitted on clock cycles 1, 2, and 5. No assumption should be made by Protocol Layer about when `pl_trdy` can de-assert or for how many cycles it remains de-asserted before it is asserted again, unless explicitly guaranteed by the Adapter. If a Flit transfer takes multiple clock cycles, the Protocol Layer is not permitted to insert

bubbles in the middle of a Flit transfer (i.e., `lp_valid` and `lp_irdy` must be asserted continuously until the Flit transfer is complete. Of course, data transfer can stall because of `p1_trdy` de-assertion).

**Figure 10-14. Data Transfer from Protocol Layer to Adapter**



As indicated in the signal list descriptions, when Adapter is sending data to the Protocol layer, there is no back-pressure mechanism, and data is transferred whenever `p1_valid` is asserted. The Adapter is permitted to insert bubbles in the middle of a Flit transfer and the Protocol Layer must be able to handle that.

#### 10.2.4.1 DLLP transfer rules for 256B Flit Mode

For PCIe and CXL.io 256B Flits (both Standard and Latency-Optimized), FDI provides a separate signal for DLLP transfers from the Protocol Layer to the Adapter and vice-versa. Since the DLLPs have to bypass the Retry buffer, the separate signal enables the Adapter to insert DLLPs into the Flits from the Protocol Layer or the Retry buffer, if it is permitted to do so per the Flit packing rules of the corresponding Flit Format. Rules relevant for FDI operation (per FDI instance) are outlined below:

For the Transmitting side:

- Protocol Layer is responsible for sending the relevant DLLPs at the rate defined by the underlying Protocol to prevent timeouts of DLLP exchanges. If the Protocol Layer has no TLPs to send, it must insert NOP Flits to ensure that the Adapter gets an opportunity to insert the DLLP bytes.
- When transferring DLLP or Optimized\_Update\_FC, the least significant byte is sent over Byte 0 of the FDI bus, the next byte over Byte 1 and so on. When the transfer is over multiple chunks across FDI, Byte 0 is transferred on the first chunk LSB, Byte 1 following it and so on.
- The Adapter must have storage for at least 1 DLLP of every unique DLLP encoding (including Optimized\_Update\_FC) per supported VC that is possible for transfer to remote Link partner. The Adapter tracks pending DLLPs and schedules them on the next available opportunity for the relevant Flits. Credit update DLLPs must not be reordered for a VC by the Adapter. It is however permitted to discard a pending credit DLLP if the Protocol Layer presented a new credit DLLP of the same FC and VC. This extends to Optimized\_Update\_FC packets; i.e., it is permitted to discard any pending NP or P Update FC DLLPs, if the Protocol Layer transferred an Optimized\_Update\_FC for the corresponding VC.

On the Receiving side:

- The Adapter must extract DLLPs from received Flits of the corresponding protocol and forward them to the Protocol Layer. The FDI signal width of `p1_dllp` must be wide enough to keep up with the maximum rate of DLLPs that could be received from the Link.
- When transferring DLLP over multiple chunks across FDI, Byte 0 is transferred on the first chunk LSB, Byte 1 following it and so on.

- The Protocol Identifier corresponding to D2D Adapter in the Flit Header overlaps with the Flit usage of NOP Flits defined in PCIe and CXL specifications. The Adapter must check for available DLLPs in these Flits as well. All 0 bits in the DLLP byte positions indicate a NOP DLLP, and must not be forwarded to the Protocol Layer.

### 10.2.5 Examples of `pl_flit_cancel` Timing Relationships

In all the examples shown in this section, a 64B datapath on FDI is shown, and “F0Bytes” in the figures correspond to “Flit 0 Bytes”.

**Figure 10-15** shows an example timing relationship for `pl_flit_cancel` and `pl_data` for Latency-Optimized Flits when the first Flit half fails CRC check. Both Flit halves are canceled by the Adapter in this example by asserting `pl_flit_cancel` one clock after the last chunk transfer of the corresponding Flit half. It is permitted for the Adapter to de-assert `pl_valid` on clock cycles 5 and 6 instead of canceling that Flit half; however, this might have implications to meeting physical design timing margins in the Adapter. The use of `pl_flit_cancel` allows the Adapter to perform the CRC check on the side without putting the CRC logic in the critical timing path of the data flow and thus permitting higher frequency operation for implementations. In the example shown, after replay flow the entire Flit is transferred to the Protocol Layer without canceling as CRC checks pass.

**Figure 10-15. Example for `pl_flit_cancel` for Latency-Optimized Flits and CRC Error on First Flit Half**



**Figure 10-16** and **Figure 10-17** show examples of two possible implementations of timing relationship for `pl_flit_cancel` and `pl_data` for Latency-Optimized Flits when the second Flit half fails CRC check. In both cases, the first half of the Flit is consumed by the Protocol Layer because it is not canceled by the Adapter (the data transferred on clock cycles 3 and 4).

In the first case (shown in **Figure 10-16**), after the replay flow, CRC passes, and the Adapter ensures that the Protocol Layer does not re-consume the first half again by asserting `pl_flit_cancel` for it. In this case, `pl_valid` asserts for the entire Flit, but only the second half is consumed because the first half was canceled on clock cycle (n+2).

In the second case (shown in **Figure 10-17**), after the replay flow, CRC passes, and the Adapter ensures that the Protocol Layer does not re-consume the first half again by not asserting `pl_valid` for it.

**Figure 10-16. Example for `pl_flit_cancel` for Latency-Optimized Flits and CRC Error on Second Flit Half**



**Figure 10-17. Example for `pl_flit_cancel` for Latency-Optimized Flits and CRC Error on Second Flit Half, Alternate Implementation Example**



Figure 10-18 shows an example for a Standard 256B Flit. In this case, the CRC bytes are packed toward the end of the Flit and thus a CRC error on either of the two halves cancels the entire Flit. After replay flow, CRC passes, and the entire Flit is sent to the Protocol Layer without canceling it.

**Figure 10-18. Example for pl\_flt\_cancel for Standard 256B Flits**



## 10.2.6 FDI State Machine

Figure 10-19 shows the FDI state machine.

**Figure 10-19. FDI State Machine**



## 10.2.7 Rx\_active\_req/Sts Handshake

The Adapter negotiates Active state transitions on FDI using sideband messages when the Adapter LSM is exposed to the Protocol Layer. Since the sideband Link is running slower than the mainband Link, the Adapter needs to make sure that the Protocol Layer's Receiver is already in Active state (even though `pl_state_sts` might not have moved to Active yet) before responding to the Active request sideband message from remote Link partner. Rx\_active\_req/Sts handshake facilitates this.

When CXL is sent over UCIe, ARB/MUX functionality is performed by the Adapter and CXL vLSMs are exposed on FDI. Although ALMPs are transmitted over mainband, the interface to the Protocol Layer is FDI and it follows the rules of Rx\_active\_req/Sts Handshake as well.

Rules for this handshake:

1. The Adapter (or ARB/MUX) asserts `pl_rx_active_req` to trigger the Protocol Layer to open its Receiver's data path for receiving protocol data or Flits. This signal does not affect the Transmitter data path (it must wait for `pl_state_sts` to move to Active and follow the rules of `pl_trdy`). `pl_rx_active_req` should have a rising edge only when `lp_rx_active_sts` = 0 and `pl_state_sts` is Reset, Retrain or Active.
2. The Protocol Layer asserts `lp_rx_active_sts` after `pl_rx_active_req` has asserted and when it is ready to receive protocol data or Flits. There must be at least one clock cycle delay between `pl_rx_active_req` assertion and `lp_rx_active_sts` assertion to prevent a combinatorial loop.
3. When `pl_rx_active_req` = 1 and `lp_rx_active_sts` = 1, the Receiver is in Active state if `pl_state_sts` is Reset, Retrain, or Active.
4. `pl_rx_active_req` should have a falling edge only when `lp_rx_active_sts` = 1. This must trigger Protocol Layer to de-assert `lp_rx_active_sts`, and this completes the transition of the Receiver away from Active state.
5. For graceful exit from Active state (i.e., a transition to PM, Retrain, LinkReset or Disabled states), both `pl_rx_active_req` and `lp_rx_active_sts` must de-assert before `pl_state_sts` transitions away from Active.
6. If `pl_rx_active_req` = 0 while `pl_state_sts` = Active, the Adapter must guarantee no Flits would be sent to the Protocol Layer (for example, this can happen if the Adapter LSM or RDI is in Retrain, but the vLSM exposed to Protocol Layer is still in Active). Thus, it is permitted to perform this handshake even when the state status on FDI remains Active throughout.
7. For Active to LinkError transition, it is permitted for `pl_state_sts` to transition to LinkError before `pl_rx_active_req` de-asserts, but both `pl_rx_active_req` and `lp_rx_active_sts` must de-assert before `pl_state_sts` transitions away from LinkError.

### 10.2.8 FDI Bring up flow

Figure 10-20 shows an example flow for Stage 3 of the Link bring up highlighting the transitions on FDI. This stage requires sequencing on FDI that coordinates the state transition from Reset to Active. If multiple stacks of protocol or ARB/MUX is present, the same sequence happens independently for each Protocol Layer stack. The flows on FDI are illustrated for Adapter 0 LSM in the sideband message encodings, however Adapter 1 LSM must send the sideband message encodings corresponding to Adapter 1 to its remote Link partner.

1. Once Adapter has completed transition to Active on RDI and successful parameter negotiation with the remote Link partner, it must do the `pl_clk_req` handshake with the Protocol Layer and reflect `pl_inband_pres`=1 on FDI. Note that the `pl_clk_req` handshake is not shown in the example flow in Figure 10-20
2. This is the trigger for Protocol Layer to request Active state. It is permitted for the Protocol Layer to wait until `pl_protocol_vld` = 1 before requesting Active. It must perform the `lp_wake_req` handshake as described in Section 10.2.3.1. Note that the `lp_wake_req` handshake is not shown in the example flow in Figure 10-20.
3. On sampling `lp_state_req` = Active, the Adapter must send the {LinkMgmt.Adapter0.Req.Active} sideband message to remote Link partner.

4. The Adapter must respond to the {LinkMgmt.Adapter.Req.Active} sideband message with a {LinkMgmt.Adapter.Rsp.Active} sideband message after making sure that the Protocol Layer's Receiver is ready. The {LinkMgmt.Adapter0.Rsp.Active} must only be sent after the Adapter has sampled `pl_rx_active_req = lp_rx_active_sts = 1`. As mentioned previously, the `pl_clk_req` handshake applies to `pl_rx_active_req` as well; it is permitted for the Adapter to keep `pl_clk_req` asserted continuously (once it has been asserted for `pl_inband_pres`) while doing the bring up flow. Note once the Adapter has sent the {LinkMgmt.Adapter0.Rsp.Active} sideband message, if it receives Flits from the remote Link partner, it must process them as applicable (i.e. for UCIE Flit mode, the Adapter must respond to the Sequence Number Handshake initiated by the remote Link or respond with Ack/Nak for Payload Flits. The Adapter will have to insert NOPs in case the `pl_state_sts` signal has not yet transitioned to Active).
5. If no ARB/MUX is present, once the Adapter has sent and received the {LinkMgmt.Adapter0.Rsp.Active} sideband message, it must transition `pl_state_sts` to Active for the Protocol Layer, and Flit transfer can begin (i.e., new Flits can be accepted from the Protocol Layer, and in UCIE Flit mode, the Adapter is permitted to initiate the Sequence Number Handshake Phase if it has not already done so as a result of Step 4).
6. If ARB/MUX is present, the sending and receipt of {LinkMgmt.Adapter0.Rsp.Active} sideband message opens up the ARB/MUX to perform ALMP exchanges over mainband and eventually transition the vLSMs to Active state.

**Step 3** through **Step 6** constitute the “Active Entry Handshake” on FDI and must be performed for every entry to Active state. Active.PMNAK to Active transition is not considered here because Active.PMNAK is only a sub-state of Active.

**Figure 10-20. FDI Bring up flow**



### 10.2.9 FDI PM Flow

This section describes the sequencing and rules for PM entry and exit on FDI. The rules are the same for L1 or L2 entry. L1 exit transitions the state machine through Retrain to Active, whereas L2 exit transitions the state machine through Reset to Active. The flow illustrations in the section use L1 as an example. A “PM request” sideband message is {LinkMgmt.Adapter\*.Req.L1} or {LinkMgmt.Adapter\*.Req.L2}. A “PM Response” sideband message is {LinkMgmt.Adapter\*.Rsp.L1} or {LinkMgmt.Adapter\*.Rsp.L2}. The flows on FDI are illustrated for Adapter 0 LSM in the sideband message encodings; however, Adapter 1 LSM must send the sideband message encodings corresponding to Adapter 1 to its remote Link partner.

- The Protocol Layer requests PM entry on FDI after idle time criteria has been met. The criteria for idle time is implementation specific and could be dependent on the protocol. For PCIe and CXL.io protocols, PM DLLPs are **not** used to negotiate PM entry/exit when using D2D Adapter’s Retry buffer (i.e., UCIE Flit mode).
- If operating in UCIE Flit mode, ARB/MUX is present within the D2D Adapter, and it follows the rules of *CXL Specification* (for 256B Flit mode) to take the vLSMs to the corresponding PM state. Note that even for CXL 64B Flit mode, the same ALMP rules as 256B Flit mode are used. This is a simplification on UCIE, because ALMPs always go through the retry buffer. Once vLSMs are in the PM state, ARB/MUX requests the Adapter Link State Machine to enter the corresponding PM state. The Adapter Link State Machine transition to PM follows the same rules as outlined for Protocol Layer and Adapter below.
- If CXL or PCIe protocol has been negotiated, only the upstream port (UP) can initiate PM entry. This is done using a sideband message from the UP Adapter to the downstream port (DP) Adapter. DP Adapter must not initiate entry into PM. PM support is required for CXL and PCIe protocols. PM entry is considered successful and complete once UP receives a valid “PM Response” sideband message. [Figure 10-21](#) shows an example flow for CXL or PCIe protocol PM Entry on FDI and Adapter. Once the FDI status is PM for all Protocol Layers, the Adapter can request PM transition on RDI.
- If Streaming protocol has been negotiated, OR UCIE is in Raw Format, OR Management Transport protocol was negotiated over the mainband without CXL or PCIe, then both side Adapters must issue a PM entry request through a sideband message once the conditions of PM entry have been satisfied. PM entry is considered successful and complete once both sides have received a valid “PM Response” sideband message. [Figure 10-22](#) shows an example flow for symmetric protocols. Once the FDI status is PM for all Protocol Layers, the Adapter can request PM transition on the RDI.
- Protocol Layer requests PM entry once it has blocked transmission of any new Protocol Layer Flits, by transitioning `lp_state_req` to L1 or L2 encoding. Once requested, the Protocol Layer cannot change this request until it observes the corresponding PM state, Retrain, Active.PMNAK or LinkError state on `pl_state_sts`; unless it is a DP Protocol Layer for PCIe or CXL. Once the FDI state is resolved, the Adapter must first bring it back to Active before processing any new PM requests from the Protocol Layer.
  - If the resolution is PM (upon successful PM entry) and the Protocol Layer needs to exit PM (or there is a pending Protocol Layer Active request from remote Link partner) then the Protocol Layer must initiate PM exit flow on FDI by requesting `lp_state_req` = Active. All PM entry related handshakes must have finished prior to this (for CXL/PCIe protocols, this is when UP has received a valid “PM Response” sideband message. For symmetric protocols, this is when both sides Adapter have received a valid “PM Response” sideband message).
  - If the resolution is Active.PMNAK, the Protocol Layer must initiate a request of Active on FDI. Once the status moves to Active, the Protocol Layer is permitted to re-request PM entry (if all conditions of PM entry are still met). [Figure 10-23](#) shows an example of PM abort flow. The PM

request could have been from either side depending on the configuration. Protocol Layer must continue receiving protocol data or Flits while the status is Active or Active.PMNAK.

- DP Protocol Layer for PCIe or CXL is permitted to change request from PM to Active without waiting for PM or Active.PMNAK (the DP FDI will never have `p1_state_sts=Active.PMNAK` since it does not send “PM Request” sideband messages); however, it is still possible for the Adapter to initiate a stallreq/ack and complete PM entry if it was in the process of committing to PM entry when the Protocol Layer changed its request. In this scenario, the Protocol Layer will see `p1_state_sts` transition to PM and it is permitted to continue asking for the new state request.
- If the resolution is LinkError, then the Link is down and it resets any outstanding PM handshakes.
- Adapter (UP port only if CXL or PCIe protocol), initiates a “PM request” sideband message once it samples a PM request on `lp_state_req` and has completed the StallReq/Ack handshake with the corresponding Protocol Layer and its Retry buffer is empty of Flits from the Protocol Layer that is requesting PM (all pending Acknowledgments have been received).
- If the Adapter LSM moves to Retrain while waiting for a “PM Response” sideband message, it must wait for the response. Once the response is received, it must transition back to Active before requesting a new PM entry. Note that the transition to Active requires Active Entry handshake with the remote Link partner, and that will cause the remote partner to exit PM. If the Adapter LSM receives a “PM Request” sideband message after it has transitioned to Retrain, it must immediately respond with {LinkMgmt.Adapter0.Rsp.PMNAK}.

**Note:** The precise timing of the remote Link partner that is observing Link Retrain is unknown; thus, the safer thing to do is to go to Active and redo the PM handshake when necessary for this scenario. There is a small probability that there might be an exit from PM and re-entry back in PM under certain scenarios.

- Once the Adapter receives a “PM request” sideband message, it must respond to it within 2 us (the time is only counted during the Adapter LSM being in Active state):
    - if its local Protocol Layer is requesting PM, it must respond with the corresponding “PM Response” sideband message after finishing the StallReq/Ack handshake with its Protocol Layer and its Retry buffer being empty. If the current status is not PM, it must transition `p1_state_sts` to PM after responding to the sideband message.
    - If the current `p1_state_sts` = PM, it must respond with “PM Response” sideband message.
    - If `p1_state_sts` = Active and `lp_state_req` = Active and it remains this way for 1us after receiving the “PM Request” sideband message, it must respond with {LinkMgmt.Adapter0.Rsp.PMNAK} sideband message. The time is only counted during all the relevant state machines being in Active state.
  - If the Adapter receives a “PM Response” sideband message in response to a “PM Request” sideband message, it must transition `p1_state_sts` on its local FDI to PM (if it is currently in Active state).
  - If the Adapter receives a {LinkMgmt.Adapter0.Rsp.PMNAK} sideband message in response to a “PM Request” sideband message, it must transition `p1_state_sts` on its local FDI to Active.PMNAK state if it is currently in Active state. If it is not in Active state, no action needs to be taken. It is permitted to retry PM entry handshake (if all conditions of PM entry are satisfied) at least 2us after receiving the {LinkMgmt.Adapter0.Rsp.PMNAK} sideband message OR if it received a corresponding “PM Request” sideband message from the remote Link partner.
  - PM exit is initiated by the Protocol Layer requesting Active on FDI. After RDI is in Active, triggers the Adapter to initiate PM exit by performing the Active Entry handshakes on sideband.
- [Figure 10-24](#) shows an example flow of PM exit on FDI when Adapter LSM is exposed.

- PM exit handshake completion requires both Adapters to send as well as receive a {LinkMgmt.Adapter0.Rsp.Active} sideband message. Once this has completed, the Adapter is permitted to transition Adapter LSM to Active.
- If **pl\_state\_sts = PM** and a {LinkMgmt.Adapter0.Req.Active} sideband message is received, the Adapter must initiate **pl\_clk\_req** handshake with the Protocol Layer, and transition Adapter LSM to Retrain (For L2 exit, the transition is to Reset). This must trigger the Protocol Layer to request Active on **lp\_state\_req** (if not already doing so), and this in turn triggers the Adapter to send {LinkMgmt.Adapter0.Rsp.Active} sideband message to the remote Link partner.

Note that the following figures are examples and do not show the **lp\_wake\_req**, **pl\_clk\_req**, and/or **pl\_rx\_active\_req** handshakes. Implementations must follow the rules outlined for these handshakes in previous sections.

**Figure 10-21. PM Entry example for CXL or PCIe protocols**



**Figure 10-22. PM Entry example for symmetric protocol**



**Figure 10-23. PM Abort Example****Figure 10-24. PM Exit Example**

## 10.3 Common rules for FDI and RDI

This section covers common set of rules applicable to FDI and RDI and cross-interactions between them. Any applicable differences are called out as well. To have common terminology for the common set of rules, Upper Layer is used to refer to Adapter for RDI, and Protocol Layer for FDI. Lower Layer is used to refer to Physical Layer for RDI and Adapter for FDI.

Because Active.PMNAK is a sub-state of Active, all rules that apply for Active are also applicable for Active.PMNAK; however the state status cannot move from Active.PMNAK directly to L1 or L2 due to the rules requiring the Upper Layer to request a transition to Active before requesting PM again.

### 10.3.1 Byte Mapping for FDI and RDI

The Flit Format figures in [Chapter 3.0](#) show examples of how a Flit is laid out on a 64B datapath when sent over FDI or RDI. [Figure 10-25](#) shows an example of a CXL.io Standard 256B Start Header Flit for reference. Each Flit takes four data transfers across FDI or RDI when the data width is 64 Bytes. Each data transfer is referred to a Flit Chunk, numbered in increasing order within an entire Flit transfer.

For every data transfer, the Least Significant Byte from the corresponding Flit Chunk is mapped to Byte 0 on FDI (or RDI), the next Byte from the Flit is mapped to Byte 1 on FDI (or RDI), and so on. Within each Byte, bit 0 of the Byte from the Flit maps to bit 0 of the corresponding Byte on FDI (or RDI), and so on. The same mapping applies for both transmit and receive directions.

For example, in Transfer 0, Byte 0 of the Flit is mapped to Byte 0 of FDI (or RDI), Byte 1 of the Flit is mapped to Byte 1, and so on. In transfer 1, Byte 64 of the Flit is mapped to Byte 0 of FDI (or RDI), Byte 65 of the Flit is mapped to Byte 1 of FDI (or RDI) and so on. This example is illustrated in [Figure 10-26](#). Data transfers follow the rules outlined in [Section 10.1.4](#) for RDI and [Section 10.2.4](#) for FDI and hence do not necessarily correspond to consecutive clock cycles.

**Figure 10-25. CXL.io Standard 256B Start Header Flit Format Example<sup>a</sup>**



- a. See [Figure 2-1](#) for color mapping.
- b. Flit Header Byte 0 and Byte 1, respectively.
- c. DLP Byte 2, Byte 3, Byte 4, and Byte 5, respectively.
- d. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Figure 10-26. FDI (or RDI) Byte Mapping for 64B Datapath to 256B Flits**

| Transfer<br>(Rows) | FDI (or RDI) Bytes<br>(Columns) |               |               |     |               |               |               |               |
|--------------------|---------------------------------|---------------|---------------|-----|---------------|---------------|---------------|---------------|
|                    | 0                               | 1             | 2             | ... | 60            | 61            | 62            | 63            |
| 0                  | Flit Byte 0                     | Flit Byte 1   | Flit Byte 2   | ... | Flit Byte 60  | Flit Byte 61  | Flit Byte 62  | Flit Byte 63  |
| 1                  | Flit Byte 64                    | Flit Byte 65  | Flit Byte 66  | ... | Flit Byte 124 | Flit Byte 125 | Flit Byte 126 | Flit Byte 127 |
| 2                  | Flit Byte 128                   | Flit Byte 129 | Flit Byte 130 | ... | Flit Byte 188 | Flit Byte 189 | Flit Byte 190 | Flit Byte 191 |
| 3                  | Flit Byte 192                   | Flit Byte 193 | Flit Byte 194 | ... | Flit Byte 252 | Flit Byte 253 | Flit Byte 254 | Flit Byte 255 |

If the FDI or RDI datapath width is increased (or decreased), the Byte mapping follows the same convention of increasing order of Flit bytes mapped to increasing order of FDI (or RDI) bytes.

Figure 10-27 shows an illustration of a 128B data path.

**Figure 10-27. FDI (or RDI) Byte Mapping for 128B Datapath to 256B Flits**

| Transfer<br>(Rows) | FDI (or RDI) Bytes<br>(Columns) |               |               |     |               |               |               |               |     |               |               |               |
|--------------------|---------------------------------|---------------|---------------|-----|---------------|---------------|---------------|---------------|-----|---------------|---------------|---------------|
|                    | 0                               | 1             | 2             | ... | 62            | 63            | 64            | 65            | ... | 125           | 126           | 127           |
| 0                  | Flit Byte 0                     | Flit Byte 1   | Flit Byte 2   | ... | Flit Byte 62  | Flit Byte 63  | Flit Byte 64  | Flit Byte 65  | ... | Flit Byte 125 | Flit Byte 126 | Flit Byte 127 |
| 1                  | Flit Byte 128                   | Flit Byte 129 | Flit Byte 130 | ... | Flit Byte 190 | Flit Byte 191 | Flit Byte 192 | Flit Byte 193 | ... | Flit Byte 253 | Flit Byte 254 | Flit Byte 255 |

For 68B Flit Formats, the Protocol Layer transfers only 64B of payload information from the Flit over FDI (the Flit Header and CRC are inserted by the Adapter). Thus, if the datapath is 128B wide, two such transfers will happen at a given clock cycle as shown in Figure 10-28. The numbering in the figure still uses the Byte positions relative to the overall Flit, hence Byte 0 corresponds to Flit 0 Byte 2, etc. On the Transmit path, the Protocol Layer inserts empty slots (i.e., bytes with a value of 00h) to populate the entire width of the bus if the interface width is greater than 64B and there is insufficient payload information to transmit. The Adapter does the same on the Receive path.

**Figure 10-28. FDI Byte Mapping for 128B Datapath for 68B Flit Format**

| Transfer<br>(Rows) | FDI Bytes<br>(Columns) |                  |                  |     |                   |                   |                  |                  |     |                   |                   |                   |
|--------------------|------------------------|------------------|------------------|-----|-------------------|-------------------|------------------|------------------|-----|-------------------|-------------------|-------------------|
|                    | 0                      | 1                | 2                | ... | 62                | 63                | 64               | 65               | ... | 125               | 126               | 127               |
| 0                  | Flit 0<br>Byte 2       | Flit 0<br>Byte 3 | Flit 0<br>Byte 4 | ... | Flit 0<br>Byte 64 | Flit 0<br>Byte 65 | Flit 1<br>Byte 2 | Flit 1<br>Byte 3 | ... | Flit 1<br>Byte 63 | Flit 1<br>Byte 64 | Flit 1<br>Byte 65 |

For 68B Flit Formats, Adapter inserts the Flit Header and CRC bytes, and performs the necessary shifting before transferring the bytes over RDI. Thus, if the data path is 128B wide, the byte mapping will follow as shown in Figure 10-29. The remainder of Flit 1 continues on the next transfer, etc. Given that the Adapter must insert PDS bytes before pausing the data stream, which makes the transfer a multiple of 256B, the transfer naturally aligns when the width of RDI is 64B, 128B, or 256B on both the Transmit and Receive directions. For wider than 256B interfaces, see the Implementation Note below.

**Figure 10-29. RDI Byte Mapping for 128B Datapath for 68B Flit Format**

| Transfer<br>(Rows) | RDI Bytes<br>(Columns) |                   |                   |     |                   |                   |                   |                  |     |                   |                   |                   |
|--------------------|------------------------|-------------------|-------------------|-----|-------------------|-------------------|-------------------|------------------|-----|-------------------|-------------------|-------------------|
|                    | 0                      | 1                 | 2                 | ... | 65                | 66                | 67                | 68               | ... | 125               | 126               | 127               |
| 0                  | Flit 0<br>Byte 0       | Flit 0<br>Byte 1  | Flit 0<br>Byte 2  | ... | Flit 0<br>Byte 65 | Flit 0<br>Byte 66 | Flit 0<br>Byte 67 | Flit 1<br>Byte 0 | ... | Flit 1<br>Byte 57 | Flit 1<br>Byte 58 | Flit 1<br>Byte 59 |
| 1                  | Flit 1<br>Byte 60      | Flit 1<br>Byte 61 | Flit 1<br>Byte 62 | ... | ...               | ...               | ...               | ...              | ... | ...               | ...               | ...               |

The frequency of operation of the interfaces along with the data width determines the maximum bandwidth that can be sustained across the FDI (or RDI) interface. For example, a 64B datapath at 2 GHz of clock frequency is required to sustain a 16 GT/s Link for an Advanced Package configuration with a single module. Similarly, to scale to 32 GT/s of Link speed operation for Advanced Package configuration with a single module, a 128B datapath running at 2 GHz would be required to support the maximum Link bandwidth.

The FDI (or RDI) byte mapping for the transmit or receive direction does not change for multi-module configurations. The MMPL logic within the Physical Layer is responsible for ensuring that the bytes are transmitted in the correct order to the correct module. Any byte swizzling or rearrangement to resolve module naming conventions, etc., is thus the responsibility of the MMPL logic.

## IMPLEMENTATION NOTE — NBYTES

For Raw Format, the value of NBYTES is vendor-defined. This Implementation Note is for UCIe Flit mode.

It is strongly recommended that when operating in UCIe Flit mode, NBYTES is chosen to be one of 64, 128, 256, or 512 and is selected to get the best KPI (e.g., latency, area, etc.) for the desired bandwidth from the UCIe Link. If NBYTES is chosen to be larger than or equal to 512, it is strongly recommended that it is a multiple of 256 and is only done for the case of a four module Advanced Package Link designed for 16 GT/s or higher. Data transfer over the Link for all Flit formats defined in UCIe Flit mode are in a granularity of 256B, so aligning to a multiple of that avoids unnecessary shifting and corresponding tracking.

For situations in which the RDI or FDI data path is wider than 256B, the following considerations apply for interoperability:

- On the Transmit side, it is required to send valid data corresponding to the full width of the interface. For FDI, this would mean the Protocol Layer might need to pack a Protocol Flit with empty slots. For RDI, this would mean the Adapter might need to insert NOP Flits (for 68B Flit Format, PDS bytes are also included as valid data for this purpose).
- On the Receive side, for RDI:

It is possible that the Physical Layer has to wait to accumulate sufficient bytes before transmitting over RDI. The Physical Layer must accumulate data in multiples of 256B and if the accumulated data is less than the RDI width, it must wait for a sufficient gap in valid data transfer on the Physical Link (at least 16 UI for differential clock and 32 UI for quadrature clock) before transmitting this data on RDI. In this scenario, the accumulated data is sent on the lower significant bytes of the RDI, and any remaining bytes on the interface are assigned to all 0s.

For 256B Flit Formats, a Flit Header which is 0000h with a CRC of 0000h is silently discarded by the Adapter. It is also not included for the purposes of Runtime Link Testing.

For 68B Flit Formats, the Adapter is expected to keep track of the PDS bytes (because these are included in Runtime Link Testing). Any extra padding beyond that is silently discarded and not included for the purposes of Runtime Link Testing.

- On the Receive side, for FDI:

The Adapter must accumulate data in multiples of 256B before forwarding to the Protocol Layer. If the accumulated data is less than the FDI width, it gets sent on the lower significant bytes of the FDI, and any remaining bytes on the interface are assigned to 0b.

For 256B Flit Formats, a Flit Header of 0000h is a NOP for the Protocol Layer and is discarded.

For 68B Flit Formats, 00h are IDLE symbols for PCIe/CXL.io or Empty slots for CXL.cachemem, both of which get discarded by the Protocol Layer. For Streaming protocols that use 68B Flit Formats, it is recommended to use the same approach.

- `lp_corrupt_crc`, `pl_flit_cancel`, and `pl_error` apply to all the Flits that are transferred at the corresponding clock cycle. If applicable, it is recommended to set NDLLP to 32 for these applications and limit the DLLP throughput to be 1 per clock cycle on FDI.

### 10.3.2 Stallreq/Ack Mechanism

The Stallreq/Ack mechanism is used by the Lower Layer to interrupt the Flit transfers by the Upper Layer at a Flit boundary. On RDI, the Stallreq/Ack mechanism must be used when exiting Active state to Retrain, PM, LinkReset or Disabled states. On FDI, for UCIe Raw Format, the Stallreq/Ack mechanism must be used when exiting Active state to Retrain, PM, LinkReset or Disabled states. On FDI, for UCIe Flit Mode, the Stallreq/Ack mechanism must only be used when exiting Active State to a PM state. For other scenarios that exit Active state for UCIe Flit mode, the Adapter must simply de-assert **p1\_trdy** at a Flit boundary before state transition.

The Stallreq/Ack mechanism is mandatory for all FDI and RDI implementations. **lp\_stallack** assertion implies that Upper Layer has stalled its pipeline at a Flit aligned boundary.

The **p1\_stallreq/lp\_stallack** handshake is a four-phase sequence that follows the rules below:

1. The **p1\_stallreq** and **lp\_stallack** must be de-asserted before domain reset exit.
2. A rising edge on **p1\_stallreq** must only occur when **lp\_stallack** is de-asserted.
3. A falling edge on **p1\_stallreq** must only occur when **lp\_stallack** is asserted or when the domain is in reset.
4. A rising edge on **lp\_stallack** must only occur when **p1\_stallreq** is asserted.
5. A falling edge on **lp\_stallack** must only occur when **p1\_stallreq** is de-asserted or when domain is in reset.
6. When **lp\_stallack** is asserted **lp\_valid** and **lp\_irdy** must both be de-asserted.
7. While **p1\_stallreq** is asserted, any data presented on the interface must be accepted by the physical layer until the rising edge of **lp\_stallack**. **p1\_trdy** is not required to be asserted consecutively.
8. The logic path between **p1\_stallreq** and **lp\_stallack** must contain at least one flip-flop to prevent a combinatorial loop.
9. A complete stallreq/stallack handshake is defined as the completion of all four phases: Rising edge on **p1\_stallreq**, rising edge on **lp\_stallack**, falling edge on **p1\_stallreq**, falling edge on **lp\_stallack**.
10. It is strongly recommended that Upper Layer implements providing **lp\_stallack** on a global free running clock so that it can finish the handshake even if the rest of its logic is clock gated.

To avoid performance penalties, it is recommended that this handshake be completed as quickly as possible while satisfying the above rules.

### IMPLEMENTATION NOTE

In multiple places within this specification, for state transitions, it is referring to completing the Stallreq/Ack handshake before the state transition. In the context of state transitions, there are two acceptable ways to implement this from the lower layer:

- One implementation from the lower layer would follow the sequence:
  - i. Assert `pl_stallreq`.
  - ii. After `lp_stallack` is asserted, perform the necessary actions for state transition (including deassertion of `pl_trdy`).
  - iii. De-assert `pl_stallreq`. Once `lp_stallack` de-asserts, the state transition is considered complete.
- The alternate implementation from the lower layer would follow the sequence:
  - i. Assert `pl_stallreq`.
  - ii. After `lp_stallack` is asserted, de-assert `pl_trdy`.
  - iii. De-assert `pl_stallreq` and perform the necessary actions for state transition.

State transition is considered complete after `pl_state_sts` update and `lp_stallack` de-assertion.

### 10.3.3 State Request and Status

Table 10-4 describes the Requests considered by the Lower layer in each of the interface states. The Upper layer must take into account the interface state status and make the necessary request modifications.

The requests are listed on the Row and the state status is listed in the Column.

The entries in Table 10-4 denote the following:

- Yes: Indicates that the request is considered for next state transition by the lower layer.
- N/A: Not Applicable
- Ignore: Indicates that the request is ignored and has no effect on the next state transition.

**Table 10-4. Requests Considered in Each State by Lower Layer**

| <b>Request (Row)<br/>Versus<br/>Status<br/>(Column)</b> | <b>Reset</b>     | <b>Active</b>       | <b>L1</b> | <b>LinkReset</b> | <b>Retrain</b> | <b>Disable</b> | <b>L2</b> | <b>LinkError</b> |
|---------------------------------------------------------|------------------|---------------------|-----------|------------------|----------------|----------------|-----------|------------------|
| NOP                                                     | Yes              | Ignore              | Ignore    | Ignore           | Ignore         | Ignore         | Ignore    | Ignore           |
| Active                                                  | Yes <sup>a</sup> | Ignore <sup>b</sup> | Yes       | Yes              | Yes            | Yes            | Yes       | Yes              |
| L1                                                      | Ignore           | Yes                 | Ignore    | Ignore           | Ignore         | Ignore         | Ignore    | Ignore           |
| LinkReset                                               | Yes <sup>a</sup> | Yes                 | Yes       | Ignore           | Yes            | Ignore         | Yes       | Ignore           |
| Retrain                                                 | Ignore           | Yes                 | Ignore    | Ignore           | Ignore         | Ignore         | Ignore    | Ignore           |
| Disable                                                 | Yes <sup>a</sup> | Yes                 | Yes       | Yes              | Yes            | Ignore         | Yes       | Ignore           |
| L2                                                      | Ignore           | Yes                 | Ignore    | Ignore           | Ignore         | Ignore         | Ignore    | Ignore           |
| LinkError<br>(sideband wire)                            | Yes              | Yes                 | Yes       | Yes              | Yes            | Yes            | Yes       | Yes              |

a. Requires request transition from NOP

b. If the Status is Active.PMNAK, then the Lower Layer transitions to Active upon sampling the Active Request.

### 10.3.3.1 Reset State rules

The Reset State can be entered on de-assertion of interface reset signal or from LinkReset/Disable/LinkError/L2 states. In Reset state, the physical layer is permitted to begin its initialization/training process.

The **p1\_state\_sts** is not permitted to exit Reset state until requested by the upper layer. The exit from Reset state is requested by the upper layer by changing the **lp\_state\_req** signal from NOP encoding value to the permitted next state encoding value.

The rules for Reset state transition are as follows:

1. Reset→Active: The lower layer triggers transitions to the Active state upon observing **lp\_state\_req == Reset (NOP)** for at least one clock while **p1\_state\_sts** is indicating Reset followed by observing **lp\_state\_req == Active**. The transition to Active is only completed once the corresponding Active Entry handshakes have completed on the Link. For RDI, it is when the Physical Layer has sent and received an Active Response sideband message to and from the remote Physical Layer respectively. For the Adapter LSM, it is when the Adapter has sent and received an Active Status sideband message to and from the remote Adapter respectively. For the ARB/MUX vLSM, it is when the ARB/MUX has sent and received an Active Status ALMP to and from the remote ARB/MUX respectively.
2. Reset→LinkReset: The lower layer transitions to the LinkReset state upon observing **lp\_state\_req == Reset (NOP)** for at least one clock while **p1\_state\_sts** is indicating Reset followed by observing **lp\_state\_req == LinkReset OR** when requested by remote Link partner through the relevant sideband message. The lower layer is permitted to transition through Active State, and when it does, Active state exit conditions apply.
3. Reset→Disabled: The lower layer transitions to the Disabled state upon observing **lp\_state\_req == Reset (NOP)** for at least one clock while **p1\_state\_sts** is indicating Reset followed by observing **lp\_state\_req == Disabled OR** when requested by the remote Link partner through the relevant sideband message. The lower layer is permitted to transition through Active State, and when it does, Active state exit conditions apply.
4. Reset→LinkError: The lower layer transitions to LinkError based on observing an internal request to move to the LinkError or **lp\_linkerror** assertion. For RDI, this transition is permitted if requested by the remote Link partner through the relevant sideband message.

### 10.3.3.2 Active State rules

The Active state to next state transitions are described below.

The rules for Active State transition are as follows:

1. Active→Retrain: The Lower layer transitions to the Retrain state upon observing `lp_state_req == Retrain` or due to an internal request to retrain the Link while `pl_state_sts == Active`. This arc is not applicable for CXL vLSMs exposed on FDI (CXL Flit Mode with Retry in the Adapter).
2. Active→L1: The physical layer transitions to L1 based on observing `lp_state_req == L1` while in the Active state, if other conditions of PM entry have also been satisfied.
3. Active→L2: The physical layer transitions to L2 based on observing `lp_state_req == L2` while in the Active state, if other conditions of PM entry have also been satisfied.

It is permitted to have an Active.PMNAK to Retrain/LinkReset/Disable/LinkError transition for cases where Lower Layer is waiting for the Upper Layer to change the request to Active and the corresponding Link event triggers it. There is no scenario where there is a transition from Active.PMNAK to L1 or L2.

[Section 10.3.3.8](#) describes the transition from Active or Active.PMNAK to LinkReset, Disable, or LinkError states.

### 10.3.3.3 PM Entry/Exit Rules

See the PM entry and exit sequences in the RDI and FDI sections.

### 10.3.3.4 Retrain State Rules

Adapter requests Retrain on RDI if any of the following events occur:

- Software writes to the Retain bit and the Link is in Active state.
- Number of CRC or parity errors detected crosses a threshold. The specific algorithm for determining this is implementation specific.
- Protocol Layer requests Retrain (only applicable for UCIe Raw Format).
- any other implementation specific condition (if applicable).

Physical Layer triggers a Retrain transition on RDI if:

- Valid framing errors are observed
- Remote Physical Layer requests Retrain entry
- Adapter requests Retrain

Protocol Layer must not request Retrain on FDI, unless UCIe is operating in UCIe Raw Format.

A Retrain transition on RDI must always be propagated to Adapter LSMs that are in Active. Retrain transitions of the UCIe Link are not propagated to CXL vLSMs. Upon Retrain entry, the credit counter for UCIe Retimer (if present) must be reset to the value advertised during initial Link bring up (the value is given by the "Retimer\_Credits" Parameter in the {AdvCap.Adapter} sideband message during initial Link bring up). The Retimer must drain or dump any Flits in flight or its internal transport buffers upon entry to Retrain. Additionally, the Retimer must trigger Retrain of the remote UCIe Link (across the Off-Package Interconnect).

Entry into Retrain state resets power management state for the corresponding state machine, and power management entry if required must be re-initiated after the interface enters Active state. If

there was an outstanding PM request that returns PM Response, the corresponding state machine must perform Active Entry handshakes to bring that state machine back to Active.

The rules for Retrain state transition are as follows:

1. Retrain→Active: If Retrain was entered from L1, the lower layer begins Active Entry handshakes upon observing `lp_state_req == Active` while `p1_state_sts == Retrain`. If Retrain was entered from Active, the lower layer begins Active Entry handshakes only after observing a NOP->Active transition on `lp_state_req`. Lower layer transitions to Active once the corresponding Active Entry handshakes have completed. Exit from Retrain on RDI requires the Active Entry handshakes to have completed between Physical Layers. Exit from Retrain on FDI must ensure that RDI has moved back to Active, and Active Entry handshakes have successfully completed between Adapters (for the Adapter LSM).
2. Transitional state: The lower layer is permitted to transition to the Active state upon observing `lp_state_req == LinkReset` or `Disabled` while `p1_state_sts == Retrain`. Following the entry into Active the lower layer is permitted to make a transition to the requested state.

[Section 10.3.3.8](#) describes Retrain exit to LinkReset, Disable, or LinkError states.

**Note:** The requirement to wait for NOP->Active transition ensures that the Upper Layer has a way to delay Active transition in case it is waiting for any relevant sideband handshakes to complete (for example the Parity Feature handshake).

### 10.3.3.5 LinkReset State Rules

LinkReset is used for reset flows (HotReset equivalent in PCIe, Protocol Layer must use this to propagate SBR to the device as well) to convey device and/or Link Reset across the UCIe Link.

Adapter triggers LinkReset transition upon observing a LinkReset request from the Protocol Layer, OR on receiving a sideband message requesting LinkReset entry from the remote Link partner OR an implementation specific internal condition (if applicable). Implementations must make best efforts to gracefully drain the Retry buffers when transitioning to LinkReset, however, entry to LinkReset must not timeout on waiting for the Retry buffer to drain. The Protocol Layer and Adapter must drain/flush their pipelines and retry buffer of the Flits for the corresponding Protocol Stack once the FDI state machines have entered LinkReset.

If all the FDI state machines and Adapter LSMS are in LinkReset, the Adapter triggers RDI to enter LinkReset as well.

The rules for LinkReset State transitions are as follows:

1. LinkReset→Reset: The lower layer transitions to the Reset state due to an internal request to move to Reset (example reset pin trigger) or `lp_state_req == Active` while `p1_state_sts == LinkReset` and all necessary actions with respect to LinkReset have been completed.
2. LinkReset→Disabled: The lower layer transitions to Disabled based on observing `lp_state_req == Disabled` or due to an internal request to move to Disabled while `p1_state_sts == LinkReset`.
3. Transitional State: The PHY is permitted to transition through Reset State, and when it does, Reset state exit conditions apply.
4. LinkReset→LinkError: The lower layer transitions to LinkError due to an internal request to move to LinkError or `lp_linkerror` assertion while `p1_state_sts == LinkReset`.

### 10.3.3.6 Disabled State Rules

Adapter triggers Disabled entry when any of the following events occur:

- Protocol Layer requests entry to Disabled state
- Software writes to the Link Disable bit corresponding to the underlying Protocol (e.g., the Link Disable bit in the Link Control register in PCIe)
- Remote Link partner requests entry to Disabled state through the relevant sideband message
- An implementation specific internal condition (if applicable)

Implementations must make best efforts to gracefully drain the Retry buffers when transitioning to Disabled, however, entry to Disabled must not timeout on waiting for the Retry buffer to drain. The Protocol Layer and Adapter must drain/flush their pipelines and retry buffer of the Flits for the corresponding Protocol Stack once the FDI state machines have entered Disabled.

If all the FDI state machines and Adapter LSMs are in Disabled, the Adapter triggers RDI to enter Disabled as well.

The rules for Disabled State are as follows:

- Disabled→Reset: The lower layer transitions to the Reset state due to an internal request to move to Reset (example reset pin trigger) or `lp_state_req == Active` while `p1_state_sts == Disabled` and all necessary actions with respect to Disabled transition have completed.
- Disabled→LinkError: The lower layer transitions to LinkError due to an internal request to move to LinkError or `lp_linkerror` assertion while `p1_state_sts == Disabled`.

### 10.3.3.7 LinkError State Rules

The lower layer enters LinkError state when directed by an `lp_linkerror` signal or due to Internal LinkError conditions. For RDI, the entry is also triggered if the remote Link partner requested LinkError entry through the relevant sideband message. It is not required to complete the stallreq/ack handshake before entering this state. However, for implementations where LinkError state is not a terminal state (terminal implies SoC needs to go through reset flow after reaching LinkError state), it is expected that software can come and retrain the Link after clearing error status registers, etc., and the following rules should be followed:

- If the lower layer decides to perform a `p1_stallreq/lp_stallack` handshake, it must provide `p1_trdy` to the upper layer to drain the packets. In cases where there is an uncorrectable internal error in the lower layer, these packets could be dropped and not transmitted on the Link.
- It is required for the upper layer to internally clean up the data path, even if `p1_trdy` is not asserted and it has sampled LinkError on `p1_state_sts` for at least one clock cycle.

The lower layer may enter LinkError state due to Internal LinkError requests such as when:

- Encountering uncorrectable errors due to hardware failure or directed by Upper Layer
- Remote Link partner requests entry into LinkError (RDI only)

The rules for LinkError state are as follows:

- LinkError→Reset: The lower layer transitions to Reset due to an internal request to move to Reset (e.g., reset pin assertion, or software clearing the error status bits that triggered the error) OR (`lp_state_req == Active` and `lp_linkerror = 0`, while `p1_state_sts == LinkError` AND minimum residency requirements are met AND no internal condition such as an error state requires the lower layer to remain in LinkError). Lower Layer must implement a minimum residency time in LinkError of 16 ms to ensure that the remote Link partner will be forced to enter