



# Universal Chiplet Interconnect Express™ (UCle™)

## Specification

---

**August 6, 2024**

**Revision 2.0, Version 1.0**

**LEGAL NOTICE FOR THIS PUBLICLY AVAILABLE SPECIFICATION FROM UNIVERSAL CHIPLET INTERCONNECT EXPRESS, INC.**

**© 2022–2024 UNIVERSAL CHIPLET INTERCONNECT EXPRESS, INC. ALL RIGHTS RESERVED.**

This Universal Chiplet Interconnect Express, Inc. Specification (this “**UCIE Specification**” or this “**document**”) is owned by and is proprietary to Universal Chiplet Interconnect Express, Inc., a Delaware nonprofit corporation (sometimes referred to as “**UCIE**” or the “**UCIE Consortium**” or the “**Company**”) and/or its successors and assigns.

**NOTICE TO USERS WHO ARE MEMBERS OF UNIVERSAL CHIPLET INTERCONNECT EXPRESS, INC.:**

If you are a Member of Universal Chiplet Interconnect Express, Inc. (herein referred to as a “**UCIE Member**”), and even if you have received this publicly available version of this UCIE Specification after agreeing to the UCIE Consortium’s Evaluation Copy Agreement (a copy of which is available at [www.uciexpress.org/specifications](http://www.uciexpress.org/specifications)), each such UCIE Member must also be in compliance with all of the following UCIE Consortium documents, policies and/or procedures (collectively, the “**UCIE Governing Documents**”) in order for such UCIE Member’s use and/or implementation of this UCIE Specification to receive and enjoy all of the rights, benefits, privileges and protections of UCIE Consortium membership: (i) the UCIE Consortium’s Intellectual Property Policy; (ii) the UCIE Consortium’s Bylaws; (iii) any and all other UCIE Consortium policies and procedures; and (iv) the UCIE Member’s Participation Agreement.

**NOTICE TO NON-MEMBERS OF UNIVERSAL CHIPLET INTERCONNECT EXPRESS, INC.:**

If you are **not** a UCIE Member and have received this publicly available version of this UCIE Specification, your use of this document is subject to your compliance with, and is limited by, all of the terms and conditions of the UCIE Consortium’s Evaluation Copy Agreement (a copy of which is available at [www.uciexpress.org/specifications](http://www.uciexpress.org/specifications)).

In addition to the restrictions set forth in the UCIE Consortium’s Evaluation Copy Agreement, any references or citations to this document must acknowledge Universal Chiplet Interconnect Express, Inc.’s sole and exclusive copyright ownership of this UCIE Specification. The proper copyright citation or reference is as follows: “**© 2022–2024 UNIVERSAL CHIPLET INTERCONNECT EXPRESS, INC. ALL RIGHTS RESERVED.**” When making any such citation or reference to this document you are not permitted to revise, alter, modify, make any derivatives of, or otherwise amend the referenced portion of this document in any way without the prior express written permission of Universal Chiplet Interconnect Express, Inc.

Except for the limited rights explicitly given to a non-UCIE Member pursuant to the explicit provisions of the UCIE Consortium’s Evaluation Copy Agreement which governs the publicly available version of this UCIE Specification, nothing contained in this UCIE Specification shall be deemed as granting (either expressly or impliedly) to any party that is **not** a UCIE Member: (i) any kind of license to implement or use this UCIE Specification or any portion or content described or contained therein, or any kind of license in or to any other intellectual property owned or controlled by the UCIE Consortium, including without limitation any trademarks of the UCIE Consortium; or (ii) any benefits and/or rights as a UCIE Member under any UCIE Governing Documents. For clarity, and without limiting the foregoing notice in any way, if you are **not** a UCIE Member but still elect to implement this UCIE Specification or any portion described herein, you are hereby given notice that your election to do so does not give you any of the rights, benefits, and/or protections of the UCIE Members, including without limitation any of the rights, benefits, privileges or protections given to a UCIE Member under the UCIE Consortium’s Intellectual Property Policy.

**LEGAL DISCLAIMERS AND ADDITIONAL NOTICE TO ALL PARTIES:**

THIS DOCUMENT AND ALL SPECIFICATIONS AND/OR OTHER CONTENT PROVIDED HEREIN IS PROVIDED ON AN “**AS IS**” BASIS. TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, UNIVERSAL CHIPLET INTERCONNECT EXPRESS, INC. (ALONG WITH THE CONTRIBUTORS TO THIS DOCUMENT) HEREBY DISCLAIM ALL REPRESENTATIONS, WARRANTIES AND/OR COVENANTS, EITHER EXPRESS OR IMPLIED, STATUTORY OR AT COMMON LAW, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, VALIDITY, AND/OR NON-INFRINGEMENT.

In the event this UCIE Specification makes any references (including without limitation any incorporation by reference) to another standard’s setting organization’s or any other party’s (“**Third Party**”) content or work, including without limitation any specifications or standards of any such Third Party (“**Third Party Specification**”), you are hereby notified that your use or implementation of any Third Party Specification: (i) is not governed by any of the UCIE Governing Documents; (ii) may require your use of a Third Party’s patents, copyrights or other intellectual property rights, which in turn may require you to independently obtain a license or other consent from that Third Party in order to have full rights to implement or use that Third Party Specification; and/or (iii) may be governed by the intellectual property policy or other policies or procedures of the Third Party which owns the Third Party Specification. Any trademarks or service marks of any Third Party which may be referenced in this UCIE Specification are owned by the respective owner of such marks.

The **UCIE™** and **UNIVERSAL CHIPLET INTERCONNECT EXPRESS™** trademarks and logos (the “**UCIE Trademarks**”) are trademarks owned by the UCIE Consortium. The UCIE Consortium reserves all rights in and to all of its UCIE Trademarks.

**NOTICE TO ALL PARTIES REGARDING THE PCI-SIG UNIQUE VALUE PROVIDED IN THIS SPECIFICATION:**

**NOTICE TO USERS:** THE UNIQUE VALUE THAT IS PROVIDED IN THIS SPECIFICATION FOR USE IN VENDOR DEFINED MESSAGE FIELDS, DESIGNATED VENDOR SPECIFIC EXTENDED CAPABILITIES, AND ALTERNATE PROTOCOL NEGOTIATION ONLY AND MAY NOT BE USED IN ANY OTHER MANNER, AND A USER OF THE UNIQUE VALUE MAY NOT USE THE UNIQUE VALUE IN A MANNER THAT (A) ALTERS, MODIFIES, HARMS OR DAMAGES THE TECHNICAL FUNCTIONING, SAFETY OR SECURITY OF THE PCI-SIG ECOSYSTEM OR ANY PORTION THEREOF, OR (B) COULD OR WOULD REASONABLY BE DETERMINED TO ALTER, MODIFY, HARM OR DAMAGE THE TECHNICAL FUNCTIONING, SAFETY OR SECURITY OF THE PCI-SIG ECOSYSTEM OR ANY PORTION THEREOF (FOR PURPOSES OF THIS NOTICE, “**PCI-SIG ECOSYSTEM**” MEANS THE PCI-SIG SPECIFICATIONS, MEMBERS OF PCI-SIG AND THEIR ASSOCIATED PRODUCTS AND SERVICES THAT INCORPORATE ALL OR A PORTION OF A PCI-SIG SPECIFICATION AND EXTENDS TO THOSE PRODUCTS AND SERVICES INTERFACING WITH PCI-SIG MEMBER PRODUCTS AND SERVICES).

# Contents

---

|                                                                    |    |
|--------------------------------------------------------------------|----|
| <b>Terminology .....</b>                                           | 25 |
| <b>Reference Documents .....</b>                                   | 34 |
| <b>Revision History .....</b>                                      | 34 |
| <b>1.0 Introduction .....</b>                                      | 35 |
| 1.1 UCIe Components.....                                           | 40 |
| 1.1.1 Protocol Layer.....                                          | 40 |
| 1.1.2 Die-to-Die (D2D) Adapter.....                                | 41 |
| 1.1.3 Physical Layer.....                                          | 41 |
| 1.1.4 Interfaces .....                                             | 42 |
| 1.2 UCIe Configurations.....                                       | 42 |
| 1.2.1 Single Module Configuration.....                             | 42 |
| 1.2.2 Multi-module Configurations .....                            | 43 |
| 1.2.3 Sideband-only Configurations.....                            | 44 |
| 1.3 UCIe Retimers.....                                             | 45 |
| 1.4 UCIe Key Performance Targets .....                             | 47 |
| 1.5 Interoperability .....                                         | 48 |
| <b>2.0 Protocol Layer .....</b>                                    | 49 |
| 2.1 PCIe .....                                                     | 50 |
| 2.1.1 Raw Format.....                                              | 51 |
| 2.1.2 Standard 256B End Header Flit Format.....                    | 51 |
| 2.1.3 68B Flit Format .....                                        | 51 |
| 2.1.4 Standard 256B Start Header Flit Format .....                 | 51 |
| 2.1.5 Latency-Optimized 256B with Optional Bytes Flit Format.....  | 52 |
| 2.2 CXL 256B Flit Mode.....                                        | 52 |
| 2.2.1 Raw Format.....                                              | 52 |
| 2.2.2 Latency-Optimized 256B Flit Formats .....                    | 52 |
| 2.2.3 Standard 256B Start Header Flit Format .....                 | 53 |
| 2.3 CXL 68B Flit Mode .....                                        | 53 |
| 2.3.1 Raw Format.....                                              | 53 |
| 2.3.2 68B Flit Format .....                                        | 53 |
| 2.4 Streaming Protocol .....                                       | 54 |
| 2.4.1 Raw Format.....                                              | 54 |
| 2.4.2 68B Flit Format .....                                        | 54 |
| 2.4.3 Standard 256B Flit Formats .....                             | 54 |
| 2.4.4 Latency-Optimized 256B Flit Formats .....                    | 55 |
| 2.5 Management Transport Protocol .....                            | 55 |
| <b>3.0 Die-to-Die Adapter.....</b>                                 | 56 |
| 3.1 Stack Multiplexing .....                                       | 57 |
| 3.2 Link Initialization .....                                      | 60 |
| 3.2.1 Stage 3 of Link Initialization: Adapter Initialization ..... | 60 |
| 3.2.1.1 Part 1: Determine Local Capabilities .....                 | 60 |
| 3.2.1.2 Part 2: Parameter Exchange with Remote Link Partner .....  | 61 |
| 3.2.1.3 FDI bring up .....                                         | 69 |
| 3.3 Operation Formats.....                                         | 70 |
| 3.3.1 Raw Format for All Protocols .....                           | 70 |
| 3.3.2 68B Flit Format .....                                        | 70 |
| 3.3.2.1 68B Flit Format Alignment and Padding Rules .....          | 72 |
| 3.3.3 Standard 256B Flit Formats .....                             | 74 |
| 3.3.4 Latency-Optimized 256B Flit Formats .....                    | 79 |

|            |                                                                                        |           |
|------------|----------------------------------------------------------------------------------------|-----------|
| 3.3.5      | Flit Format-related Implementation Requirements<br>for Protocol Layer and Adapter..... | 83        |
| 3.4        | Decision Table for Flit Format and Protocol.....                                       | 84        |
| 3.5        | State Machine Hierarchy .....                                                          | 88        |
| 3.6        | Power Management Link States .....                                                     | 89        |
| 3.7        | CRC Computation .....                                                                  | 91        |
| 3.8        | Retry Rules.....                                                                       | 92        |
| 3.9        | Runtime Link Testing using Parity .....                                                | 94        |
| <b>4.0</b> | <b>Logical Physical Layer.....</b>                                                     | <b>97</b> |
| 4.1        | Data and Sideband Transmission Flow .....                                              | 97        |
| 4.1.1      | Byte to Lane Mapping .....                                                             | 97        |
| 4.1.2      | Valid Framing .....                                                                    | 99        |
| 4.1.2.1    | Valid Framing for Retimers .....                                                       | 100       |
| 4.1.3      | Clock Gating .....                                                                     | 100       |
| 4.1.4      | Free Running Clock Mode .....                                                          | 101       |
| 4.1.5      | Sideband transmission .....                                                            | 101       |
| 4.1.5.1    | Sideband Performant Mode Operation (PMO) .....                                         | 101       |
| 4.2        | Lane Reversal .....                                                                    | 102       |
| 4.2.1      | Lane ID .....                                                                          | 103       |
| 4.3        | Interconnect redundancy remapping .....                                                | 105       |
| 4.3.1      | Data Lane repair .....                                                                 | 105       |
| 4.3.2      | Data Lane repair with Lane reversal .....                                              | 107       |
| 4.3.3      | Data Lane repair implementation.....                                                   | 107       |
| 4.3.3.1    | Single Lane repair .....                                                               | 107       |
| 4.3.3.2    | Two Lane repair.....                                                                   | 109       |
| 4.3.3.3    | Single Lane repair with Lane reversal .....                                            | 111       |
| 4.3.3.3.1  | x64 Advanced Package Pseudo Codes .....                                                | 111       |
| 4.3.3.3.2  | x32 Advanced Package Pseudo Codes .....                                                | 111       |
| 4.3.3.4    | Two Lane repair with Lane reversal .....                                               | 112       |
| 4.3.3.4.1  | x64 Advanced Package Pseudo Codes .....                                                | 112       |
| 4.3.3.4.2  | x32 Advanced Package Pseudo Codes .....                                                | 113       |
| 4.3.4      | Clock and Track Lane remapping .....                                                   | 114       |
| 4.3.5      | Clock and Track Lane repair implementation .....                                       | 115       |
| 4.3.6      | Valid Repair and implementation .....                                                  | 116       |
| 4.3.7      | Width Degrade in Standard Package Interfaces .....                                     | 117       |
| 4.4        | Data to Clock Training and Test Modes .....                                            | 117       |
| 4.4.1      | Scrambling and training pattern generation .....                                       | 119       |
| 4.5        | Link Initialization and Training.....                                                  | 122       |
| 4.5.1      | Link Training Basic Operations .....                                                   | 123       |
| 4.5.1.1    | Transmitter initiated Data to Clock Point Test.....                                    | 123       |
| 4.5.1.2    | Transmitter initiated Data to Clock Eye Width Sweep .....                              | 125       |
| 4.5.1.3    | Receiver initiated Data to Clock point test .....                                      | 126       |
| 4.5.1.4    | Receiver initiated Data to Clock Eye Width Sweep.....                                  | 127       |
| 4.5.2      | Link Training with Retimer .....                                                       | 128       |
| 4.5.3      | Link Training State Machine .....                                                      | 129       |
| 4.5.3.1    | RESET .....                                                                            | 131       |
| 4.5.3.2    | Sideband Initialization (SBINIT) .....                                                 | 132       |
| 4.5.3.3    | MBINIT.....                                                                            | 135       |
| 4.5.3.3.1  | MBINIT.PARAM .....                                                                     | 136       |
| 4.5.3.3.2  | MBINIT.CAL .....                                                                       | 145       |
| 4.5.3.3.3  | MBINIT.REPAIRCLK .....                                                                 | 145       |
| 4.5.3.3.4  | MBINIT.REPAIRVAL .....                                                                 | 148       |
| 4.5.3.3.5  | MBINIT.REVERSALMB .....                                                                | 150       |
| 4.5.3.3.6  | MBINIT.REPAIRMB .....                                                                  | 152       |
| 4.5.3.4    | MBTRAIN .....                                                                          | 154       |

|            |                                                                               |     |
|------------|-------------------------------------------------------------------------------|-----|
| 4.5.3.4.1  | MBTRAIN.VALVREF .....                                                         | 155 |
| 4.5.3.4.2  | MBTRAIN.DATAVREF .....                                                        | 156 |
| 4.5.3.4.3  | MBTRAIN.SPEEDIDLE .....                                                       | 157 |
| 4.5.3.4.4  | MBTRAIN.TXSELFCAL .....                                                       | 157 |
| 4.5.3.4.5  | MBTRAIN.RXCLKCAL .....                                                        | 157 |
| 4.5.3.4.6  | MBTRAIN.VALTRAINCENTER .....                                                  | 158 |
| 4.5.3.4.7  | MBTRAIN.VALTRAINVREF .....                                                    | 158 |
| 4.5.3.4.8  | MBTRAIN.DATATRAINCENTER1 .....                                                | 159 |
| 4.5.3.4.9  | MBTRAIN.DATATRAINVREF .....                                                   | 160 |
| 4.5.3.4.10 | MBTRAIN.RXDESKEW .....                                                        | 160 |
| 4.5.3.4.11 | MBTRAIN.DATATRAINCENTER2 .....                                                | 161 |
| 4.5.3.4.12 | MBTRAIN.LINKSPEED .....                                                       | 162 |
| 4.5.3.4.13 | MBTRAIN.REPAIR .....                                                          | 165 |
| 4.5.3.5    | LINKINIT .....                                                                | 166 |
| 4.5.3.6    | ACTIVE .....                                                                  | 166 |
| 4.5.3.7    | PHYRETRAIN .....                                                              | 166 |
| 4.5.3.7.1  | Adapter initiated PHY retrain .....                                           | 168 |
| 4.5.3.7.2  | PHY initiated PHY retrain .....                                               | 168 |
| 4.5.3.7.3  | Remote Die requested PHY retrain .....                                        | 169 |
| 4.5.3.7.4  | PHY retrain from LINKSPEED .....                                              | 169 |
| 4.5.3.8    | TRAINERROR .....                                                              | 169 |
| 4.5.3.9    | L1/L2 .....                                                                   | 170 |
| 4.6        | Runtime Recalibration .....                                                   | 170 |
| 4.7        | Multi-module Link .....                                                       | 170 |
| 4.7.1      | Multi-module initialization .....                                             | 171 |
| 4.7.1.1    | Sideband Assignment and Retimer Credits for Multi-module Configurations ..... | 174 |
| 4.7.1.2    | Examples of MMPL Synchronization .....                                        | 174 |
| 4.7.1.2.1  | Example 1: MMPL Resolution results in a Width Degrade per Module .....        | 175 |
| 4.7.1.2.2  | Example 2: MMPL Resolution results in a Speed Degrade .....                   | 176 |
| 4.7.1.2.3  | Example 3: MMPL Resolution results in a Module Disable .....                  | 176 |
| 4.7.2      | Multi-module Interoperability between x64 and x32 Advanced Packages .....     | 177 |
| 4.8        | Sideband PHY Arbitration between MPMs and Link Management Packets .....       | 178 |
| <b>5.0</b> | <b>Electrical Layer (2D and 2.5D)</b> .....                                   | 180 |
| 5.1        | Interoperability .....                                                        | 180 |
| 5.1.1      | Data rates .....                                                              | 180 |
| 5.1.2      | Reference Clock (REFCLK) .....                                                | 181 |
| 5.2        | Overview .....                                                                | 182 |
| 5.2.1      | Interface Overview .....                                                      | 182 |
| 5.2.2      | Electrical summary .....                                                      | 184 |
| 5.3        | Transmitter Specification .....                                               | 185 |
| 5.3.1      | Driver Topology .....                                                         | 185 |
| 5.3.2      | Transmitter Electrical parameters .....                                       | 186 |
| 5.3.3      | 24 GT/s and 32 GT/s Transmitter Equalization .....                            | 187 |
| 5.4        | Receiver Specification .....                                                  | 189 |
| 5.4.1      | Receiver Electrical Parameters .....                                          | 190 |
| 5.4.2      | Rx Termination .....                                                          | 190 |
| 5.4.3      | 24 and 32 GT/s Receiver Equalization .....                                    | 193 |
| 5.5        | Clocking .....                                                                | 193 |
| 5.5.1      | Track .....                                                                   | 194 |
| 5.6        | Supply noise and clock skew .....                                             | 196 |
| 5.7        | Ball-out and Channel Specification .....                                      | 197 |

|            |                                                                            |            |
|------------|----------------------------------------------------------------------------|------------|
| 5.7.1      | Voltage Transfer Function .....                                            | 199        |
| 5.7.2      | Advanced Package.....                                                      | 200        |
| 5.7.2.1    | Loss and Crosstalk Mask .....                                              | 201        |
| 5.7.2.2    | x64 Advanced Package Module Bump Map.....                                  | 201        |
| 5.7.2.3    | x32 Advanced Package Module Bump Map.....                                  | 210        |
| 5.7.2.4    | x64 and x32 Advanced Package Module Interoperability .....                 | 216        |
| 5.7.2.5    | Module Naming of Advanced Package Modules .....                            | 219        |
| 5.7.3      | Standard Package .....                                                     | 223        |
| 5.7.3.1    | x16 Standard Package Module Bump Map.....                                  | 224        |
| 5.7.3.2    | x8 Standard Package Module Bump Map .....                                  | 227        |
| 5.7.3.3    | x16 and x8 Standard Package Module Interoperability.....                   | 227        |
| 5.7.3.4    | Module Naming of Standard Package Modules .....                            | 228        |
| 5.7.3.4.1  | Module Degrade Rules .....                                                 | 232        |
| 5.7.4      | UCIE-S Sideband-only Port .....                                            | 234        |
| 5.8        | Tightly Coupled Mode.....                                                  | 235        |
| 5.9        | Interconnect redundancy Remapping .....                                    | 235        |
| 5.9.1      | Advanced Package Lane Remapping.....                                       | 235        |
| 5.9.2      | Standard Package Lane remapping .....                                      | 236        |
| 5.10       | BER requirements, CRC and retry .....                                      | 236        |
| 5.11       | Valid and Clock Gating .....                                               | 237        |
| 5.12       | Electrical Idle .....                                                      | 239        |
| 5.13       | Sideband signaling.....                                                    | 239        |
| 5.13.1     | Sideband Electrical Parameters .....                                       | 240        |
| 5.13.2     | Auxiliary Clock (AUXCLK) .....                                             | 241        |
| <b>6.0</b> | <b>UCIE-3D.....</b>                                                        | <b>242</b> |
| 6.1        | Introduction.....                                                          | 242        |
| 6.2        | UCIE-3D Features and Summary .....                                         | 242        |
| 6.3        | UCIE-3D Tx, Rx, and Clocking .....                                         | 244        |
| 6.4        | Electrical Specification.....                                              | 245        |
| 6.4.1      | Timing Budget .....                                                        | 245        |
| 6.4.2      | ESD and Energy Efficiency .....                                            | 247        |
| 6.4.3      | UCIE-3D Module and Bump Map .....                                          | 248        |
| 6.4.4      | Repair Strategy.....                                                       | 249        |
| 6.4.5      | Channel and Data Rate Extension .....                                      | 251        |
| <b>7.0</b> | <b>Sideband .....</b>                                                      | <b>252</b> |
| 7.1        | Protocol Specification .....                                               | 252        |
| 7.1.1      | Packet Types .....                                                         | 253        |
| 7.1.2      | Packet Formats .....                                                       | 256        |
| 7.1.2.1    | Register Access Packets .....                                              | 256        |
| 7.1.2.2    | Messages without Data .....                                                | 259        |
| 7.1.2.3    | Messages with data payloads.....                                           | 265        |
| 7.1.2.4    | Management Port Message (MPM) with Data .....                              | 274        |
| 7.1.2.4.1  | Common Fields in MPM Header of MPM<br>with Data Messages on Sideband ..... | 274        |
| 7.1.2.4.2  | Encapsulated MTP Message .....                                             | 275        |
| 7.1.2.4.3  | Vendor-defined Management Port<br>Gateway Message .....                    | 276        |
| 7.1.2.5    | MPMs without Data.....                                                     | 276        |
| 7.1.2.5.1  | Common Header Fields of MPM<br>without Data Messages on Sideband.....      | 277        |
| 7.1.2.5.2  | Management Port Gateway Capabilities Message....                           | 277        |
| 7.1.2.5.3  | Credit Return Message .....                                                | 278        |
| 7.1.2.5.4  | Init Done Message .....                                                    | 279        |
| 7.1.2.5.5  | PM Message .....                                                           | 279        |

|            |                                                                               |            |
|------------|-------------------------------------------------------------------------------|------------|
| 7.1.2.5.6  | Vendor-defined Management Port<br>Gateway Message.....                        | 279        |
| 7.1.3      | Flow Control and Data Integrity.....                                          | 280        |
| 7.1.3.1    | Flow Control and Data Integrity over FDI and RDI .....                        | 280        |
| 7.1.3.2    | Flow Control and Data Integrity over<br>UCIE sideband Link between dies ..... | 281        |
| 7.1.3.3    | End-to-End flow control and forward progress<br>for UCIE Link sideband.....   | 281        |
| 7.1.4      | Operation on RDI and FDI .....                                                | 284        |
| <b>8.0</b> | <b>System Architecture .....</b>                                              | <b>285</b> |
| 8.1        | UCIE Manageability .....                                                      | 285        |
| 8.1.1      | Overview .....                                                                | 285        |
| 8.1.2      | Theory of Operation.....                                                      | 286        |
| 8.1.3      | UCIE Management Transport .....                                               | 289        |
| 8.1.3.1    | UCIE Management Transport Packet .....                                        | 289        |
| 8.1.3.1.1  | Traffic Class and Packet Ordering Requirements....                            | 291        |
| 8.1.3.1.2  | Packet Length .....                                                           | 293        |
| 8.1.3.1.3  | Management Protocol.....                                                      | 293        |
| 8.1.3.2    | Management Network ID .....                                                   | 294        |
| 8.1.3.3    | Routing .....                                                                 | 295        |
| 8.1.3.3.1  | Routing of a Packet from a Management Entity<br>within the Chiplet .....      | 295        |
| 8.1.3.3.2  | Routing of a Packet Received<br>on a Management Port .....                    | 297        |
| 8.1.3.4    | Packet Integrity Protection .....                                             | 297        |
| 8.1.3.4.1  | CRC Integrity Protection .....                                                | 297        |
| 8.1.3.5    | Access Control.....                                                           | 298        |
| 8.1.3.5.1  | Standard Asset Classes .....                                                  | 300        |
| 8.1.3.5.2  | Security Director .....                                                       | 302        |
| 8.1.3.6    | Initialization and Configuration .....                                        | 302        |
| 8.1.3.6.1  | Management Capability Directory.....                                          | 304        |
| 8.1.3.6.2  | Chiplet Capability Structure.....                                             | 306        |
| 8.1.3.6.3  | Access Control Capability Structure .....                                     | 315        |
| 8.1.3.6.4  | Security Clearance Group Capability Structure .....                           | 322        |
| 8.1.4      | UCIE Memory Access Protocol .....                                             | 323        |
| 8.1.4.1    | UCIE Memory Access Protocol Packets .....                                     | 324        |
| 8.1.4.1.1  | UCIE Memory Request Packet.....                                               | 324        |
| 8.1.4.1.2  | UCIE Memory Access Response Packet .....                                      | 326        |
| 8.1.4.2    | UCIE Memory Access Protocol Capability Structure .....                        | 328        |
| 8.2        | Management Transport Packet (MTP) Encapsulation .....                         | 331        |
| 8.2.1      | MTP Encapsulation Architecture Overview .....                                 | 331        |
| 8.2.2      | Management Port Messages.....                                                 | 335        |
| 8.2.2.1    | Sideband .....                                                                | 335        |
| 8.2.2.2    | Mainband.....                                                                 | 336        |
| 8.2.2.2.1  | MPMs with Data.....                                                           | 336        |
| 8.2.2.2.2  | MPMs without Data .....                                                       | 338        |
| 8.2.3      | Management Transport Path Setup .....                                         | 341        |
| 8.2.3.1    | Sideband .....                                                                | 341        |
| 8.2.3.1.1  | Negotiation Phase Steps .....                                                 | 341        |
| 8.2.3.1.2  | Initialization Phase Steps .....                                              | 341        |
| 8.2.3.1.3  | Other Sideband Management Transport<br>Path Rules .....                       | 346        |
| 8.2.3.2    | Mainband.....                                                                 | 346        |
| 8.2.3.2.1  | Negotiation Phase Steps .....                                                 | 346        |
| 8.2.3.2.2  | Initialization Phase Steps .....                                              | 346        |

|           |                                                                                             |     |
|-----------|---------------------------------------------------------------------------------------------|-----|
| 8.2.3.2.3 | Other Mainband Management Transport Path Rules .....                                        | 349 |
| 8.2.4     | Common Rules for Management Transport over Sideband and Mainband .....                      | 349 |
| 8.2.4.1   | Management Packet Flow Control .....                                                        | 349 |
| 8.2.4.2   | Segmentation.....                                                                           | 351 |
| 8.2.4.3   | Interleaving and Multi-module Sideband and Multi-stack Mainband Ordering.....               | 352 |
|           | 8.2.4.3.1 Transmitter Rules .....                                                           | 352 |
|           | 8.2.4.3.2 Receiver Rules .....                                                              | 353 |
| 8.2.4.4   | 'Init Done' Timeout Flow .....                                                              | 355 |
| 8.2.5     | Other Management Transport Details .....                                                    | 355 |
| 8.2.5.1   | Sideband .....                                                                              | 355 |
|           | 8.2.5.1.1 Management Port Gateway Flow Control over RDI..                                   | 355 |
|           | 8.2.5.1.2 MPMs with Data Length Rules.....                                                  | 355 |
|           | 8.2.5.1.3 Sideband Runtime Management Transport Path Monitoring — Heartbeat Mechanism ..... | 356 |
|           | 8.2.5.1.4 Sideband Management Path Power Management Rules .....                             | 357 |
|           | 8.2.5.1.5 Management Port Gateway Mux Arbitration .....                                     | 358 |
| 8.2.5.2   | Mainband.....                                                                               | 358 |
|           | 8.2.5.2.1 NOP Message .....                                                                 | 358 |
|           | 8.2.5.2.2 Credit Return DWORD Format .....                                                  | 358 |
|           | 8.2.5.2.3 Management Flit Formats .....                                                     | 359 |
|           | 8.2.5.2.4 L1/L2 Link States and Management Transport .....                                  | 362 |
|           | 8.2.5.2.5 Link Reset/Link Disable and Management Transport.....                             | 362 |
| 8.2.6     | Retimers and Management Transport.....                                                      | 363 |
| 8.3       | UCIE Debug and Test Architecture (UDA).....                                                 | 363 |
| 8.3.1     | Overview .....                                                                              | 363 |
| 8.3.1.1   | DFx Management Hub (DMH) .....                                                              | 364 |
| 8.3.1.2   | DFx Management Spoke (DMS).....                                                             | 364 |
| 8.3.1.3   | Supported Protocols .....                                                                   | 365 |
|           | 8.3.1.3.1 UCIE Memory Access Protocol (UMAP) .....                                          | 365 |
|           | 8.3.1.3.2 Vendor-defined Test and Debug Protocol.....                                       | 365 |
| 8.3.1.4   | UDM and UCIE Memory Access Protocol Message Encapsulation over UCIE .....                   | 366 |
| 8.3.1.5   | UCIE Test Port Options and Other Considerations .....                                       | 366 |
|           | 8.3.1.5.1 Determinism Considerations.....                                                   | 366 |
| 8.3.1.6   | DFx Security .....                                                                          | 366 |
| 8.3.2     | Sort/Pre-bond Chiplet Testing with UDA .....                                                | 367 |
| 8.3.3     | SiP-level Chiplet Testing with UDA .....                                                    | 368 |
| 8.3.4     | System Debug with UDA .....                                                                 | 369 |
| 8.3.5     | DMH/DMS Registers .....                                                                     | 369 |
| 8.3.5.1   | DMH/DMS Register Address Space and Access Mechanism .....                                   | 369 |
| 8.3.5.2   | DMH Registers.....                                                                          | 370 |
|           | 8.3.5.2.1 Ver (Offset 00h) .....                                                            | 371 |
|           | 8.3.5.2.2 Capability ID (Offset 02h) .....                                                  | 371 |
|           | 8.3.5.2.3 DBG_CAP — Debug Capabilities (Offset 04h) .....                                   | 372 |
|           | 8.3.5.2.4 DBG_CTL — Debug Control (Offset 08h) .....                                        | 372 |
|           | 8.3.5.2.5 DBG_STS — Debug Status (Offset Ah).....                                           | 372 |
|           | 8.3.5.2.6 DMH_Length_Low — DMH Register Space Length Low (Offset 10h).....                  | 372 |
|           | 8.3.5.2.7 DMH_Length_High — DMH Register Space Length High (Offset 14h) .....               | 372 |

|                                               |                                                                                                                                                                   |            |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 8.3.5.2.8                                     | DMH_Ext_Cap_Low — DMH Extended Capability Pointer Low (Offset 18h).....                                                                                           | 373        |
| 8.3.5.2.9                                     | DMH_Ext_Cap_High — DMH Extended Capability Pointer High (Offset 1Ch).....                                                                                         | 373        |
| 8.3.5.2.10                                    | DMS_Start_Low — DMS Starting Address Low (Offset 20h) .....                                                                                                       | 373        |
| 8.3.5.2.11                                    | DMS_Start_High — DMS Starting Address High (Offset 24h) .....                                                                                                     | 373        |
| 8.3.5.3                                       | DMS Registers .....                                                                                                                                               | 373        |
| 8.3.5.3.1                                     | "Empty" Spoke Registers .....                                                                                                                                     | 374        |
| 8.3.5.3.2                                     | Common DMS Registers for All Non-empty Spokes .....                                                                                                               | 374        |
| 8.3.5.3.3                                     | DMS Registers of UCIE Spoke Types ('Spoke Type' = 0 through 2) .....                                                                                              | 379        |
| 8.3.5.3.4                                     | DMS Registers of Vendor-defined Spoke Types ('Spoke Type' = 128 through 255) .....                                                                                | 383        |
| 8.3.5.3.5                                     | DMS Register Implementation in UCIE Adapter and in UCIE Physical Layer.....                                                                                       | 384        |
| <b>9.0 Configuration and Parameters .....</b> |                                                                                                                                                                   | <b>385</b> |
| 9.1                                           | High-level Software View of UCIE.....                                                                                                                             | 385        |
| 9.2                                           | SW Discovery of UCIE Links .....                                                                                                                                  | 386        |
| 9.3                                           | Register Location Details and Access Mechanism.....                                                                                                               | 386        |
| 9.4                                           | Software view Examples.....                                                                                                                                       | 388        |
| 9.5                                           | UCIE Registers .....                                                                                                                                              | 391        |
| 9.5.1                                         | UCIE Link DVSEC .....                                                                                                                                             | 391        |
| 9.5.1.1                                       | PCI Express Extended Capability Header (Offset 0h) .....                                                                                                          | 393        |
| 9.5.1.2                                       | Designated Vendor Specific Header 1, 2 (Offsets 4h and 8h) .....                                                                                                  | 393        |
| 9.5.1.3                                       | Capability Descriptor (Offset Ah) .....                                                                                                                           | 394        |
| 9.5.1.4                                       | UCIE Link DVSEC - UCIE Link Capability (Offset Ch).....                                                                                                           | 395        |
| 9.5.1.5                                       | UCIE Link DVSEC - UCIE Link Control (Offset 10h).....                                                                                                             | 396        |
| 9.5.1.6                                       | UCIE Link DVSEC - UCIE Link Status (Offset 14h).....                                                                                                              | 398        |
| 9.5.1.7                                       | UCIE Link DVSEC - Link Event Notification Control (Offset 18h) ..                                                                                                 | 401        |
| 9.5.1.8                                       | UCIE Link DVSEC - Error Notification Control (Offset 1Ah) .....                                                                                                   | 401        |
| 9.5.1.9                                       | UCIE Link DVSEC - Register Locator 0, 1, 2, 3 Low<br>(Offset 1Ch and when Register Locators 1, 2, 3<br>are present Offsets 24h, 2Ch, and 34h respectively) .....  | 405        |
| 9.5.1.10                                      | UCIE Link DVSEC - Register Locator 0, 1, 2, 3 High<br>(Offset 20h and when Register Locators 1, 2, 3<br>Are Present Offsets 28h, 30h, and 38h respectively) ..... | 406        |
| 9.5.1.11                                      | UCIE Link DVSEC - Sideband Mailbox Index Low<br>(Offset is design dependent).....                                                                                 | 406        |
| 9.5.1.12                                      | UCIE Link DVSEC - Sideband Mailbox Index High<br>(Offset is design dependent).....                                                                                | 407        |
| 9.5.1.13                                      | UCIE Link DVSEC - Sideband Mailbox Data Low<br>(Offset is design dependent).....                                                                                  | 407        |
| 9.5.1.14                                      | UCIE Link DVSEC - Sideband Mailbox Data High<br>(Offset is design dependent).....                                                                                 | 407        |
| 9.5.1.15                                      | UCIE Link DVSEC - Sideband Mailbox Control<br>(Offset is design dependent).....                                                                                   | 408        |
| 9.5.1.16                                      | UCIE Link DVSEC - Sideband Mailbox Status<br>(Offset is design dependent).....                                                                                    | 408        |
| 9.5.1.17                                      | UCIE Link DVSEC - Requester ID (Offset is design dependent) ...                                                                                                   | 408        |
| 9.5.1.18                                      | UCIE Link DVSEC - Associated Port Numbers<br>(Offset is design dependent).....                                                                                    | 409        |
| 9.5.1.19                                      | Examples of setting the Length field<br>in DVSEC for various Scenarios .....                                                                                      | 409        |
| 9.5.2                                         | UCIE Switch Register Block (UiSRB) DVSEC Capability .....                                                                                                         | 409        |

|            |                                                                        |     |
|------------|------------------------------------------------------------------------|-----|
| 9.5.2.1    | PCI Express Extended Capability Header (Offset 0h) .....               | 409 |
| 9.5.2.2    | Designated Vendor Specific Header 1, 2 (Offsets 4h and 8h) .....       | 409 |
| 9.5.2.3    | PCIe Switch Register Block (UiSRB) Base Address (Offset Ch)....        | 410 |
| 9.5.3      | D2D/PHY Register Block .....                                           | 411 |
| 9.5.3.1    | PCIe Register Block Header.....                                        | 411 |
| 9.5.3.2    | Uncorrectable Error Status Register (Offset 10h) .....                 | 411 |
| 9.5.3.3    | Uncorrectable Error Mask Register (Offset 14h).....                    | 412 |
| 9.5.3.4    | Uncorrectable Error Severity Register (Offset 18h) .....               | 413 |
| 9.5.3.5    | Correctable Error Status Register (Offset 1Ch) .....                   | 413 |
| 9.5.3.6    | Correctable Error Mask Register (Offset 20h) .....                     | 414 |
| 9.5.3.7    | Header Log 1 Register (Offset 24h) .....                               | 414 |
| 9.5.3.8    | Header Log 2 Register (Offset 2Ch) .....                               | 415 |
| 9.5.3.9    | Error and Link Testing Control Register (Offset 30h). ....             | 417 |
| 9.5.3.10   | Runtime Link Testing Parity Log 0 (Offset 34h) .....                   | 418 |
| 9.5.3.11   | Runtime Link Testing Parity Log 1 (Offset 3Ch) .....                   | 418 |
| 9.5.3.12   | Runtime Link Testing Parity Log 2 (Offset 44h) .....                   | 418 |
| 9.5.3.13   | Runtime Link Testing Parity Log 3 (Offset 4Ch) .....                   | 419 |
| 9.5.3.14   | Advertised Adapter Capability Log (Offset 54h) .....                   | 419 |
| 9.5.3.15   | Finalized Adapter Capability Log (Offset 5Ch).....                     | 419 |
| 9.5.3.16   | Advertised CXL Capability Log (Offset 64h).....                        | 419 |
| 9.5.3.17   | Finalized CXL Capability Log (Offset 6Ch) .....                        | 419 |
| 9.5.3.18   | Advertised Multi-Protocol Capability Log Register (Offset 78h)....     | 420 |
| 9.5.3.19   | Finalized Multi-Protocol Capability Log Register (Offset 80h) .....    | 420 |
| 9.5.3.20   | Advertised CXL Capability Log Register for Stack 1 (Offset 88h) .      | 420 |
| 9.5.3.21   | Finalized CXL Capability Log Register for Stack 1 (Offset 90h)....     | 420 |
| 9.5.3.22   | PHY Capability (Offset 1000h).....                                     | 421 |
| 9.5.3.23   | PHY Control (Offset 1004h) .....                                       | 422 |
| 9.5.3.24   | PHY Status (Offset 1008h) .....                                        | 423 |
| 9.5.3.25   | PHY Initialization and Debug (Offset 100Ch) .....                      | 424 |
| 9.5.3.26   | Training Setup 1 (Offset 1010h).....                                   | 425 |
| 9.5.3.27   | Training Setup 2 (Offset 1020h).....                                   | 425 |
| 9.5.3.28   | Training Setup 3 (Offset 1030h).....                                   | 426 |
| 9.5.3.29   | Training Setup 4 (Offset 1050h).....                                   | 426 |
| 9.5.3.30   | Current Lane Map Module 0 (Offset 1060h) .....                         | 427 |
| 9.5.3.31   | Current Lane Map Module 1 (Offset 1068h) .....                         | 427 |
| 9.5.3.32   | Current Lane Map Module 2 (Offset 1070h) .....                         | 427 |
| 9.5.3.33   | Current Lane Map Module 3 (Offset 1078h) .....                         | 427 |
| 9.5.3.34   | Error Log 0 (Offset 1080h) .....                                       | 428 |
| 9.5.3.35   | Error Log 1 (Offset 1090h) .....                                       | 429 |
| 9.5.3.36   | Runtime Link Test Control (Offset 1100h).....                          | 429 |
| 9.5.3.37   | Runtime Link Test Status (Offset 1108h).....                           | 431 |
| 9.5.3.38   | Mainband Data Repair (Offset 110Ch) .....                              | 431 |
| 9.5.3.39   | Clock, Track, Valid and Sideband Repair (Offset 1134h) .....           | 433 |
| 9.5.3.40   | PCIe Link Health Monitor (UHM) DVSEC .....                             | 434 |
| 9.5.3.40.1 | UHM Status (Offset Eh) .....                                           | 435 |
| 9.5.3.40.2 | Eye Margin (Starting Offset 18h) .....                                 | 435 |
| 9.5.4      | Test/Compliance Register Block.....                                    | 436 |
| 9.5.4.1    | PCIe Register Block Header.....                                        | 437 |
| 9.5.4.2    | D2D Adapter Test/Compliance Register Block Offset .....                | 437 |
| 9.5.4.3    | PHY Test/Compliance Register Block Offset.....                         | 437 |
| 9.5.4.4    | D2D Adapter Test/Compliance Register Block.....                        | 438 |
| 9.5.4.4.1  | Adapter Compliance Control .....                                       | 438 |
| 9.5.4.4.2  | Flit Tx Injection Control .....                                        | 439 |
| 9.5.4.4.3  | Adapter Test Status (Offset 30h from D2DOFF).....                      | 440 |
| 9.5.4.4.4  | Link State Injection Control Stack 0<br>(Offset 34h from D2DOFF) ..... | 441 |
| 9.5.4.4.5  | Link State Injection Control Stack 1<br>(Offset 38h from D2DOFF) ..... | 442 |
| 9.5.4.4.6  | Retry Injection Control (Offset 40h from D2DOFF)..                     | 442 |

|             |                                                                                            |            |
|-------------|--------------------------------------------------------------------------------------------|------------|
| 9.5.4.5     | PHY Test/Compliance Register Block .....                                                   | 444        |
| 9.5.4.5.1   | Physical Layer Compliance Control 1 (Offsets 000h, 400h, 800h, and C00h from PHYOFF) ..... | 444        |
| 9.5.4.5.2   | Physical Layer Compliance Control 2 (Offsets 008h, 408h, 808h, and C08h from PHYOFF) ..... | 446        |
| 9.5.4.5.3   | Physical Layer Compliance Status 1 (Offsets 010h, 410h, 810h, and C10h from PHYOFF) .....  | 447        |
| 9.5.4.5.4   | Physical Layer Compliance Status 2 (Offsets 018h, 418h, 818h, and C18h from PHYOFF) .....  | 447        |
| 9.5.4.5.5   | Physical Layer Compliance Status 3 (Offsets 020h, 420h, 820h, and C20h from PHYOFF) .....  | 448        |
| 9.5.5       | Implementation Specific Register Blocks.....                                               | 448        |
| 9.6         | PCIe Link Registers in Streaming Mode and System SW/FW Implications .....                  | 449        |
| 9.7         | MSI and MSI-X Capability in Hosts/Switches for PCIe Interrupt.....                         | 450        |
| 9.8         | PCIe Early Discovery Table (UEDT) .....                                                    | 450        |
| <b>10.0</b> | <b>Interface Definitions.....</b>                                                          | <b>452</b> |
| 10.1        | Raw Die-to-Die Interface (RDI) .....                                                       | 452        |
| 10.1.1      | Interface reset requirements.....                                                          | 460        |
| 10.1.2      | Interface clocking requirements .....                                                      | 460        |
| 10.1.3      | Dynamic clock gating.....                                                                  | 461        |
| 10.1.3.1    | Rules and description for<br>lp_wake_req/pl_wake_ack handshake .....                       | 461        |
| 10.1.3.2    | Rules and description for pl_clk_req/lp_clk_ack handshake.....                             | 461        |
| 10.1.4      | Data Transfer .....                                                                        | 463        |
| 10.1.5      | RDI State Machine.....                                                                     | 465        |
| 10.1.6      | RDI bring up flow .....                                                                    | 466        |
| 10.1.7      | RDI PM flow.....                                                                           | 467        |
| 10.2        | Flit-Aware Die-to-Die Interface (FDI).....                                                 | 471        |
| 10.2.1      | Interface reset requirements.....                                                          | 479        |
| 10.2.2      | Interface clocking requirements .....                                                      | 479        |
| 10.2.3      | Dynamic clock gating.....                                                                  | 479        |
| 10.2.3.1    | Rules and description for<br>lp_wake_req/pl_wake_ack handshake .....                       | 480        |
| 10.2.3.2    | Rules and description for pl_clk_req/lp_clk_ack handshake.....                             | 480        |
| 10.2.4      | Data Transfer .....                                                                        | 481        |
| 10.2.4.1    | DLLP transfer rules for 256B Flit Mode .....                                               | 482        |
| 10.2.5      | Examples of pl_flit_cancel Timing Relationships.....                                       | 483        |
| 10.2.6      | FDI State Machine.....                                                                     | 484        |
| 10.2.7      | Rx_active_req/Sts Handshake.....                                                           | 484        |
| 10.2.8      | FDI Bring up flow .....                                                                    | 485        |
| 10.2.9      | FDI PM Flow .....                                                                          | 487        |
| 10.3        | Common rules for FDI and RDI.....                                                          | 491        |
| 10.3.1      | Byte Mapping for FDI and RDI.....                                                          | 491        |
| 10.3.2      | Stallreq/Ack Mechanism .....                                                               | 495        |
| 10.3.3      | State Request and Status .....                                                             | 496        |
| 10.3.3.1    | Reset State rules .....                                                                    | 497        |
| 10.3.3.2    | Active State rules.....                                                                    | 498        |
| 10.3.3.3    | PM Entry/Exit Rules.....                                                                   | 498        |
| 10.3.3.4    | Retrain State Rules .....                                                                  | 498        |
| 10.3.3.5    | LinkReset State Rules .....                                                                | 499        |
| 10.3.3.6    | Disabled State Rules.....                                                                  | 500        |
| 10.3.3.7    | LinkError State Rules.....                                                                 | 500        |
| 10.3.3.8    | Common State Rules .....                                                                   | 501        |
| 10.3.4      | Example Flow Diagrams .....                                                                | 504        |
| 10.3.4.1    | LinkReset Entry and Exit .....                                                             | 504        |

|             |                                                       |            |
|-------------|-------------------------------------------------------|------------|
| 10.3.4.2    | LinkError .....                                       | 505        |
| 10.3.4.3    | Example of L2 Cross Product with Retrain on RDI ..... | 506        |
| 10.3.4.4    | L2 Exit Example for RDI .....                         | 507        |
| <b>11.0</b> | <b>Compliance.....</b>                                | <b>508</b> |
| 11.1        | Protocol Layer Compliance .....                       | 509        |
| 11.2        | Adapter Compliance.....                               | 509        |
| 11.3        | PHY Compliance .....                                  | 510        |
| <b>A</b>    | <b>CXL/PCIe Register applicability to UCIe .....</b>  | <b>511</b> |
| A.1         | CXL Registers applicability to UCIe .....             | 511        |
| A.2         | PCIe Register applicability to UCIe .....             | 511        |
| A.3         | PCIe/CXL registers that need to be part of D2D .....  | 513        |
| <b>B</b>    | <b>AIB Interoperability .....</b>                     | <b>514</b> |
| B.1         | AIB Signal Mapping .....                              | 514        |
| B.1.1       | Data path.....                                        | 514        |
| B.1.2       | Always high Valid .....                               | 514        |
| B.1.3       | Sideband.....                                         | 514        |
| B.1.4       | Raw Die-to-Die interface .....                        | 515        |
| B.2         | Initialization.....                                   | 516        |
| B.3         | Bump Map .....                                        | 516        |

# Figures

---

|      |                                                                                                                      |    |
|------|----------------------------------------------------------------------------------------------------------------------|----|
| 1-1  | A Package Composed of CPU Dies, Accelerator Die(s),<br>and I/O Tile Die Connected through UCIe .....                 | 36 |
| 1-2  | UCIe enabling long-reach connectivity at Rack/Pod Level .....                                                        | 37 |
| 1-3  | Standard Package interface .....                                                                                     | 37 |
| 1-4  | Advanced Package interface: Example 1 .....                                                                          | 38 |
| 1-5  | Advanced Package interface: Example 2 .....                                                                          | 38 |
| 1-6  | Advanced Package interface: Example 3 .....                                                                          | 38 |
| 1-7  | Example of UCIe-3D .....                                                                                             | 39 |
| 1-8  | UCIe Layers and functionalities .....                                                                                | 40 |
| 1-9  | Physical Layer components .....                                                                                      | 41 |
| 1-10 | Single module configuration: Advanced Package .....                                                                  | 42 |
| 1-11 | Single module configuration: Standard Package .....                                                                  | 43 |
| 1-12 | Two-module configuration for Standard Package .....                                                                  | 43 |
| 1-13 | Four-module configuration for Standard Package .....                                                                 | 43 |
| 1-14 | Example of a Two-module Configuration for Advanced Package .....                                                     | 44 |
| 1-15 | One-port Sideband-only Link .....                                                                                    | 44 |
| 1-16 | Two-port Sideband-only Link .....                                                                                    | 44 |
| 1-17 | Four-port Sideband-only Link.....                                                                                    | 45 |
| 1-18 | Block Diagram for UCIe Retimer Connection .....                                                                      | 45 |
| 2-1  | Color-coding Convention in Flit Format Byte Map Figures .....                                                        | 50 |
| 2-2  | 68B Flit Format on FDI .....                                                                                         | 54 |
| 3-1  | Functionalities in the Die-to-Die Adapter .....                                                                      | 56 |
| 3-2  | Example Configurations .....                                                                                         | 59 |
| 3-3  | Stages of UCIe Link Initialization .....                                                                             | 60 |
| 3-4  | Parameter Exchange for CXL or PCIe (i.e., "68B Flit Mode"<br>or "CXL 256B Flit Mode" is 1 in {FinCap.Adapter}) ..... | 64 |
| 3-5  | Both Stacks are CXL or PCIe.....                                                                                     | 66 |
| 3-6  | Stack 0 is PCIe, Stack 1 is Streaming .....                                                                          | 67 |
| 3-7  | Stack 0 is Streaming, Stack 1 is PCIe .....                                                                          | 67 |
| 3-8  | Both Stacks are Streaming .....                                                                                      | 68 |
| 3-9  | Stack 0 is Streaming, Stack 1 is CXL .....                                                                           | 69 |
| 3-10 | Format 1: Raw Format .....                                                                                           | 70 |
| 3-11 | Format 2: 68B Flit Format .....                                                                                      | 73 |
| 3-12 | Format 2: 68B Flit Format PDS Example 1 .....                                                                        | 74 |
| 3-13 | Format 2: 68B Flit Format PDS Example 2 — Extra 0s Padded<br>to Make the Data Transfer a Multiple of 256B .....      | 74 |
| 3-14 | Format 3: Standard 256B End Header Flit Format for PCIe .....                                                        | 76 |
| 3-15 | Format 3: Standard 256B End Header Flit Format for Streaming Protocol .....                                          | 76 |
| 3-16 | Format 3: Standard 256B End Header Flit Format<br>for Management Transport Protocol .....                            | 76 |
| 3-17 | Format 4: Standard 256B Start Header Flit Format<br>for CXL.cachemem or Streaming Protocol .....                     | 77 |
| 3-18 | Format 4: Standard 256B Start Header Flit Format for CXL.io or PCIe .....                                            | 77 |
| 3-19 | Format 4: Standard 256B Start Header Flit Format<br>for Management Transport Protocol .....                          | 77 |
| 3-20 | Format 5: Latency-Optimized 256B without Optional Bytes Flit Format for CXL.io ....                                  | 80 |
| 3-21 | Format 5: Latency-Optimized 256B without Optional Bytes Flit Format<br>for CXL.cachemem and Streaming Protocol ..... | 81 |
| 3-22 | Format 5: Latency-Optimized 256B without Optional Bytes Flit Format<br>for Management Transport Protocol .....       | 81 |

|      |                                                                                                          |     |
|------|----------------------------------------------------------------------------------------------------------|-----|
| 3-23 | Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for CXL.io or PCIe .....                | 81  |
| 3-24 | Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for CXL.cachemem .....                  | 82  |
| 3-25 | Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for Streaming Protocol .....            | 82  |
| 3-26 | Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for Management Transport Protocol ..... | 82  |
| 3-27 | State Machine Hierarchy Examples .....                                                                   | 88  |
| 3-28 | Example of Hierarchical PM Entry for CXL .....                                                           | 90  |
| 3-29 | Diagram of CRC Calculation .....                                                                         | 91  |
| 3-30 | Successful Parity Feature negotiation between Die 1 Tx and Die 0 Rx .....                                | 95  |
| 3-31 | Unsuccessful Parity Feature negotiation between Die 1 Tx and Die 0 Rx .....                              | 96  |
| 4-1  | Bit arrangement within a byte transfer .....                                                             | 97  |
| 4-2  | Byte map for x64 interface .....                                                                         | 98  |
| 4-3  | Byte map for x32 interface .....                                                                         | 98  |
| 4-4  | Byte map for x16 interface .....                                                                         | 98  |
| 4-5  | Byte to Lane mapping for Standard package x16 degraded to x8 .....                                       | 99  |
| 4-6  | Valid framing example .....                                                                              | 100 |
| 4-7  | Clock gating .....                                                                                       | 100 |
| 4-8  | Example 64-bit Sideband Serial Packet Transfer .....                                                     | 101 |
| 4-9  | Sideband Packet Transmission: Back-to-Back .....                                                         | 101 |
| 4-10 | Example 64-bit Sideband Serial Packet Transfer in Sideband Performant Mode .....                         | 102 |
| 4-11 | Sideband Packet Transmission: Back-to-Back in Sideband Performant Mode .....                             | 102 |
| 4-12 | Data Lane remapping possibilities to fix potential defects .....                                         | 105 |
| 4-13 | Data Lane remapping: Mux chain .....                                                                     | 106 |
| 4-14 | Example of Single Lane failure remapping .....                                                           | 108 |
| 4-15 | Example of Single Lane remapping implementation .....                                                    | 108 |
| 4-16 | Example of Two Lane failure remapping .....                                                              | 110 |
| 4-17 | Example of Two Lane remapping implementation .....                                                       | 110 |
| 4-18 | Clock and Track repair .....                                                                             | 114 |
| 4-19 | Clock and track repair: Differential Rx .....                                                            | 114 |
| 4-20 | Clock and track repair: Pseudo Differential Rx .....                                                     | 114 |
| 4-21 | Clock and Track Lane repair scheme .....                                                                 | 115 |
| 4-22 | Clock and track repair: CKP repair .....                                                                 | 115 |
| 4-23 | Clock and track repair: CKN repair .....                                                                 | 116 |
| 4-24 | Clock and track repair: Track repair .....                                                               | 116 |
| 4-25 | Valid repair: Normal Path .....                                                                          | 116 |
| 4-26 | Valid Repair: Repair Path .....                                                                          | 117 |
| 4-27 | Test and training logic .....                                                                            | 118 |
| 4-28 | Lane failure detection .....                                                                             | 118 |
| 4-29 | All Lane error detection .....                                                                           | 119 |
| 4-30 | LFSR implementation .....                                                                                | 120 |
| 4-31 | LFSR alternate implementation .....                                                                      | 121 |
| 4-32 | Example Retimer bring up when performing speed/width match .....                                         | 128 |
| 4-33 | Link Training State Machine .....                                                                        | 130 |
| 4-34 | MBINIT: Mainband Initialization and Repair Flow .....                                                    | 136 |
| 4-35 | Example Sideband Management Transport Protocol Negotiation – Single-module Scenario .....                | 138 |
| 4-36 | Example Sideband Management Transport Protocol Negotiation – Two-module Scenario .....                   | 139 |
| 4-37 | Example Sideband MPM Logical Flow with Two Modules and No Module Reversal ...                            | 141 |
| 4-38 | Example Sideband MPM Logical Flow with Two Modules and Module Reversal .....                             | 141 |
| 4-39 | MBINIT "Stall" Example 1 .....                                                                           | 143 |
| 4-40 | MBINIT "Stall" Example 2 .....                                                                           | 144 |

|      |                                                                                                                                                                                                  |     |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 4-41 | Mainband Training.....                                                                                                                                                                           | 155 |
| 4-42 | Example of Byte Mapping for Matching Module IDs .....                                                                                                                                            | 171 |
| 4-43 | Example of Byte Mapping for Differing Module IDs .....                                                                                                                                           | 171 |
| 4-44 | Example of Width Degradation with Byte Mapping for Differing Module IDs .....                                                                                                                    | 172 |
| 4-45 | Example of Byte Mapping with Module Disable .....                                                                                                                                                | 172 |
| 4-46 | Decision Flow Chart for Multi-module Advanced Package .....                                                                                                                                      | 173 |
| 4-47 | Decision Flow Chart for Multi-module Standard Package .....                                                                                                                                      | 174 |
| 4-48 | Implementation Example Showing Two Different Operating Modes<br>of the Same Hardware Implementation .....                                                                                        | 177 |
| 4-49 | RDI Byte-to-Module Assignment Example for x64 Interop with x32 .....                                                                                                                             | 178 |
| 4-50 | Example of Encapsulated MTPs Transmitted on Sideband Link<br>without Sideband PMO .....                                                                                                          | 179 |
| 4-51 | Example of a Large Management Packet Split into Two Encapsulated<br>MTPs, with No Segmentation, No Sideband PMO, and with<br>Two Link Management Packets between the Two Encapsulated MTPs ..... | 179 |
| 5-1  | Example Common Reference Clock .....                                                                                                                                                             | 181 |
| 5-2  | x64 or x32 Advanced Package Module .....                                                                                                                                                         | 183 |
| 5-3  | x16 or x8 Standard Package Module .....                                                                                                                                                          | 183 |
| 5-4  | Transmitter .....                                                                                                                                                                                | 185 |
| 5-5  | Transmitter driver example circuit .....                                                                                                                                                         | 186 |
| 5-6  | Transmitter de-emphasis .....                                                                                                                                                                    | 188 |
| 5-7  | Transmitter de-emphasis waveform.....                                                                                                                                                            | 188 |
| 5-8  | Receiver topology .....                                                                                                                                                                          | 189 |
| 5-9  | Receiver Termination Map for Table 5-6 (Tx Swing = 0.4 V) .....                                                                                                                                  | 191 |
| 5-10 | Receiver termination .....                                                                                                                                                                       | 191 |
| 5-11 | Receiver termination map for Table 5-7 (TX Swing = 0.85 V) .....                                                                                                                                 | 192 |
| 5-12 | Example CTLE .....                                                                                                                                                                               | 193 |
| 5-13 | Clocking architecture .....                                                                                                                                                                      | 194 |
| 5-14 | Track Usage Example .....                                                                                                                                                                        | 195 |
| 5-15 | Example Eye diagram .....                                                                                                                                                                        | 197 |
| 5-16 | Example Eye Simulation Setup.....                                                                                                                                                                | 198 |
| 5-17 | Circuit for VTF calculation .....                                                                                                                                                                | 199 |
| 5-18 | Loss and Crosstalk Mask .....                                                                                                                                                                    | 201 |
| 5-19 | Viewer Orientation Looking at the Defined UCIe Bump Matrix .....                                                                                                                                 | 201 |
| 5-20 | 10-column x64 Advanced Package Bump Map .....                                                                                                                                                    | 203 |
| 5-21 | 16-column x64 Advanced Package Bump Map .....                                                                                                                                                    | 204 |
| 5-22 | 8-column x64 Advanced Package Bump Map .....                                                                                                                                                     | 205 |
| 5-23 | 10-column x64 Advanced Package Bump map: Signal exit order .....                                                                                                                                 | 206 |
| 5-24 | 10-column x64 Advanced Package Bump Map Example<br>for 32 GT/s Implementation .....                                                                                                              | 207 |
| 5-25 | 16-column x64 Advanced Package Bump Map Example<br>for 16 GT/s Implementation .....                                                                                                              | 208 |
| 5-26 | 8-column x64 Advanced Package Bump Map Example<br>for 32 GT/s Implementation .....                                                                                                               | 209 |
| 5-27 | 10-column x32 Advanced Package Bump Map .....                                                                                                                                                    | 211 |
| 5-28 | 16-column x32 Advanced Package Bump Map .....                                                                                                                                                    | 211 |
| 5-29 | 8-column x32 Advanced Package Bump Map .....                                                                                                                                                     | 212 |
| 5-30 | 10-column x32 Advanced Package Bump Map: Signal Exit Order .....                                                                                                                                 | 212 |
| 5-31 | 10-column x32 Advanced Package Bump Map Example<br>for 32 GT/s Implementation .....                                                                                                              | 213 |
| 5-32 | 16-column x32 Advanced Package Bump Map Example<br>for 16 GT/s Implementation .....                                                                                                              | 214 |
| 5-33 | 8-column x32 Advanced Package Bump Map Example<br>for 32 GT/s Implementation .....                                                                                                               | 215 |

|      |                                                                                                                                                  |     |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 5-34 | Example of Normal and Mirrored x64-to-x32 Advanced Package Module Connection .....                                                               | 218 |
| 5-35 | Example of Normal and Mirrored x32-to-x32 Advanced Package Module Connection .....                                                               | 219 |
| 5-36 | Naming Convention for One-, Two-, and Four-module Advanced Package Paired with "Standard Die Rotate" Configurations .....                        | 220 |
| 5-37 | Naming Convention for One-, Two-, and Four-module Advanced Package Paired with "Mirrored Die Rotate" Configurations .....                        | 220 |
| 5-38 | Examples for Advanced Package Configurations Paired with "Standard Die Rotate" Counterparts, with a Different Number of Modules .....            | 221 |
| 5-39 | Examples for Advanced Package Configurations Paired with "Mirrored Die Rotate" Counterparts, with a Different Number of Modules .....            | 222 |
| 5-40 | Standard Package Bump Map: x16 interface .....                                                                                                   | 225 |
| 5-41 | Standard Package x16 interface: Signal exit order .....                                                                                          | 225 |
| 5-42 | Standard Package Bump Map: x32 interface .....                                                                                                   | 225 |
| 5-45 | Standard Package reference configuration .....                                                                                                   | 226 |
| 5-43 | Standard Package x32 interface: Signal exit routing .....                                                                                        | 226 |
| 5-44 | Standard Package cross section for stacked module .....                                                                                          | 226 |
| 5-46 | Standard Package Bump Map: x8 Interface .....                                                                                                    | 227 |
| 5-47 | Naming Convention for One-, Two-, and Four-module Standard Package Paired with "Standard Die Rotate" Configurations .....                        | 228 |
| 5-48 | Naming Convention for One-, Two-, and Four-module Standard Package Paired with "Mirrored Die Rotate" Configurations .....                        | 229 |
| 5-49 | Examples for Standard Package Configurations Paired with "Standard Die Rotate" Counterparts, with a Different Number of Modules .....            | 230 |
| 5-50 | Examples for Standard Package Configurations Paired with "Mirrored Die Rotate" Counterparts, with a Different Number of Modules .....            | 231 |
| 5-51 | Additional Examples for Standard Package Configurations Paired with "Mirrored Die Rotate" Counterparts, with a Different Number of Modules ..... | 231 |
| 5-52 | Example of a Configuration for Standard Package, with Some Modules Disabled ..                                                                   | 233 |
| 5-53 | UCIE-S Sideband-only Port Bump Map .....                                                                                                         | 234 |
| 5-54 | UCIE-S Sideband-only Port Supported Configurations .....                                                                                         | 234 |
| 5-55 | Data Lane repair resources .....                                                                                                                 | 236 |
| 5-56 | Data Lane repair .....                                                                                                                           | 236 |
| 5-57 | Valid Framing .....                                                                                                                              | 237 |
| 5-58 | Data, Clock, Valid Levels for Half-rate Clocking:<br>Clock-gated Unterminated Link .....                                                         | 238 |
| 5-59 | Data, Clock, Valid Levels for Quarter-rate Clocking:<br>Clock-gated Unterminated Link .....                                                      | 238 |
| 5-60 | Data, Clock, Valid Levels for Half-rate Clocking:<br>Continuous Clock Unterminated Link .....                                                    | 238 |
| 5-61 | Data, Clock, Valid Gated Levels for Half-rate Clocking:<br>Terminated Link .....                                                                 | 239 |
| 5-62 | Data, Clock, Valid Gated Levels for Quarter-rate Clocking:<br>Terminated Link .....                                                              | 239 |
| 5-63 | Data, Clock, Valid Gated Levels for Half-rate Clocking:<br>Continuous Clock Terminated Link .....                                                | 239 |
| 5-64 | Sideband signaling .....                                                                                                                         | 240 |
| 6-1  | Example of 3D Die Stacking.....                                                                                                                  | 242 |
| 6-2  | UCIE-3D Illustration .....                                                                                                                       | 243 |
| 6-3  | UCIE-3D PHY.....                                                                                                                                 | 244 |
| 6-4  | Start Edge and Sample Edge .....                                                                                                                 | 245 |
| 6-5  | Dtx and Drx Spec Range for 4 GT/s .....                                                                                                          | 247 |
| 6-6  | UCIE-3D Module Bump Map.....                                                                                                                     | 248 |
| 6-7  | x70 Module .....                                                                                                                                 | 249 |
| 6-8  | Bundle Repair .....                                                                                                                              | 250 |

|      |                                                                                                                 |     |
|------|-----------------------------------------------------------------------------------------------------------------|-----|
| 7-1  | Format for Register Access Request .....                                                                        | 257 |
| 7-2  | Format for Register Access Completions .....                                                                    | 258 |
| 7-3  | Format for Messages without Data .....                                                                          | 259 |
| 7-4  | Format for Messages with data payloads .....                                                                    | 266 |
| 7-5  | Common Fields in MPM Header of all MPM with Data Messages on Sideband .....                                     | 274 |
| 7-6  | Encapsulated MTP on Sideband .....                                                                              | 275 |
| 7-7  | Vendor-defined Management Port Gateway Message with Data on Sideband .....                                      | 276 |
| 7-8  | Common Fields in MPM Header of all MPM without Data Messages on Sideband .....                                  | 277 |
| 7-9  | Management Port Gateway Capabilities MPM on Sideband .....                                                      | 277 |
| 7-10 | Credit Return MPM on Sideband .....                                                                             | 278 |
| 7-11 | Init Done MPM on Sideband .....                                                                                 | 279 |
| 7-12 | PM MPM on Sideband .....                                                                                        | 279 |
| 7-13 | Vendor-defined Management Port Gateway MPM without Data on Sideband .....                                       | 280 |
| 7-14 | Example Flow for Remote Register Access Request<br>(Local FDI/RDI Credit Checks Are Not Explicitly Shown) ..... | 282 |
| 8-1  | Example UCIe Chiplet that Supports Manageability .....                                                          | 286 |
| 8-2  | Example SiP that Supports Manageability .....                                                                   | 287 |
| 8-3  | UCIe Manageability Protocol Hierarchy .....                                                                     | 288 |
| 8-4  | Relationship Between the Various Types of Management Entities .....                                             | 289 |
| 8-5  | UCIe Management Transport Packet .....                                                                          | 290 |
| 8-6  | Management Network ID Format .....                                                                              | 294 |
| 8-7  | Access Control Determination in a Responder Management Entity .....                                             | 300 |
| 8-8  | Memory Map for Management Entities .....                                                                        | 303 |
| 8-9  | Management Capability Structure Organization .....                                                              | 304 |
| 8-10 | Vendor Defined Management Capability Structure Organization .....                                               | 304 |
| 8-11 | Management Capability Directory .....                                                                           | 305 |
| 8-12 | Capability Pointer .....                                                                                        | 305 |
| 8-13 | Chiplet Capability Structure Organization .....                                                                 | 307 |
| 8-14 | Chiplet Capability Structure .....                                                                              | 307 |
| 8-15 | Management Port Structure .....                                                                                 | 310 |
| 8-16 | Route Entry .....                                                                                               | 314 |
| 8-17 | Access Control Capability Structure .....                                                                       | 316 |
| 8-18 | Standard Asset Class Access Table .....                                                                         | 318 |
| 8-19 | Vendor Defined Asset Class Access Table .....                                                                   | 319 |
| 8-20 | Security Clearance Group Capability Structure .....                                                             | 322 |
| 8-21 | Security Clearance Group Context .....                                                                          | 323 |
| 8-22 | UCIe Memory Access Request Packet Format .....                                                                  | 324 |
| 8-23 | UCIe Memory Access Response Packet .....                                                                        | 328 |
| 8-24 | UCIe Memory Access Protocol Capability Structure .....                                                          | 329 |
| 8-25 | UCIe Sideband Management Path Architecture .....                                                                | 332 |
| 8-26 | UCIe Mainband Management Path Architecture .....                                                                | 333 |
| 8-27 | Supported Configurations for Management Port Gateway Connectivity<br>to D2D Adapter on Mainband .....           | 335 |
| 8-28 | Common Fields in MPM Header of all MPM with Data Messages on Mainband .....                                     | 336 |
| 8-29 | Encapsulated MTP on Mainband .....                                                                              | 337 |
| 8-30 | Vendor-defined Management Port Gateway Message with Data on Mainband .....                                      | 338 |
| 8-31 | Common Fields in MPM Header of all MPM without Data Messages on Mainband .....                                  | 339 |
| 8-32 | Management Port Gateway Capabilities MPM on Mainband .....                                                      | 339 |
| 8-33 | Init Done MPM on Mainband .....                                                                                 | 340 |
| 8-34 | Vendor-defined Management Port Gateway Message without Data on Mainband .....                                   | 340 |
| 8-35 | Sideband Management Transport Initialization Phase Example<br>with RxQ-ID=0 and One VC (VC0) .....              | 343 |
| 8-36 | Sideband Management Transport Initialization Phase Example<br>with RxQ-ID=0, 1 and One VC (VC0) .....           | 344 |

|       |                                                                                                                                           |     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 8-37  | Sideband Management Transport Initialization Phase Example with RxQ-ID=0 and Two VCs (VC0, VC1) .....                                     | 345 |
| 8-38  | Mainband Management Transport Initialization Phase Example with RxQ-ID=0 and One VC (VC0) .....                                           | 348 |
| 8-39  | Mainband Management Transport Initialization Phase Example with RxQ-ID=0, 1 and One VC (VC0) .....                                        | 348 |
| 8-40  | Mainband Management Transport Initialization Phase Example with RxQ-ID=0 and Two VCs (VC0, VC1) .....                                     | 349 |
| 8-41  | Example Illustration of a Large MTP Transmitted over Multiple RxQ-IDs on Sideband with Segmentation .....                                 | 352 |
| 8-42  | Conceptual Illustration of Sideband Multi-module Ordering with Three RxQs .....                                                           | 354 |
| 8-43  | Example Illustration of a Large MTP Split into Multiple Smaller Encapsulated-MTPs for Transport over Sideband, without Segmentation ..... | 356 |
| 8-44  | Management Flit NOP Message on Mainband .....                                                                                             | 358 |
| 8-45  | Management Transport Credit Return DWORD (CRD) Format on Mainband .....                                                                   | 358 |
| 8-46  | Valid MPM Header Start Locations for Various Flit Formats .....                                                                           | 360 |
| 8-47  | Example Mapping of MPMs and NOPs in Flit of Format 3 .....                                                                                | 361 |
| 8-48  | Example Mapping of MPMs and NOPs in Flit of Format 5 .....                                                                                | 361 |
| 8-49  | Example MPM Mapping to Management Flit for Format 3 with MPM Rollover to Next Flit .....                                                  | 362 |
| 8-50  | UDA Overview in Each Chiplet – Illustration .....                                                                                         | 364 |
| 8-51  | Vendor-defined Test and Debug UDM .....                                                                                                   | 366 |
| 8-52  | PCIe-based Chiplet Testing/Debugging at Sort .....                                                                                        | 367 |
| 8-53  | PCIe-based Testing of Chiplets in an SiP .....                                                                                            | 368 |
| 8-54  | PCIe-based System Testing/Debug .....                                                                                                     | 369 |
| 8-55  | DMH/DMS Address Mapping .....                                                                                                             | 370 |
| 8-56  | DMH Capability Register Map .....                                                                                                         | 371 |
| 8-57  | Empty Spoke Register Map .....                                                                                                            | 374 |
| 8-58  | Common DMS Registers for All Non-empty Spokes Register Map .....                                                                          | 374 |
| 8-59  | DMS Register Map for PCIe Spoke Types .....                                                                                               | 379 |
| 8-60  | DMS Register Map for Vendor-defined Spoke Types .....                                                                                     | 383 |
| 9-1   | Software view Example with Root Ports and Endpoints .....                                                                                 | 388 |
| 9-2   | Software view Example with Switch and Endpoints .....                                                                                     | 389 |
| 9-3   | Software view Example of PCIe Endpoint .....                                                                                              | 390 |
| 9-4   | PCIe Link DVSEC .....                                                                                                                     | 392 |
| 9-5   | PCIe Link Health Monitor (UHM) DVSEC .....                                                                                                | 434 |
| 9-6   | PCIe Test/Compliance Register Block .....                                                                                                 | 436 |
| 10-1  | Example configurations using RDI .....                                                                                                    | 453 |
| 10-2  | Example Waveform Showing Handling of Level Transition .....                                                                               | 462 |
| 10-3  | Data Transfer from Adapter to Physical Layer .....                                                                                        | 463 |
| 10-4  | lp_irdy asserting two cycles before lp_valid .....                                                                                        | 464 |
| 10-5  | lp_irdy asserting at the same cycle as lp_valid .....                                                                                     | 464 |
| 10-6  | RDI State Machine .....                                                                                                                   | 465 |
| 10-7  | Example flow of Link bring up on RDI .....                                                                                                | 466 |
| 10-8  | Successful PM entry flow .....                                                                                                            | 469 |
| 10-9  | PM Abort flow .....                                                                                                                       | 469 |
| 10-10 | PM Exit flow .....                                                                                                                        | 470 |
| 10-11 | RDI PM Exit Example Showing Interactions with LTSI .....                                                                                  | 470 |
| 10-12 | Example configurations using FDI .....                                                                                                    | 471 |
| 10-13 | Example Waveform Showing Handling of Level Transition .....                                                                               | 481 |
| 10-14 | Data Transfer from Protocol Layer to Adapter .....                                                                                        | 482 |
| 10-15 | Example for pl_flit_cancel for Latency-Optimized Flits and CRC Error on First Flit Half .....                                             | 483 |
| 10-16 | Example for pl_flit_cancel for Latency-Optimized Flits and CRC Error on Second Flit Half .....                                            | 483 |

|       |                                                                                                                                     |     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------|-----|
| 10-17 | Example for pl_flit_cancel for Latency-Optimized Flits<br>and CRC Error on Second Flit Half, Alternate Implementation Example ..... | 483 |
| 10-18 | Example for pl_flit_cancel for Standard 256B Flits .....                                                                            | 484 |
| 10-19 | FDI State Machine .....                                                                                                             | 484 |
| 10-20 | FDI Bring up flow .....                                                                                                             | 486 |
| 10-21 | PM Entry example for CXL or PCIe protocols .....                                                                                    | 489 |
| 10-22 | PM Entry example for symmetric protocol .....                                                                                       | 489 |
| 10-23 | PM Abort Example .....                                                                                                              | 490 |
| 10-24 | PM Exit Example .....                                                                                                               | 490 |
| 10-25 | CXL.io Standard 256B Start Header Flit Format Example .....                                                                         | 491 |
| 10-26 | FDI (or RDI) Byte Mapping for 64B Datapath to 256B Flits.....                                                                       | 492 |
| 10-27 | FDI (or RDI) Byte Mapping for 128B Datapath to 256B Flits .....                                                                     | 492 |
| 10-28 | FDI Byte Mapping for 128B Datapath for 68B Flit Format.....                                                                         | 492 |
| 10-29 | RDI Byte Mapping for 128B Datapath for 68B Flit Format.....                                                                         | 493 |
| 10-30 | LinkReset Example .....                                                                                                             | 504 |
| 10-31 | LinkError example .....                                                                                                             | 505 |
| 10-32 | Example of L2 Cross Product with Retrain on RDI .....                                                                               | 506 |
| 10-33 | L2 Exit Example for RDI .....                                                                                                       | 507 |
| 11-1  | Examples of Standard and Advanced Package setups for DUT and Golden Die<br>Compliance Testing .....                                 | 509 |
| B-1   | AIB interoperability .....                                                                                                          | 514 |

# Tables

---

|      |                                                                                                                                    |     |
|------|------------------------------------------------------------------------------------------------------------------------------------|-----|
| 1    | Terms and Definitions.....                                                                                                         | 25  |
| 2    | Unit of Measure Symbols.....                                                                                                       | 33  |
| 3    | Reference Documents .....                                                                                                          | 34  |
| 4    | Revision History .....                                                                                                             | 34  |
| 1-1  | Characteristics of UCIe on Standard Package .....                                                                                  | 37  |
| 1-2  | Characteristics of UCIe on Advanced Package .....                                                                                  | 38  |
| 1-3  | Characteristics of UCIe-3D .....                                                                                                   | 39  |
| 1-4  | UCIe 2D and 2.5D Key Performance Targets .....                                                                                     | 47  |
| 1-5  | UCIe-3D Key Performance Targets .....                                                                                              | 47  |
| 1-6  | Groups for different bump pitches .....                                                                                            | 48  |
| 2-1  | Specification to protocol mode requirements.....                                                                                   | 50  |
| 3-1  | Capabilities that Must Be Negotiated between Link Partners .....                                                                   | 61  |
| 3-2  | Flit Header for Format 2 without Retry .....                                                                                       | 71  |
| 3-3  | Flit Header for Format 2 with Retry .....                                                                                          | 71  |
| 3-4  | Flit Header for Format 3, Format 4, Format 5, and Format 6 without Retry .....                                                     | 78  |
| 3-5  | Flit Header for Format 3, Format 4, Format 5, and Format 6 with Retry .....                                                        | 79  |
| 3-6  | Summary of Flit Formats .....                                                                                                      | 83  |
| 3-7  | Protocol Mapping and Implementation Requirements .....                                                                             | 84  |
| 3-8  | Truth Table for Determining Protocol .....                                                                                         | 85  |
| 3-9  | Truth Table 1.....                                                                                                                 | 87  |
| 3-10 | Truth Table 2 .....                                                                                                                | 87  |
| 4-1  | Valid framing for Retimers .....                                                                                                   | 100 |
| 4-2  | Lane ID: Advanced Package module .....                                                                                             | 103 |
| 4-3  | Lane ID: Standard Package Module .....                                                                                             | 104 |
| 4-4  | LFSR seed values .....                                                                                                             | 119 |
| 4-5  | Data-to-Clock Training Parameters .....                                                                                            | 124 |
| 4-6  | State Definitions for Initialization .....                                                                                         | 129 |
| 4-7  | Per Lane ID Pattern .....                                                                                                          | 150 |
| 4-8  | Per Lane ID Pattern Examples .....                                                                                                 | 151 |
| 4-9  | Standard Package Logical Lane Map .....                                                                                            | 154 |
| 4-10 | Runtime Link Test Status Register based Retrain encoding .....                                                                     | 167 |
| 4-11 | Retrain encoding .....                                                                                                             | 167 |
| 4-12 | Retrain exit state resolution .....                                                                                                | 167 |
| 4-13 | Messages exchanged that are used to determine resolution for Example 1 .....                                                       | 175 |
| 4-14 | Messages exchanged that are used to determine resolution for Example 2 .....                                                       | 176 |
| 4-15 | Messages exchanged that are used to determine resolution for Example 3 .....                                                       | 176 |
| 4-16 | Capability Register and Link Training Parameter Values<br>for RDI Byte-to-Module Assignment Example for x64 Interop with x32 ..... | 178 |
| 5-1  | REFCLK Frequency PPMs and SSC PPMs .....                                                                                           | 181 |
| 5-2  | Electrical summary .....                                                                                                           | 184 |
| 5-3  | Transmitter Electrical Parameters .....                                                                                            | 186 |
| 5-4  | Transmitter de-emphasis values .....                                                                                               | 188 |
| 5-5  | Receiver Electrical parameters .....                                                                                               | 190 |
| 5-6  | Maximum channel reach for unterminated Receiver (Tx Swing = 0.4 V) .....                                                           | 191 |
| 5-7  | Maximum Channel reach for unterminated Receiver (TX swing = 0.85V) .....                                                           | 192 |
| 5-8  | Forwarded clock frequency and phase .....                                                                                          | 194 |
| 5-9  | I/O Noise and Clock Skew .....                                                                                                     | 196 |
| 5-10 | Eye requirements .....                                                                                                             | 197 |
| 5-11 | Channel Characteristics.....                                                                                                       | 200 |

|      |                                                                                                                           |     |
|------|---------------------------------------------------------------------------------------------------------------------------|-----|
| 5-12 | x64 Advanced Package Module Signal List .....                                                                             | 200 |
| 5-13 | Bump Map Options and the Recommended Bump Pitch Range and Max Speed .....                                                 | 206 |
| 5-14 | Maximum Systematic Lane-to-lane Length Mismatch in um between<br>the Reference Bump Maps in the Implementation Note ..... | 216 |
| 5-15 | x64 and x32 Advanced Package Connectivity Matrix .....                                                                    | 217 |
| 5-16 | Summary of Advanced Package Module Connection Combinations<br>with Same Number of Modules on Both Sides .....             | 221 |
| 5-17 | Summary of Advanced Package Module Connection Combinations<br>with Different Number of Modules on Both Sides .....        | 222 |
| 5-18 | IL and Crosstalk for Standard Package: With Receiver Termination Enabled .....                                            | 223 |
| 5-19 | IL and Crosstalk for Standard Package: No Rx Termination .....                                                            | 223 |
| 5-20 | Standard Package Module Signal List .....                                                                                 | 223 |
| 5-21 | Summary of Standard Package Module Connection Combinations<br>with Same Number of Modules on Both Sides .....             | 229 |
| 5-22 | Summary of Standard Package Module Connection Combinations<br>with Different Number of Modules on Both Sides .....        | 232 |
| 5-23 | Summary of Degraded Links when Standard Package Module-pairs Fail .....                                                   | 233 |
| 5-24 | Tightly Coupled Mode: Eye Mask .....                                                                                      | 235 |
| 5-25 | Tightly Coupled Mode Channel for Advanced Package .....                                                                   | 235 |
| 5-26 | Raw BER requirements .....                                                                                                | 237 |
| 5-27 | Sideband Parameters summary .....                                                                                         | 240 |
| 5-28 | AUXCLK Frequency Parameters .....                                                                                         | 241 |
| 6-1  | UCIE-3D Key Performance Indicators .....                                                                                  | 243 |
| 6-2  | Timing and Mismatch Specification .....                                                                                   | 245 |
| 6-3  | ESD Specification for ≤ 10 um Bump Pitch .....                                                                            | 248 |
| 6-4  | Energy Efficiency Target .....                                                                                            | 248 |
| 7-1  | Opcode Encodings Mapped to Packet Types .....                                                                             | 253 |
| 7-2  | FDI sideband: srcid and dstid encodings on FDI .....                                                                      | 254 |
| 7-3  | RDI sideband: srcid and dstid encodings on RDI .....                                                                      | 254 |
| 7-4  | UCIE Link sideband: srcid and dstid encodings for UCIE Link .....                                                         | 255 |
| 7-5  | Field descriptions for Register Access Requests .....                                                                     | 256 |
| 7-6  | Mapping of Addr[23:0] for Different Requests .....                                                                        | 257 |
| 7-7  | Field Descriptions for a Completion .....                                                                                 | 258 |
| 7-8  | Message Encodings for Messages without Data .....                                                                         | 259 |
| 7-9  | Link Training State Machine related Message encodings<br>for messages without data .....                                  | 262 |
| 7-10 | Message encodings for Messages with Data .....                                                                            | 266 |
| 7-11 | Link Training State Machine related encodings .....                                                                       | 268 |
| 7-12 | Supported MPM with Data Messages on Sideband .....                                                                        | 274 |
| 7-13 | Common Fields in MPM Header of all MPM with Data Messages<br>on Sideband .....                                            | 274 |
| 7-14 | Encapsulated MTP on Sideband Fields .....                                                                                 | 275 |
| 7-15 | Vendor-defined Management Port Gateway Message<br>with Data on Sideband Fields .....                                      | 276 |
| 7-16 | Supported MPM without Data Messages on Sideband .....                                                                     | 276 |
| 7-17 | Common Fields in MPM Header of all MPM without Data Messages on Sideband .....                                            | 277 |
| 7-18 | Management Port Gateway Capabilities MPM Header Fields on Sideband .....                                                  | 277 |
| 7-19 | Credit Return MPM Header Fields on Sideband .....                                                                         | 278 |
| 7-20 | Init Done MPM Header Fields on Sideband .....                                                                             | 279 |
| 7-21 | PM MPM Header Fields on Sideband .....                                                                                    | 279 |
| 7-22 | MPM Header Vendor-defined Management Port Gateway Message<br>without Data on Sideband .....                               | 280 |

|      |                                                                                            |     |
|------|--------------------------------------------------------------------------------------------|-----|
| 8-1  | UCIE Management Transport Packet Fields .....                                              | 290 |
| 8-2  | Traffic Class Characteristics .....                                                        | 292 |
| 8-3  | Management Protocol IDs .....                                                              | 294 |
| 8-4  | Management Protocol use of Access Control Mechanism .....                                  | 298 |
| 8-5  | Asset Types .....                                                                          | 301 |
| 8-6  | Asset Contexts .....                                                                       | 301 |
| 8-7  | Standard Security Asset Classes .....                                                      | 301 |
| 8-8  | UCIE-defined Management Capability IDs .....                                               | 304 |
| 8-9  | Management Capability Directory Fields .....                                               | 305 |
| 8-10 | Capability Pointer Fields .....                                                            | 306 |
| 8-11 | Chiplet Capability Structure Fields .....                                                  | 308 |
| 8-12 | Management Port Structure Fields .....                                                     | 310 |
| 8-13 | Route Entry Fields .....                                                                   | 314 |
| 8-14 | Access Control Capability Structure Fields .....                                           | 316 |
| 8-15 | Read Access Control (RAC) Structure Field Description .....                                | 320 |
| 8-16 | Write Access Control (WAC) Structure Field Description .....                               | 321 |
| 8-17 | Security Clearance Group Capability Structure Fields .....                                 | 322 |
| 8-18 | Security Clearance Group Context Fields .....                                              | 323 |
| 8-19 | UCIE Memory Access Request Packet Fields .....                                             | 325 |
| 8-20 | UCIE Memory Access Response Packet Fields .....                                            | 328 |
| 8-21 | UCIE Memory Access Protocol Capability Structure Fields .....                              | 329 |
| 8-22 | MPM Opcodes on Mainband .....                                                              | 336 |
| 8-23 | Supported MPM with Data Messages on Mainband .....                                         | 336 |
| 8-24 | Common Fields in MPM Header of all MPM with Data Messages<br>on Mainband .....             | 336 |
| 8-25 | Encapsulated MTP on Mainband Fields.....                                                   | 337 |
| 8-26 | Vendor-defined Management Port Gateway Message<br>with Data on Mainband Fields .....       | 338 |
| 8-27 | Supported MPM without Data Messages on Mainband .....                                      | 338 |
| 8-28 | Common Fields in MPM Header of all MPM without Data Messages on Mainband....               | 339 |
| 8-29 | Management Port Gateway Capabilities MPM Header Fields on Mainband .....                   | 339 |
| 8-30 | Init Done MPM Header Fields on Mainband.....                                               | 340 |
| 8-31 | MPM Header Vendor-defined Management Port Gateway Message<br>without Data on Mainband..... | 341 |
| 8-32 | Version.....                                                                               | 371 |
| 8-33 | Capability ID, Ver.....                                                                    | 371 |
| 8-34 | Debug Capability.....                                                                      | 372 |
| 8-35 | Debug Control .....                                                                        | 372 |
| 8-36 | Debug Status .....                                                                         | 372 |
| 8-37 | DMH_Length_Low .....                                                                       | 372 |
| 8-38 | DMH_Length_High .....                                                                      | 372 |
| 8-39 | DMH Extended Capability Pointer Low .....                                                  | 373 |
| 8-40 | DMH Extended Capability Pointer High .....                                                 | 373 |
| 8-41 | DMS_Start_Low.....                                                                         | 373 |
| 8-42 | DMS_Start_High .....                                                                       | 373 |
| 8-43 | DMS_Next_Low Address .....                                                                 | 374 |
| 8-44 | DMS_Next_High Address.....                                                                 | 374 |
| 8-45 | Spoke Vendor ID.....                                                                       | 375 |
| 8-46 | Spoke Device ID .....                                                                      | 375 |
| 8-47 | DMS_Next_Low Address .....                                                                 | 376 |
| 8-48 | DMS_Next_High Address.....                                                                 | 376 |
| 8-49 | Spoke Revision ID .....                                                                    | 376 |
| 8-50 | DMS-ID .....                                                                               | 377 |
| 8-51 | Associated DMS-ID[0, 1, 2] .....                                                           | 377 |
| 8-52 | Spoke Capability .....                                                                     | 377 |

|      |                                                                         |     |
|------|-------------------------------------------------------------------------|-----|
| 8-53 | Spoke Control.....                                                      | 377 |
| 8-54 | Spoke Status.....                                                       | 378 |
| 8-55 | DMS Register Space Length Low .....                                     | 378 |
| 8-56 | DMS Register Space Length High.....                                     | 378 |
| 8-57 | DMS Extended Capability Pointer Low .....                               | 378 |
| 8-58 | DMS Extended Capability Pointer High .....                              | 378 |
| 8-59 | Port ID .....                                                           | 380 |
| 8-60 | Adapter_Physical_Layer_Ptr_Low .....                                    | 380 |
| 8-61 | Adapter_Physical_Layer_Ptr_High .....                                   | 380 |
| 8-62 | Compliance_Test_Ptr_Low.....                                            | 381 |
| 8-63 | Compliance_Test_Ptr_High .....                                          | 381 |
| 8-64 | Impl_Spec_Adapter_Ptr_Low .....                                         | 382 |
| 8-65 | Impl_Spec_Adapter_Ptr_High .....                                        | 382 |
| 8-66 | Impl_Spec_Physical_Layer_Ptr_Low .....                                  | 382 |
| 8-67 | Impl_Spec_Physical_Layer_Ptr_High.....                                  | 382 |
| 9-1  | Software view of Upstream and Downstream Device at UCIE interface ..... | 385 |
| 9-2  | SW discovery of UCIE Links .....                                        | 386 |
| 9-3  | Summary of location of various UCIE Link related registers .....        | 387 |
| 9-4  | Register Attributes .....                                               | 391 |
| 9-5  | UCIE Link DVSEC - PCI Express Extended Capability Header .....          | 393 |
| 9-6  | UCIE Link DVSEC - Designated Vendor Specific Header 1, 2 .....          | 393 |
| 9-7  | UCIE Link DVSEC - Capability Descriptor .....                           | 394 |
| 9-8  | UCIE Link DVSEC - UCIE Link Capability .....                            | 395 |
| 9-9  | UCIE Link DVSEC - UCIE Link Control.....                                | 396 |
| 9-10 | UCIE Link DVSEC - UCIE Link Status .....                                | 398 |
| 9-11 | UCIE Link DVSEC - Link Event Notification Control .....                 | 401 |
| 9-12 | UCIE Link DVSEC - Error Notification Control.....                       | 402 |
| 9-13 | UCIE Link DVSEC - Register Locator 0, 1, 2, 3 Low .....                 | 405 |
| 9-14 | UCIE Link DVSEC - Register Locator 0, 1, 2, 3 High .....                | 406 |
| 9-15 | UCIE Link DVSEC - Sideband Mailbox Index Low.....                       | 406 |
| 9-16 | UCIE Link DVSEC - Sideband Mailbox Index High.....                      | 407 |
| 9-17 | UCIE Link DVSEC - Sideband Mailbox Data Low .....                       | 407 |
| 9-18 | UCIE Link DVSEC - Sideband Mailbox Data High .....                      | 407 |
| 9-19 | UCIE Link DVSEC - Sideband Mailbox Control.....                         | 408 |
| 9-20 | UCIE Link DVSEC - Sideband Mailbox Status .....                         | 408 |
| 9-21 | UCIE Link DVSEC - Requester ID .....                                    | 408 |
| 9-22 | UCIE Link DVSEC - Associated Port Numbers .....                         | 409 |
| 9-23 | UiSRB DVSEC - PCI Express Extended Capability Header .....              | 409 |
| 9-24 | UiSRB DVSEC - Designated Vendor Specific Header 1, 2 .....              | 410 |
| 9-25 | UiSRB DVSEC - UiSRB Base Address .....                                  | 410 |
| 9-26 | D2D/PHY Register Block - UCIE Register Block Header (Offset 0h) .....   | 411 |
| 9-27 | Uncorrectable Error Status Register .....                               | 411 |
| 9-28 | Uncorrectable Error Mask Register.....                                  | 412 |
| 9-29 | Uncorrectable Error Severity Register .....                             | 413 |
| 9-30 | Correctable Error Status Register .....                                 | 413 |
| 9-31 | Correctable Error Mask Register .....                                   | 414 |
| 9-32 | Header Log 1 Register .....                                             | 414 |
| 9-33 | Header Log 2 Register .....                                             | 415 |
| 9-34 | Error and Link Testing Control Register .....                           | 417 |
| 9-35 | Runtime Link Testing Parity Log 0 Register .....                        | 418 |
| 9-36 | Runtime Link Testing Parity Log 1 Register .....                        | 418 |
| 9-37 | Runtime Link Testing Parity Log 2 Register .....                        | 418 |
| 9-38 | Runtime Link Testing Parity Log 3 Register .....                        | 419 |
| 9-39 | Advertised Adapter Capability Log Register .....                        | 419 |

|      |                                                                                |     |
|------|--------------------------------------------------------------------------------|-----|
| 9-40 | Finalized Adapter Capability Log Register.....                                 | 419 |
| 9-41 | Advertised CXL Capability Log Register .....                                   | 419 |
| 9-42 | Finalized CXL Capability Log Register .....                                    | 419 |
| 9-43 | Advertised Multi-Protocol Capability Log Register.....                         | 420 |
| 9-44 | Finalized Multi-Protocol Capability Log Register .....                         | 420 |
| 9-45 | Advertised CXL Capability Log Register for Stack 1 .....                       | 420 |
| 9-46 | Finalized CXL Capability Log Register for Stack 1 .....                        | 420 |
| 9-47 | Physical Layer Capability Register.....                                        | 421 |
| 9-48 | Physical Layer Control Register .....                                          | 422 |
| 9-49 | Physical Layer Status Register .....                                           | 423 |
| 9-50 | Phy Init and Debug Register .....                                              | 424 |
| 9-51 | Training Setup 1 Register.....                                                 | 425 |
| 9-52 | Training Setup 2 Register.....                                                 | 425 |
| 9-53 | Training Setup 3 Register.....                                                 | 426 |
| 9-54 | Training Setup 4 Register.....                                                 | 426 |
| 9-55 | Current Lane Map Module 0 Register.....                                        | 427 |
| 9-56 | Current Lane Map Module 1 Register.....                                        | 427 |
| 9-57 | Current Lane Map Module 2 Register.....                                        | 427 |
| 9-58 | Current Lane Map Module 3 Register.....                                        | 427 |
| 9-59 | Error Log 0 Register .....                                                     | 428 |
| 9-60 | Error Log 1 Register .....                                                     | 429 |
| 9-61 | Runtime Link Test Control .....                                                | 429 |
| 9-62 | Runtime Link Test Status Register.....                                         | 431 |
| 9-63 | Mainband Data Repair Register .....                                            | 431 |
| 9-64 | Clock, Track, Valid and Sideband Repair Register.....                          | 433 |
| 9-65 | UHM DVSEC - Designated Vendor Specific Header 1, 2 (Offsets 04h and 08h) ..... | 434 |
| 9-66 | UHM Status .....                                                               | 435 |
| 9-67 | EML_Lnx_Mody .....                                                             | 435 |
| 9-68 | EMR_Lnx_Mody .....                                                             | 435 |
| 9-69 | UCIE Register Block Header (Offset 0h).....                                    | 437 |
| 9-70 | D2D Adapter Test/Compliance Register Block Offset (Offset 10h).....            | 437 |
| 9-71 | PHY Test/Compliance Register Block Offset (Offset 14h) .....                   | 437 |
| 9-72 | Adapter Compliance Control (Offset 20h from D2DOFF).....                       | 438 |
| 9-73 | Flit Tx Injection Control (Offset 28h from D2DOFF) .....                       | 439 |
| 9-74 | Adapter Test Status.....                                                       | 440 |
| 9-75 | Link State Injection Control Stack 0 .....                                     | 441 |
| 9-76 | Link State Injection Control Stack 1 .....                                     | 442 |
| 9-77 | Retry Injection Control .....                                                  | 442 |
| 9-78 | Physical Layer Compliance Control 1 .....                                      | 444 |
| 9-79 | Physical Layer Compliance Control 2 .....                                      | 446 |
| 9-80 | Physical Layer Compliance Status 1 .....                                       | 447 |
| 9-81 | Physical Layer Compliance Status 2 .....                                       | 447 |
| 9-82 | Physical Layer Compliance Status 3 .....                                       | 448 |
| 9-83 | UEDT Header .....                                                              | 450 |
| 9-84 | UCIE Link Structure (UCLS) .....                                               | 450 |
| 10-1 | RDI signal list .....                                                          | 453 |
| 10-2 | RDI Config interface extensions for Management Transport .....                 | 458 |
| 10-3 | FDI signal list .....                                                          | 472 |
| 10-4 | Requests Considered in Each State by Lower Layer .....                         | 497 |
| A-1  | CXL Registers for UCIE devices .....                                           | 511 |
| A-2  | PCIe Registers for UCIE devices .....                                          | 512 |
| B-1  | AIB 2.0 Datapath mapping for Advanced Package .....                            | 515 |
| B-2  | AIB 1.0 Datapath mapping for Advanced Package .....                            | 515 |

## Terminology

**Table 1. Terms and Definitions (Sheet 1 of 8)**

| Term               | Definition                                                                                                                                                |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ack                | Acknowledge                                                                                                                                               |
| ACPI               | Advanced Configuration and Power Interface                                                                                                                |
| Addr               | Address                                                                                                                                                   |
| Advanced Package   | This packaging technology is used for performance optimized applications and short reach interconnects.                                                   |
| AFE                | Analog Front End                                                                                                                                          |
| ALMP               | ARB/MUX Link Management Packet (as defined in <i>CXL Specification</i> )                                                                                  |
| APMW               | Advanced Package Module Width                                                                                                                             |
| ARB/MUX            | Arbiter/Multiplexer (as defined in <i>CXL Specification</i> )                                                                                             |
| Asset              | Any data or mechanism used to access data that should be protected from illicit access, use, availability, disclosure, alteration, destruction, or theft. |
| ATE                | Automated Test Equipment                                                                                                                                  |
| B2B                | Back-to-Back                                                                                                                                              |
| BAR                | Base Address Register                                                                                                                                     |
| BDF                | Bus Device Function                                                                                                                                       |
| BE                 | Byte Enable                                                                                                                                               |
| BEI                | BAR Equivalent Indicator                                                                                                                                  |
| BER                | Bit Error Ratio                                                                                                                                           |
| BFM                | Bus Functional Model                                                                                                                                      |
| bubble             | Gap in data transfer and/or signal transitions. Measured in number of clock cycles.                                                                       |
| bundle             | Tx group or Rx group for UCIe-3D interconnects that contains data, clock, power, and ground. A 3D Module consists of a Tx bundle and an Rx bundle.        |
| C4 bump            | Controller Collapse Chip Connect bump                                                                                                                     |
| CA                 | Completer Abort                                                                                                                                           |
| CDM                | Charged Device Model                                                                                                                                      |
| chiplet            | Integrated circuit die that contains a well-defined subset of functionality that is designed to be combined with other chiplets in a package.             |
| clear<br>cleared   | If clear or reset is used and no value is provided for a bit, it is interpreted as 0b.                                                                    |
| CLM                | Current Lane Map                                                                                                                                          |
| CMLS               | Common Maximum Link Speed                                                                                                                                 |
| CoWoS              | Chip on Wafer on Substrate                                                                                                                                |
| CPU                | Central Processing Unit                                                                                                                                   |
| CRC                | Cyclic Redundancy Check                                                                                                                                   |
| CXL                | Compute eXpress Link                                                                                                                                      |
| CXL 68B Flit Mode  | This term is used to reference 68B Flit Mode related Protocol features defined in <i>CXL Specification</i> .                                              |
| CXL 256B Flit Mode | This term is used to reference 256B Flit Mode related Protocol features defined in <i>CXL Specification</i> .                                             |
| D2C                | Data-to-Clock                                                                                                                                             |
| D2D                | Die-to-Die                                                                                                                                                |
| DCC                | Duty Cycle Correction                                                                                                                                     |

**Table 1. Terms and Definitions (Sheet 2 of 8)**

| Term                           | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DDR                            | Double Data Rate Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DevID                          | Device ID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DFx                            | Design for Debug or Design for Test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DLLP                           | Data Link Layer Packet (as defined in <i>PCIe Base Specification</i> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DLP                            | In Flit modes, the Data Link Layer Payload within a flit (as defined in <i>PCIe Base Specification</i> ).                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DMH                            | DFx Management Hub. DFx entity that provides enumeration/global control/status of DFx capabilities in a chiplet.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DMS                            | DFx Management Spoke. DFx entity that implements a specific test/debug functionality within a DMH.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DMS-ID                         | Static design time ID assigned to a DMS for ID-routed messages within a DMH. Interchangeably used with the term Spoke-ID.                                                                                                                                                                                                                                                                                                                                                                                                             |
| Domain Reset<br>(domain reset) | Used to refer to a hardware mechanism that sets or returns all PCIe registers and state machines associated with a given PCIe Link to their initialization values as specified in this document. It is required for both sides of the Link to have an overlapping time window such that they are both in domain reset concurrently.                                                                                                                                                                                                   |
| DP                             | Downstream Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DSP                            | Downstream Switch Port (as defined in <i>CXL Specification</i> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DVFS                           | Dynamic Voltage Frequency Scaling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| DVSEC                          | Designated Vendor-Specific Extended Capability (as defined in <i>PCIe Base Specification</i> )                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DWORD                          | Double Word. Four bytes. When used as an addressable quantity, a Double Word is four bytes of data that are aligned on a four-byte boundary (i.e., the least significant two bits of the address are 00b).                                                                                                                                                                                                                                                                                                                            |
| E2E                            | End to end                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| EM                             | Eye Margin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| EMIB                           | Embedded Multi-die Interconnect Bridge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| EML                            | Eye Margin Left                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| EMR                            | Eye Margin Right                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| EMV                            | Eye Margin Valid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Encapsulated MTP<br>eMTP       | Encapsulated Management Transport Packet. The resulting packet after <a href="#">Encapsulation</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Encapsulation                  | Process of splitting an MTP or Vendor defined messages (exchanged between Management Port Gateways on both ends of a link) into smaller pieces to meet any required payload length restrictions or for any other reasons like credit availability, adding a 2-DWORD header to each piece and if required, adding a 1-DWORD data padding at the end of an <a href="#">MTP</a> to transmit the MTP over sideband or mainband PCIe link. In the case of an MTP, the resulting packet after Encapsulation is called the Encapsulated MTP. |
| Endpoint<br>EP                 | As defined in <i>PCIe Base Specification</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| eRCD                           | Exclusive Restricted CXL Device (as defined in <i>CXL Specification</i> )                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| eRCH                           | Exclusive Restricted CXL Host (as defined in <i>CXL Specification</i> )                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ESD                            | Electro-Static Discharge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| F2B                            | Face-to-Back                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| F2F                            | Face-to-Face                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| FDI                            | Flit-Aware Die-to-Die Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| FEC                            | Forward Error Correction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| FEXT                           | Far-End CrossTalk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| FH                             | Flit Header                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**Table 1. Terms and Definitions (Sheet 3 of 8)**

| Term                                       | Definition                                                                                                                                                                                                         |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO                                       | First In, First Out                                                                                                                                                                                                |
| FIR                                        | Finite Impulse Response                                                                                                                                                                                            |
| FIT                                        | Failure In Time. 1 FIT = 1 device failure in $10^9$ hours.                                                                                                                                                         |
| Flit                                       | Link Layer unit of transfer (as defined in <i>CXL Specification</i> ).                                                                                                                                             |
| Flit_Marker<br>FM                          | Flit Marker (as defined in <i>PCIe Base Specification</i> )                                                                                                                                                        |
| FW                                         | Firmware                                                                                                                                                                                                           |
| FW-CLK                                     | Forwarded Clock over the UCIe Link for mainband data Lanes                                                                                                                                                         |
| HMLS                                       | Highest Maximum Link Speed of next-lower configuration.                                                                                                                                                            |
| Hub                                        | See <a href="#">DMH</a> .                                                                                                                                                                                          |
| HW                                         | Hardware                                                                                                                                                                                                           |
| IL                                         | Insertion Loss                                                                                                                                                                                                     |
| I/O                                        | Input/Output                                                                                                                                                                                                       |
| IP                                         | Generic term used to refer to architecture blocks that are defined within the specification (e.g., D2D adapter, PHY, etc.).                                                                                        |
| IPA                                        | Ignore Prohibited Access                                                                                                                                                                                           |
| ISI                                        | Inter-Symbol Interference                                                                                                                                                                                          |
| KPI                                        | Key Performance Indicator                                                                                                                                                                                          |
| Lane                                       | A pair of signals mapped to physical bumps, one for Transmission, and one for Reception. A xN UCIe Link is composed of N Lanes.                                                                                    |
| LCLK                                       | Refers to the clock at which the Logical Physical Layer, Adapter and RDI/FDI are operating.                                                                                                                        |
| LCRC                                       | Link CRC                                                                                                                                                                                                           |
| LFSR                                       | Linear Feedback Shift Register                                                                                                                                                                                     |
| Link<br>UCIe Link                          | A Link or UCIe Link refers to the set of two UCIe components and their interconnecting Lanes which forms a dual-simplex communications path between the two components.                                            |
| LSM                                        | Adapter Link State Machine                                                                                                                                                                                         |
| LTS defense                                | Link Training State Machine                                                                                                                                                                                        |
| LTSSM                                      | Link Training and Status State Machine (as defined in <i>PCIe Base Specification</i> )                                                                                                                             |
| LSB                                        | Least Significant Bit                                                                                                                                                                                              |
| Mainband<br>MB                             | Connection that constitutes the main data path of UCIe. Consists of a forwarded clock, a data valid pin, and N Lanes of data per module.                                                                           |
| Management Bridge                          | Type of Management Entity that bridges a Management Network within an SiP to another network that may be internal or external to the SiP.                                                                          |
| Management Director                        | Management Element that is responsible for discovering, configuring, and coordinating the overall management of the SiP and acts as the manageability Root of Trust (RoT).                                         |
| Management Domain                          | One or more chiplets in an SiP that are interconnected by a Management Network and support UCIe Manageability.                                                                                                     |
| Management Element                         | Type of Management Entity that can perform one or more management functions.                                                                                                                                       |
| Management Entity                          | Addressable entity on the Management Network that can send and/or receive UCIe Management Transport packets. A Management Element, a Management Port, and a Management Bridge are all a type of Management Entity. |
| Management Flit                            | A Flit that carries a <a href="#">Management Port Message (MPM)</a> .                                                                                                                                              |
| Management Link<br>Encapsulation Mechanism | Mechanism that defines how UCIe Management Transport packets are transferred across a point-to-point management link.                                                                                              |

**Table 1. Terms and Definitions (Sheet 4 of 8)**

| Term                          | Definition                                                                                                                                                                                                        |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Management Network            | Network within and between chiplets that is capable of transporting UCIe Management Transport packets.                                                                                                            |
| Management Port               | Management Entity that facilitates management communication between chiplets using a chiplet-to-chiplet management link.                                                                                          |
| Management Port Gateway (MPG) | Entity that provides the bridging functionality when transporting an <a href="#">MTP</a> from/to a local SoC management fabric (which is an SoC-specific implementation) to/from a UCIe link.                     |
| Management Port Message (MPM) | Sideband or mainband message that relates to encapsulation.                                                                                                                                                       |
| Management Protocol           | Protocol carried on top of the UCIe Management Transport.                                                                                                                                                         |
| Management Reset              | Type of reset that causes all UCIe manageability and manageability structures in a chiplet to be reset to their default state.                                                                                    |
| MCLS                          | Number of active Modules Current Link Speed                                                                                                                                                                       |
| MMIO                          | Memory mapped Input/Output                                                                                                                                                                                        |
| MMPL                          | Multi-module PHY Logic                                                                                                                                                                                            |
| Module                        | UCIe main data path on the physical bumps is organized as a group of Lanes called a Module. For Standard Package, 16 Lanes constitute a single Module. For Advanced Package, 64 Lanes constitute a single Module. |
| MSB                           | Most Significant Bit                                                                                                                                                                                              |
| MTP                           | Management Transport Packet                                                                                                                                                                                       |
| Nak                           | Negatively acknowledge                                                                                                                                                                                            |
| NEXT                          | Near-End CrossTalk                                                                                                                                                                                                |
| NOP                           | No Operation                                                                                                                                                                                                      |
| NVMe                          | Non-Volatile Memory express                                                                                                                                                                                       |
| One-Time Programmable         | Any data storage mechanism that is capable of being programmed only once (e.g., fuse).                                                                                                                            |
| P2P                           | Peer to peer                                                                                                                                                                                                      |
| Packet                        | A block of data transmitted across a network.                                                                                                                                                                     |
| PCIe (PCI Express)            | Peripheral Component Interconnect Express (defined in <i>PCIe Base Specification</i> )                                                                                                                            |
| PCIe Flit Mode                | This term is used to reference Flit Mode related Protocol features defined in <i>PCIe Base Specification</i> .                                                                                                    |
| PCIe non-Flit Mode            | This term is used to reference non-Flit Mode related Protocol features defined in <i>PCIe Base Specification</i> .                                                                                                |
| PDOS                          | Permanent Denial of Service                                                                                                                                                                                       |
| PDS                           | Pause of Data Stream                                                                                                                                                                                              |
| PHY                           | Physical Layer (PHY and Physical Layer are used interchangeable throughout the Specification)                                                                                                                     |
| PI                            | Phase Interpolator                                                                                                                                                                                                |
| PLL                           | Phase-Locked Loop                                                                                                                                                                                                 |
| PM                            | Power Management states, used to refer to behavior and/or rules related to Power Management states (covers both L1 and L2).                                                                                       |
| PMO                           | Sideband Performant Mode Operation                                                                                                                                                                                |
| QWORD                         | Quad Word. Eight bytes. When used as an addressable quantity, a Quad Word is eight bytes of data that are aligned on an eight-byte boundary (i.e., the least significant three bits of the address are 000b).     |
| RAC                           | Read Access Control                                                                                                                                                                                               |
| RCD                           | Restricted CXL Device (as defined in <i>CXL Specification</i> )                                                                                                                                                   |
| RCH                           | Restricted CXL Host (as defined in <i>CXL Specification</i> )                                                                                                                                                     |
| RCiEP                         | Root Complex Integrated Endpoint                                                                                                                                                                                  |

**Table 1. Terms and Definitions (Sheet 5 of 8)**

| Term                                             | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RCKN_P<br>RXCKN<br>rxckn                         | Physical Lane for Clock Receiver Phase-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RCKP_P<br>RXCKP<br>rxckp                         | Physical Lane for Clock Receiver Phase-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RCRB                                             | Root Complex Register Block                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RDI                                              | Raw Die-to-Die Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RD_P[N]<br>RD_PN<br>RXDATA[N]<br>rxdataN         | Nth Physical Lane for Data Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| remote Link partner                              | This term is used throughout this specification to denote the logic associated with the far side of the UCIe Link; to denote actions or messages sent or received by the Link partner of a UCIe die.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Replay<br>Retry                                  | Retry and Replay are used interchangeably to refer to the Link level reliability mechanisms.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reserved                                         | The contents, states, or information are not defined at this time. Using any Reserved area (for example, packet header bit-fields, configuration register bits) is not permitted. Reserved register fields must be read only and must return 0 (all 0s for multi-bit fields) when read. For packets transmitted and received over the UCIe Link (mainband or sideband), the Reserved bits must be cleared to 0b by the sender and ignored by the receiver. Reserved encodings for register and packet fields must not be used. Any implementation dependence on a Reserved field value or encoding will result in an implementation that is not UCIe-compliant. The functionality of such an implementation cannot be guaranteed in this or any future revision of this specification.<br>For registers, UCIe uses the "RsvdP" or "RsvdZ" attributes for reserved fields, as well as Rsvd, and these follow the same definition as PCIe Base Specification for hardware as well as software. |
| reset                                            | If reset or clear is used and no value is provided for a bit, it is interpreted as 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RID                                              | Revision ID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RL                                               | Register Locator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Root Complex                                     | As defined in <i>PCIe Base Specification</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Root Port<br>RP                                  | As defined in <i>PCIe Base Specification</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RoT                                              | Root of Trust                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RRDCK_P<br>RXCKRD<br>rxckRD                      | Physical Lane for redundant Clock/Track Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RRD_P[N]<br>RRD_PN<br>RXDATARD[N]<br>rxdataRD[N] | Nth Physical Lane for redundant Data Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RRDVLD_P<br>RXVLDRD<br>rxvldRD                   | Physical Lane for redundant Valid Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| RTRK_P<br>RXTRK<br>rxtrk                         | Physical Lane for Track Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RVLD_P<br>RXVLD<br>rxvld                         | Physical Lane for Valid Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Rx                                               | Receiver                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**Table 1. Terms and Definitions (Sheet 6 of 8)**

| Term                     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXCKSB<br>rxcksb         | Physical Lane for sideband Clock Receiver                                                                                                                                                                                                                                                                                                                                                                                                           |
| RXCKSBRD<br>rxcksbRD     | Physical Lane for redundant sideband Clock Receiver                                                                                                                                                                                                                                                                                                                                                                                                 |
| RXDATASB<br>rxdatasb     | Physical Lane for sideband Data Receiver                                                                                                                                                                                                                                                                                                                                                                                                            |
| RXDATASBRD<br>rxdatasbRD | Physical Lane for redundant sideband Data Receiver                                                                                                                                                                                                                                                                                                                                                                                                  |
| SBFE                     | Sideband Feature Extensions                                                                                                                                                                                                                                                                                                                                                                                                                         |
| {<SBMSG>}                | Sideband message requests or responses are referred to by their names enclosed in curly brackets. See <a href="#">Chapter 7.0</a> for the mapping of sideband message names to relevant encodings. An asterisk in the <SBMSG> name is used to denote a group of messages with the same prefix or suffix in their name.                                                                                                                              |
| SC                       | Successful Completion                                                                                                                                                                                                                                                                                                                                                                                                                               |
| SD                       | Security Director. Management Element that may configure security parameters.                                                                                                                                                                                                                                                                                                                                                                       |
| Segmentation             | Process of taking a large <a href="#">MTP</a> , splitting it into smaller “segments” and sending those segments on multiple sideband links or mainband stacks.                                                                                                                                                                                                                                                                                      |
| SERDES                   | Serializer/Deserializer                                                                                                                                                                                                                                                                                                                                                                                                                             |
| serial packet            | A 64-bit serial packet is defined on the sideband I/O interface to the remote chiplet as shown in <a href="#">Figure 4-8</a> .                                                                                                                                                                                                                                                                                                                      |
| set                      | If set is used and no value is provided for a bit, it is interpreted as 1b.                                                                                                                                                                                                                                                                                                                                                                         |
| SFES                     | Sideband Feature Extensions Supported                                                                                                                                                                                                                                                                                                                                                                                                               |
| Sideband<br>SB           | Connection used for parameter exchanges, register accesses for debug/compliance and coordination with remote partner for Link training and management. Consists of a forwarded clock pin and a data pin in each direction. The clock is fixed at 800 MHz regardless of the main data path speed. The sideband logic for the UCIe Physical Layer must be on auxiliary power and an “always on” domain. Each module has its own set of sideband pins. |
| SiP                      | System in Package. Collection of chiplets packaged as a unit.                                                                                                                                                                                                                                                                                                                                                                                       |
| SM                       | State Machine                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SO                       | Sideband-only                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SoC                      | System on a Chip                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Spoke                    | See <a href="#">DMS</a> .                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Standard Package         | This packaging technology is used for low cost and long reach interconnects using traces on organic package/substrate                                                                                                                                                                                                                                                                                                                               |
| Strobe                   | Used interchangeably with clock for sideband clock                                                                                                                                                                                                                                                                                                                                                                                                  |
| SW                       | Software                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| TC                       | Traffic Class                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| TCKN_P<br>TXCKN<br>txckn | Physical Lane for Clock Transmitter Phase-2                                                                                                                                                                                                                                                                                                                                                                                                         |
| TCKP_P<br>TXCKP<br>txckp | Physical Lane for Clock Transmitter Phase-1                                                                                                                                                                                                                                                                                                                                                                                                         |
| TCM                      | Tightly coupled mode                                                                                                                                                                                                                                                                                                                                                                                                                                |
| TDPI                     | Test, Debug, Pattern, and Infrastructure                                                                                                                                                                                                                                                                                                                                                                                                            |

**Table 1. Terms and Definitions (Sheet 7 of 8)**

| Term                                             | Definition                                                                                                                                                                                                                                                   |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TD_P[N]<br>TD_PN<br>TXDATA[N]<br>txdataN         | Nth Physical Lane for Data Transmitter                                                                                                                                                                                                                       |
| TLP                                              | Transaction Layer Packet (as defined in <i>PCIe Base Specification</i> )                                                                                                                                                                                     |
| TRD_P[N]<br>TRD_PN<br>TXDATARD[N]<br>txdataRD[N] | Nth Physical Lane for redundant Data Transmitter                                                                                                                                                                                                             |
| TRDCK_P<br>TXCKRD<br>txckRD                      | Physical Lane for redundant Clock/Track Transmitter                                                                                                                                                                                                          |
| TRDVLD_P<br>TXVLDRD<br>txvldRD                   | Physical Lane for redundant Valid Transmitter                                                                                                                                                                                                                |
| Trx                                              | Transceiver                                                                                                                                                                                                                                                  |
| TSV                                              | Through-Silicon Via                                                                                                                                                                                                                                          |
| TTRK_P<br>TXTRK<br>txtrk                         | Physical Lane for Track Transmitter                                                                                                                                                                                                                          |
| TVLD_P<br>TXVLD<br>txvld                         | Physical Lane for Valid Transmitter                                                                                                                                                                                                                          |
| Tx                                               | Transmitter                                                                                                                                                                                                                                                  |
| TXCKSB<br>txcksb                                 | Physical Lane for sideband Clock Transmitter                                                                                                                                                                                                                 |
| TXCKSBRD<br>txcksbRD                             | Physical Lane for redundant sideband Clock Transmitter                                                                                                                                                                                                       |
| TXDATASB<br>txdatasb                             | Physical Lane for sideband Data Transmitter                                                                                                                                                                                                                  |
| TXDATASBRD<br>txdatasbRD                         | Physical Lane for redundant sideband Data Transmitter                                                                                                                                                                                                        |
| TXEQ                                             | Transmitter Equalization                                                                                                                                                                                                                                     |
| UCIE                                             | Universal Chiplet Interconnect express                                                                                                                                                                                                                       |
| UCIE-3D                                          | Universal Chiplet Interconnect express for 3D packaging                                                                                                                                                                                                      |
| UCIE-A                                           | Used to denote x64 Advanced Package module.                                                                                                                                                                                                                  |
| UCIE-A x32                                       | Used to denote x32 Advanced Package module. See <a href="#">Chapter 5.0</a> for UCIE-A x32 Advanced Package bump matrices, and interoperability between x32 to x32 and x32 to x64 module configurations.                                                     |
| UCIE-S                                           | Used to denote x16 Standard Package module.                                                                                                                                                                                                                  |
| UCIE chiplet                                     | A <a href="#">chiplet</a> that complies with the UCIE specification.                                                                                                                                                                                         |
| UCIE DFx Architecture UDA                        | DFx architecture specified for chiplets and SiPs that implement UCIE.                                                                                                                                                                                        |
| UCIE DFx Message UDM                             | Generic term for all UCIE Management Transport packets with Protocol ID set to 'Test and Debug Protocols'.                                                                                                                                                   |
| UCIE die                                         | This term is used throughout this specification to denote the logic associated with the UCIE Link on any given chiplet with a UCIE Link connection. It is used as a common noun to denote actions or messages sent or received by an implementation of UCIE. |

**Table 1. Terms and Definitions (Sheet 8 of 8)**

| Term                               | Definition                                                                                                                                                                                                                                                                                        |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UCIE Flit Mode                     | Operating Mode in which CRC bytes are inserted and checked by the D2D Adapter. If applicable, Retry is also performed by the D2D Adapter.                                                                                                                                                         |
| UCIE Link                          | A UCIE connection between two chiplets. These chiplets are Link partners in the context of UCIE since they communicate with each other using a common UCIE Link.                                                                                                                                  |
| UCIE Mainband Management Port      | Chiplet port that implements the Management Link Encapsulation Mechanism and can transfer UCIE Management Transport packets across a point-to-point UCIE mainband link.                                                                                                                           |
| UCIE Management Transport Protocol | Protocol used to transfer UCIE Management Transport packets between management entities.                                                                                                                                                                                                          |
| UCIE Raw Format                    | Operating format in which all the bytes of a Flit are populated by the Protocol Layer.                                                                                                                                                                                                            |
| UCIE Sideband Management Port      | Chiplet port that implements the Management Link Encapsulation Mechanism and can transfer UCIE Management Transport packets across a point-to-point UCIE sideband link.                                                                                                                           |
| UCLS                               | UCIE Link Structure                                                                                                                                                                                                                                                                               |
| UEDT                               | UCIE Early Discovery Table                                                                                                                                                                                                                                                                        |
| UHM                                | UCIE Link Health Monitor                                                                                                                                                                                                                                                                          |
| UIE                                | Uncorrectable Internal Error                                                                                                                                                                                                                                                                      |
| UiRB                               | UCIE Register Block                                                                                                                                                                                                                                                                               |
| UiSRB                              | UCIE Structure Register Block                                                                                                                                                                                                                                                                     |
| UMAP                               | UCIE Memory Access Protocol                                                                                                                                                                                                                                                                       |
| Unit Interval UI                   | Given a data stream of a repeating pattern of alternating 1 and 0 values, the Unit Interval is the value measured by averaging the time interval between voltage transitions, over a time interval sufficiently long to make all intentional frequency modulation of the source clock negligible. |
| UP                                 | Upstream Port                                                                                                                                                                                                                                                                                     |
| UR                                 | Unsupported Request                                                                                                                                                                                                                                                                               |
| USP                                | Upstream Switch Port                                                                                                                                                                                                                                                                              |
| VH                                 | Virtual Hierarchy (as defined in <i>CXL Specification</i> )                                                                                                                                                                                                                                       |
| vLSM                               | Virtual Link State Machine                                                                                                                                                                                                                                                                        |
| Vref                               | Reference voltage for receivers                                                                                                                                                                                                                                                                   |
| VTF                                | Voltage Transfer Function                                                                                                                                                                                                                                                                         |
| WAC                                | Write Access Control                                                                                                                                                                                                                                                                              |
| zero                               | Numerical value of 0 in a bit, field, or register, of appropriate width for that bit, field, or register.                                                                                                                                                                                         |

**Table 2.** Unit of Measure Symbols

| Symbol | Unit of Measure          |
|--------|--------------------------|
| b      | bit                      |
| B      | byte                     |
| dB     | decibel                  |
| fF     | femtofarad               |
| GB/s   | gigabytes per second     |
| GHz    | gigahertz                |
| GT/s   | gigatransfers per second |
| KB/s   | kilobytes per second     |
| MB/s   | megabytes per second     |
| MHz    | megahertz                |
| mm     | millimeter               |
| ms     | millisecond              |
| MT/s   | megatransfers per second |
| mUI    | milli-Unit interval      |
| mV     | millivolt                |
| mVpp   | millivolt peak-to-peak   |
| um     | micrometer               |
| us     | microsecond              |
| ns     | nanosecond               |
| pJ     | picojoule                |
| pk     | peak                     |
| ppm    | parts per million        |
| ps     | picosecond               |
| s      | second                   |
| TB/s   | terabytes per second     |
| V      | volt                     |

## Reference Documents

**Table 3.** Reference Documents<sup>a</sup>

| Document                                                                              | Document Location                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>PCI Express® Base Specification<br/>(PCIe Base Specification)<br/>Revision 6.2</i> | <a href="http://www.pcisig.com">www.pcisig.com</a>                                                                                                                                                                                                                                  |
| <i>Compute Express Link Specification<br/>(CXL Specification)<br/>Revision 3.1</i>    | <a href="http://computeexpresslink.org">computeexpresslink.org</a>                                                                                                                                                                                                                  |
| <i>ACPI Specification<br/>(version 6.5 or later)</i>                                  | <a href="http://www.uefi.org">www.uefi.org</a>                                                                                                                                                                                                                                      |
| <i>Industry Council on ESD Targets<br/>white papers</i>                               | <a href="http://www.jedec.org">www.jedec.org</a> , reference JEP196<br><a href="http://www.esdindustrycouncil.org/ic/en">www.esdindustrycouncil.org/ic/en</a> , reference White Paper 2 Part II<br><a href="http://www.esda.org">www.esda.org</a> , reference White Paper 2 Part II |

a. References to these documents throughout this specification relate to the versions/revisions listed here.

## Revision History

Table 4 lists the significant changes in different revisions.

**Table 4.** Revision History

| Revision | Date              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.0      | August 6, 2024    | <ul style="list-style-type: none"> <li>• Chapter 6.0, UCIE-3D and related support for UCIE 3D</li> <li>• Chapter 8.0, System Architecture and related support for: <ul style="list-style-type: none"> <li>— Section 8.1, "UCIE Manageability"</li> <li>— Section 8.2, "Management Transport Packet (MTP) Encapsulation"</li> <li>— Section 8.3, "UCIE Debug and Test Architecture (UDA)"</li> </ul> </li> <li>• di/dt risk mitigation during clock gating</li> <li>• Incorporation of Errata and bug fixes over 1.1</li> </ul>                                  |
| 1.1      | July 10, 2023     | <ul style="list-style-type: none"> <li>• Streaming Flit Format Capabilities (Allows Streaming protocols to use Adapter Retry/CRC)</li> <li>• Enhanced Multi-Protocol Multiplexing (Allows dynamic multiplexing of different protocols on the same Adapter)</li> <li>• Support for x32 Advanced Package Modules</li> <li>• Support for UCIE Link Health Monitoring</li> <li>• Definition of Hardware capabilities to enable Compliance</li> <li>• di/dt risk mitigation during clock gating</li> <li>• Incorporation of Errata and bug fixes over 1.0</li> </ul> |
| 1.0      | February 17, 2022 | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

§ §

## 1.0 Introduction

---

This chapter provides an overview of the Universal Chiplet Interconnect express (UCIE) architecture. UCIE is an open, multi-protocol capable, on-package interconnect standard for connecting multiple dies on the same package. The primary motivation is to enable a vibrant ecosystem supporting disaggregated die architectures which can be interconnected using UCIE. UCIE supports multiple protocols (PCIe, CXL, Streaming, and a raw format that can be used to map any protocol of choice as long as both ends support it) on top of a common physical and Link layer. It encompasses the elements needed for SoC construction such as the application layer, as well as the form-factors relevant to the package (e.g., bump location, power delivery, thermal solution, etc.).

UCIE Manageability Architecture is an optional mechanism to manage a UCIE-based System-in-Package (SiP) by provisioning for a common manageability architecture and hardware/software infrastructure to be leveraged across implementations. UCIE DFX Architecture (UDA) leverages the UCIE Manageability Architecture to provide a standardized test and debug infrastructure for a UCIE-based SiP.

The specification is defined to ensure interoperability across a wide range of devices having different performance characteristics. A well-defined debug and compliance mechanism is provided to ensure interoperability. It is expected that the specification will evolve in a backward compatible manner.

While UCIE supports a wide range of usage models, some are provided here as an illustration of the type of capability and innovation it can unleash in the compute industry. The initial protocols being mapped to UCIE are PCIe, CXL, and Streaming. The mappings for all protocols are done using a Flit Format, including the Raw Format. Both PCIe and CXL are widely used and these protocol mappings will enable more on-package integration by replacing the PCIe SERDES PHY and the PCIe/CXL LogPHY along with the Link level Retry with a UCIE Adapter and PHY to improve the power and performance characteristics. UCIE provisions for Streaming protocols to also leverage the Link Level Retry of the UCIE Adapter, and this can be used to provide reliable transport for protocols other than PCIe or CXL. UCIE also supports a Raw Format that is protocol-agnostic to enable other protocols to be mapped; while allowing usages such as integrating a standalone SERDES/transceiver tile (e.g., ethernet) on-package. When using Raw Format, the Protocol Layer is responsible for reliable transport across the UCIE Link.

**Figure 1-1** demonstrates an SoC package composed of CPU Dies, accelerator Die(s) and I/O Tile Die(s) connected through UCIE. The accelerator or I/O Tile can use CXL transactions over UCIE when connected to a CPU — leveraging the I/O, coherency, and memory protocols of CXL. The I/O tile can provide the external CXL, PCIe, and DDR pins of the package. The accelerator can also use PCIe transactions over UCIE when connected to a CPU. The CPU to CPU connectivity on-package can also use the UCIE interconnect, running coherency protocols.

**Figure 1-1.** A Package Composed of CPU Dies, Accelerator Die(s), and I/O Tile Die Connected through UCIe



A UCIe Retimer may be used to extend the UCIe connectivity beyond the package using an Off-Package Interconnect. Examples of Off-Package Interconnect include electrical cable or optical cable or any other technology to connect packages at a Rack/Pod level as shown in [Figure 1-2](#). The UCIe specification requires the UCIe Retimer to implement the UCIe interface to the Die that it connects on its local package and ensure that the Flits are delivered to the remote UCIe Die interface in the separate package following UCIe protocol using the channel extension technology of its choice.

[Figure 1-2](#) demonstrates a rack/pod-level disaggregation using CXL protocol. [Figure 1-2a](#) shows the rack level view where multiple compute nodes (virtual hierarchy) from different compute chassis connect to a CXL switch which connects to multiple CXL accelerators/Type-3 memory devices which can be placed in one or more separate drawer. The logical view of this connectivity is shown in [Figure 1-2b](#), where each “host” (H1, H2,...) is a compute drawer. Each compute drawer connects to the switch using an Off-Package Interconnect running CXL protocol through a UCIe Retimer, as shown in [Figure 1-2c](#). The switch also has co-package Retimers where the Retimer tiles connect to the main switch die using UCIe and on the other side are the PCIe/CXL physical interconnects to connect to the accelerators/memory devices, as shown in [Figure 1-2c](#).

**Figure 1-2. UCIe enabling long-reach connectivity at Rack/Pod Level**

UCIe permits three different packaging options: Standard Package (2D), and Advanced Package (2.5D), and UCIe-3D. This covers the spectrum from lowest cost to best performance interconnects.

- Standard Package** — This packaging technology is used for low cost and long reach (10 mm to 25 mm, when measured from a bump on one Die to the connecting bump of the remote Die) interconnects using traces on organic package/substrate, while still providing significantly better BER characteristics compared to off-package SERDES. [Figure 1-3](#) shows an example application using the Standard Package option. [Table 1-1](#) shows a summary of the characteristics of the Standard Package option with UCIe.

**Figure 1-3. Standard Package interface****Table 1-1. Characteristics of UCIe on Standard Package**

| Index                                 | Value                                             |
|---------------------------------------|---------------------------------------------------|
| Supported speeds (per Lane)           | 4 GT/s, 8 GT/s, 12 GT/s, 16 GT/s, 24GT/s, 32 GT/s |
| Bump Pitch                            | 100 um to 130 um                                  |
| Channel reach (short reach)           | 10 mm                                             |
| Channel reach (long reach)            | 25 mm                                             |
| Raw Bit Error Rate (BER) <sup>a</sup> | 1e-27 (<= 8 GT/s)<br>1e-15 (>= 12 GT/s)           |

a. See [Chapter 5.0](#) for details about BER characteristics.

- 2. Advanced Package** — This packaging technology is used for performance optimized applications. Consequently, the channel reach is short (less than 2 mm, when measured from a bump on one Die to the connecting bump of the remote Die) and the interconnect is expected to be optimized for high bandwidth and low latency with best performance and power efficiency characteristics. [Figure 1-4](#), [Figure 1-5](#), and [Figure 1-6](#) show example applications using the Advanced Package option.

[Table 1-2](#) shows a summary of the main characteristics of the Advanced Package option.

**Table 1-2. Characteristics of UCIe on Advanced Package**

| Index                                 | Value                                              |
|---------------------------------------|----------------------------------------------------|
| Supported speeds (per Lane)           | 4 GT/s, 8 GT/s, 12 GT/s, 16 GT/s, 24 GT/s, 32 GT/s |
| Bump pitch                            | 25 um to 55 um                                     |
| Channel reach                         | 2 mm                                               |
| Raw Bit Error Rate (BER) <sup>a</sup> | 1e-27 (<=12GT/s)<br>1e-15 (>=16GT/s)               |

a. See [Chapter 5.0](#) for details about BER characteristics.

**Figure 1-4. Advanced Package interface: Example 1**



**Figure 1-5. Advanced Package interface: Example 2**



**Figure 1-6. Advanced Package interface: Example 3**



3. **UCIE-3D:** This packaging technology uses a two-dimensional array of interconnect bumps for data transmission between dies where one die is stacked on top of another. A menu of design options are provided for vendors to develop standard building blocks.

[Table 1-3](#) shows a summary of the main characteristics of UCIE-3D. [Figure 1-7](#) shows an example of UCIE-3D. See [Chapter 6.0](#) for a detailed description of UCIE-3D.

**Table 1-3. Characteristics of UCIE-3D**

| Index                                 | Value                                                                      |
|---------------------------------------|----------------------------------------------------------------------------|
| Supported speed (per Lane)            | up to 4 GT/s                                                               |
| Bump pitch                            | <10 um (optimized <sup>a</sup> )<br>10 to 25 um (functional <sup>a</sup> ) |
| Channel                               | 3D vertical                                                                |
| Raw Bit Error Rate (BER) <sup>b</sup> | 1e-27                                                                      |

a. Circuit Architecture is optimized for < 10 um bump pitches. 10 to 25 um are supported functionally.  
b. See [Chapter 6.0](#) for details about BER characteristics.

**Figure 1-7. Example of UCIE-3D**



## 1.1 UCIe Components

UCIe is a layered protocol, with each layer performing a distinct set of functions. [Figure 1-8](#) shows the three main components of the UCIe stack and the functionality partitioning between the layers. It is required for every component in the UCIe stack to be capable of supporting the advertised functionality and bandwidth. Several timeouts and related errors are defined for different handshakes and state transitions. All timeout values specified are minus 0% and plus 50% unless explicitly stated otherwise. All timeout values must be set to the specified values after Domain Reset. All counter values must be set to the specified values after Domain Reset.

**Figure 1-8. UCIe Layers and functionalities**



### 1.1.1 Protocol Layer

While the Protocol Layer may be application specific, UCIe Specification provides examples of transferring CXL or PCIe protocols over UCIe Links. The following protocols are supported in UCIe for enabling different applications:

- PCIe from *PCIe Base Specification*.
- CXL from *CXL Specification*. Note that RCD/RCH/eRCD/eRCH are not supported.
- Streaming protocol: This offers generic modes for a user defined protocol to be transmitted using UCIe.
- UCIe Management Transport protocol<sup>a</sup>: This is an end-to-end media independent protocol(s) for management communication on the UCIe Management Network within the UCIe Manageability Architecture.

For each protocol, different optimizations and associated Flit transfers are available for transfer over UCIe. [Chapter 2.0](#) and [Chapter 3.0](#) cover the relevant details of different modes and Flit Formats.

a. UCIe Management Transport protocol can be encapsulated for transport over the UCIe sideband or the UCIe mainband. [Section 8.1](#) covers the details of this protocol. [Section 8.2](#) covers the details around encapsulation of this protocol over the UCIe sideband and the UCIe mainband.

## 1.1.2 Die-to-Die (D2D) Adapter

The D2D Adapter coordinates with the Protocol Layer and the Physical Layer to ensure successful data transfer across the UCIe Link. It minimizes logic on the main data path as much as possible, thus providing a low-latency, optimized data path for protocol Flits. When transporting CXL protocol, the ARB/MUX functionality required for multiple simultaneous protocols is performed by the D2D Adapter. For options where the Raw BER is more than 1e-27, a CRC and Retry scheme is provided in the UCIe Specification for PCIe, CXL, or Streaming protocol, which is implemented in the D2D Adapter. See [Section 3.8](#) for Retry rules.

D2D Adapter is responsible for coordinating higher level Link state machine and bring up, protocol options related parameter exchanges with remote Link partner, and when supported, power management coordination with remote Link partner. [Chapter 3.0](#) covers the relevant details for the D2D Adapter.

## 1.1.3 Physical Layer

The Physical Layer has three sub-components as shown in [Figure 1-9](#).

**Figure 1-9. Physical Layer components**



The UCIe main data path on the physical bumps is organized as a group of Lanes called a Module. A Module forms the atomic granularity for the structural design implementation of the UCIe AFE. The number of Lanes per Module for Standard and Advanced Packages is specified in [Chapter 4.0](#). A given instance of Protocol Layer or D2D adapter can send data over multiple modules where bandwidth scaling is required.

The physical Link of UCIe is composed of two types of connections:

### 1. Sideband:

This connection is used for parameter exchanges, register accesses for debug/compliance and coordination with remote partner for Link training and management. It consists of a forwarded clock pin and a data pin in each direction. The clock is fixed at 800 MHz regardless of the mainband data rate. The sideband logic for the UCIe Physical Layer must be on auxiliary power and an “always on” domain. Each module has its own set of sideband pins.

For the Advanced Package option, a redundant pair of clock and data pins in each direction is provided for repair.

### 2. Mainband:

This connection constitutes the main data path of UCIe. It consists of a forwarded clock, a data valid pin, a track pin, and N Lanes of data per module.

For the Advanced Package option, N=64 (also referred to as x64) or N=32 (also referred to as x32) and overall four extra pins for Lane repair are provided in the bump map.

For the Standard Package option, N=16 (also referred to as x16) or N=8 (also referred to as x8) and no extra pins for repair are provided.

The Logical Physical Layer coordinates the different functions and their relative sequencing for proper Link bring up and management (e.g., sideband transfers, mainband training and repair, etc.). [Chapter 4.0](#) and [Chapter 5.0](#) cover the details on Physical Layer operation.

### 1.1.4 Interfaces

UCIE defines the interfaces between the Physical Layer and the D2D Adapter (Raw D2D Interface), and the D2D Adapter and the Protocol Layer (Flit-aware D2D Interface) in [Chapter 10.0](#). A reference list of signals is also provided to cover the interactions and rules of the Management Transport protocol between the SoC and the UCIE Stack.

The motivation for this is two-fold:

- Allow vendors and SoC builders to easily mix and match different layers from different IP providers at low integration cost and faster time to market. (For example, getting a Protocol Layer to work with the D2D Adapter and Physical Layer from any different vendor that conforms to the interface handshakes provided in the UCIE Specification.)
- Given that inter-op testing during post-silicon has greater overhead and cost associated with it, a consistent understanding and development of Bus Functional Models (BFMs) can allow easier IP development for this stack.

## 1.2 UCIE Configurations

This section describes the different configurations and permutations permitted for UCIE operation.

### 1.2.1 Single Module Configuration

A single Module configuration is a x64 or x32 data interface in an Advanced Package, as shown in [Figure 1-10](#). A single module configuration is a x16 or a x8 data interface in a Standard Package, as shown in [Figure 1-11](#). A x8 Standard Package module is only permitted for a single module configuration and is primarily provided for pre-bond test purposes. In multiple instantiations of a single module configuration where each module has its own dedicated Adapter, they operate independently (e.g., they could be transferring data at different data rates and widths).

**Figure 1-10. Single module configuration: Advanced Package**



**Figure 1-11. Single module configuration: Standard Package**

### 1.2.2 Multi-module Configurations

This specification allows for two and four module configurations. When operating with a common Adapter, the modules in two-module and four-module configurations must operate at the same data rate and width. Examples of two-module and four-module configurations are shown in [Figure 1-12](#) through [Figure 1-14](#).

**Figure 1-12. Two-module configuration for Standard Package****Figure 1-13. Four-module configuration for Standard Package**

**Figure 1-14.** Example of a Two-module Configuration for Advanced Package

### 1.2.3 Sideband-only Configurations

A Standard Package UCIe sideband-only configuration is permitted for test or manageability purposes. This can be a one, two, or four sideband-only ports as part of the same UCIe sideband-only Link. [Figure 1-15](#), [Figure 1-16](#), and [Figure 1-17](#) show examples of these configurations. See [Section 5.7.4](#) for more details.

**Figure 1-15.** One-port Sideband-only Link**Figure 1-16.** Two-port Sideband-only Link

**Figure 1-17. Four-port Sideband-only Link**

### 1.3 UCIe Retimers

As described previously, UCIe Retimers are used to enable different types of Off Package Interconnects to extend the channel reach between two UCIe Dies on different packages. Each UCIe Retimer has a local UCIe Link connection to a UCIe die on-package as well as an external connection for longer reach. [Figure 1-18](#) shows a high level block diagram demonstrating a system utilizing UCIe Retimers to enable an Off Package Interconnect between UCIe Die 0 and UCIe Die 1. UCIe Retimer 0 and UCIe Die 0 are connected through UCIe Link 0 within Package 0. UCIe Retimer 1 and UCIe Die 1 are connected through UCIe Link 1 within Package 1. The terminology of “remote Retimer partner” is used to reference the UCIe Retimer die connected to the far side of the Off Package Interconnect.

**Figure 1-18. Block Diagram for UCIe Retimer Connection**

The responsibility of a UCIe Retimer include:

- Reliable Flit transfer across the Off Package Interconnect. Three options are available for achieving this as described below:
  - The Retimer is permitted to use the FEC and CRC natively defined by the underlying specification of the protocol it carries (e.g., PCIe or CXL) as long as the external interconnect conforms to the underlying error model (e.g., BER and error correlation) of the specification corresponding to the protocol it transports. The UCIe Links would be setup to utilize the Raw Format to tunnel native bits of the protocol it transports (e.g., PCIe or CXL Flits). In this scenario, the queue sizes (Protocol Layer buffers) must be adjusted on the UCIe Dies to meet the underlying round trip latency.
  - The Retimer is permitted to provide the necessary FEC, CRC and Retry capabilities to handle the BER of the Off Package Interconnect. In this case, the Flits undergo three independent Links; each UCIe Retimer performs an independent ACK/NAK for Retry with the UCIe die within its package and a separate independent ACK/NAK for Retry with the remote Retimer

partner. For this scenario, protocols are permitted to use any of the applicable Flit Formats for transport over the UCIe Link.

- The Retimer provides its own FEC by replacing the native PCIe or CXL defined FEC with its own, or adding its FEC in addition to the native PCIe or CXL defined FEC, but takes advantage of the built in CRC and Replay mechanisms of the underlying protocol. In this scenario, the queue sizes (Protocol Layer buffers, Retry buffers) must be adjusted on the UCIe Dies to meet the underlying round trip latency.
- Resolution of Link and Protocol Parameters with remote Retimer partner to ensure interoperability between UCIe Dies end-to-end (E2E). For example, Retimers are permitted to force the same Link width, speed, protocol (including any relevant protocol specific parameters) and Flit Formats on both Package 0 and Package 1 in [Figure 1-18](#). The specific mechanism of resolution including message transfer for parameter exchanges across the Off Package Interconnect is implementation specific for the Retimers and they must ensure a consistent operational mode taking into account their own capabilities along with the UCIe Die capabilities on both Package 0 and Package 1. However, for robustness of the UCIe Links to avoid unnecessary timeouts in case the external interconnect requires a longer time to Link up or resolution of parameters with remote Retimer partner, UCIe Specification defines a “Stall” response to the relevant sideband messages that can potentially get delayed. The Retimers must respond with the “Stall” response within the rules of UCIe Specification to avoid such unnecessary timeouts while waiting for, or negotiating with remote Retimer partner. It is the responsibility of the Retimer to ensure the UCIe Link is not stalled indefinitely.
- Resolution of Link States for Adapter Link State Machine (LSM) or the RDI states with remote Retimer partner to ensure correct E2E operation. See [Chapter 3.0](#) for more details.
- Flow control and back-pressure:
  - Data transmitted from a UCIe Die to a UCIe Retimer is flow-controlled using credits. These credits are on top of any underlying protocol credit mechanism (such as PH, PD credits in PCIe). These UCIe D2D credits must be for flow control across the two UCIe Retimers and any data transmitted to the UCIe Retimer must eventually be consumed by the remote UCIe die without any other dependency. Every UCIe Retimer must implement a Receiver Buffer for Flits that it receives from the UCIe die within its package. The Receiver buffer credits are advertised to the UCIe die during initial parameter exchanges for the D2D Adapter, and the UCIe die must not send any data to the UCIe Retimer if it does not have a credit for it. One credit corresponds to 256B of data (including any FEC, CRC, etc.). Credit returns are overloaded on the Valid framing (see [Section 4.1.2](#)). Credit counters at the UCIe Die are reassigned to their initial advertised value whenever RDI states transition away from Active. UCIe Retimer must drain or dump (as applicable) the data in its receiver buffer before re-entering Active state.
  - Data transmitted from a UCIe Retimer to a UCIe die is not flow-controlled at the D2D adapter level. The UCIe Retimer may have its independent flow-control with the other UCIe Retimer if needed, which is beyond the scope of this specification.

## 1.4 UCIe Key Performance Targets

Table 1-4 gives a summary of the performance targets for UCIe Advanced and Standard Package configurations. Table 1-5 gives a summary of the performance targets for UCIe-3D.

**Table 1-4. UCIe 2D and 2.5D Key Performance Targets**

| Metric                                                   | Link Speed/<br>Voltage    | Advanced Package<br>(x64) | Standard Package |
|----------------------------------------------------------|---------------------------|---------------------------|------------------|
| Die Edge Bandwidth Density <sup>a</sup><br>(GB/s per mm) | 4 GT/s                    | 165                       | 28               |
|                                                          | 8 GT/s                    | 329                       | 56               |
|                                                          | 12 GT/s                   | 494                       | 84               |
|                                                          | 16 GT/s                   | 658                       | 112              |
|                                                          | 24 GT/s                   | 988                       | 168              |
|                                                          | 32 GT/s                   | 1317                      | 224              |
| Energy Efficiency <sup>b</sup><br>(pJ/bit)               | 0.7 V<br>(Supply Voltage) | 0.5 (<=12 GT/s)           | 0.5 (4 GT/s)     |
|                                                          |                           | 0.6 (>=16 GT/s)           | 1.0 (<=16 GT/s)  |
|                                                          |                           | -                         | 1.25 (32 GT/s)   |
|                                                          | 0.5 V<br>(Supply Voltage) | 0.25 (<=12 GT/s)          | 0.5 (<=16 GT/s)  |
|                                                          |                           | 0.3 (>=16 GT/s)           | 0.75 (32 GT/s)   |
| Latency Target <sup>c</sup>                              |                           | <=2ns                     |                  |

- a. Die edge bandwidth density is defined as total I/O bandwidth in GB per sec per mm silicon die edge, with 45-um (Advanced Package) and 110-um (Standard Package) bump pitch. For a x32 Advanced Package module, the Die Edge Bandwidth Density is 50% of the corresponding value for x64.
- b. Energy Efficiency (energy consumed per bit to traverse from FDI to bump and back to FDI) includes all the Adapter and Physical Layer-related circuitry including, but not limited to, Tx, Rx, PLL, Clock Distribution, etc. Channel reach and termination are discussed in Chapter 5.0.
- c. Latency includes the latency of the Adapter and the Physical Layer (FDI to bump delay) on Tx and Rx. See Chapter 5.0 for details of Physical Layer latency. Latency target is based on 16 GT/s. Latency at other data rates may differ due to data rate-dependent aspects such as data accumulation and transfer time. Note that the latency target does not include the accumulation of bits required for processing; either within or across Flits.

**Table 1-5. UCIe-3D Key Performance Targets**

| Metric                                                    | Link Speed/Voltage         | UCIe-3D   |
|-----------------------------------------------------------|----------------------------|-----------|
| Bandwidth Density <sup>a</sup><br>(GB/s/mm <sup>2</sup> ) | 4 GT/s                     | 4000      |
| Energy Efficiency <sup>b</sup><br>(pJ/bit)                | 0.65 V<br>(Supply Voltage) | 0.05      |
| Latency Target <sup>c</sup>                               |                            | <= 125 ps |

- a. Bandwidth Density is provided for a 9-um bump pitch.
- b. Energy Efficiency (energy consumed per bit) includes all the Tx, Rx, PLL, Clock Distribution, etc.
- c. Latency includes the latency on Tx and Rx.

## 1.5 Interoperability

Package designers need to ensure that Dies that are connected on a package can inter-operate. This includes compatible package interconnect (e.g., Advanced vs. Standard), protocols, voltage levels, etc. It is strongly recommended that a Die adopts Transmitter voltage of less than 0.85 V so that the Die can inter-operate with a wide range of process nodes in the foreseeable future.

This specification comprehends interoperability across a wide range of bump pitch for Advanced Packaging options. It is expected that over time, the smaller bump pitches will be predominantly used. With smaller bump pitch, we expect designs will reduce the maximum advertised frequency (even though they can go to 32G) to optimize for area and to address the power delivery and thermal constraints of high bandwidth with reduced area. [Table 1-6](#) summarizes these bump pitches across four groups. Interoperability is guaranteed within each group as well as across groups, based on the PHY dimension specified in [Chapter 5.0](#). The performance targets provided in [Table 1-4](#) are with the 45 um bump pitch, based on the technology widely deployed at the time of publication of UCIe 1.0 and UCIe 1.1 Specifications (2022 – 2023).

**Table 1-6. Groups for different bump pitches**

| Bump Pitch (um)  | Minimum Frequency (GT/s) | Expected Maximum Frequency (GT/s) |
|------------------|--------------------------|-----------------------------------|
| Group 1: 25 - 30 | 4                        | 12                                |
| Group 2: 31 - 37 | 4                        | 16                                |
| Group 3: 38 - 44 | 4                        | 24                                |
| Group 4: 45 - 55 | 4                        | 32                                |

§ §

## 2.0 Protocol Layer

---

Universal Chiplet Interconnect express (UCIE) maps PCIe and CXL, as well as any Streaming protocol. Throughout the UCIE Specification, Protocol-related features are kept separate from Flit Formats and packetization. This is because UCIE provides different transport mechanisms that are not necessarily tied to protocol features (e.g., PCIe non-Flit mode packets are transported using CXL.io 68B Flit Format). Protocol features include the definitions of Transaction Layer and higher layers, as well as Link Layer features not related to Flit packing/Retry (e.g., Flow Control negotiations etc.).

The following terminology is used throughout this specification to identify Protocol-level features:

- PCIe Flit mode: To reference Flit mode-related Protocol features defined in *PCIe Base Specification*
- PCIe non-Flit mode: To reference non-Flit mode-related Protocol features defined in *PCIe Base Specification*
- CXL 68B Flit mode: To reference 68B Flit mode-related Protocol features defined in *CXL Specification*
- CXL 256B Flit mode: To reference 256B Flit mode-related Protocol features defined in *CXL Specification*

The following protocol mappings are supported over the UCIE mainband:

- PCIe Flit mode
- CXL 68B Flit mode, CXL 256B Flit Mode: If CXL is negotiated, each of CXL.io, CXL.cache, and CXL.mem protocols are negotiated independently.
- Streaming protocol: This offers generic modes for a user defined protocol to be transmitted using UCIE.
- Management Transport protocol: This allows transport of manageability packets.

**Note:** RCD/RCH/eRCD/eRCH are not supported. PCIe non-Flit Mode is supported using CXL.io 68B Flit Format as the transport mechanism.

The Protocol Layer requirements for interoperability are as follows:

- A Protocol Layer must support PCIe non-Flit mode if it is advertising the 68B Flit Mode parameter from [Table 3-1](#).
- If a Protocol Layer supports CXL 256B Flit Mode, it must support PCIe Flit Mode and 68B Flit Mode as defined in *CXL Specification* for CXL.io protocol.
- A Protocol Layer advertising CXL is permitted to only support CXL 68B Flit Mode without supporting CXL 256B Flit Mode or PCIe Flit Mode

## IMPLEMENTATION NOTE

Table 2-1 summarizes the mapping of the above rules from a specification version to a protocol mode.

**Table 2-1. Specification to protocol mode requirements**

| Native Specification Supported <sup>a</sup> | PCIe Non-Flit Mode     | CXL 68B Flit Mode | CXL 256B Flit Mode | PCIe Flit Mode         |
|---------------------------------------------|------------------------|-------------------|--------------------|------------------------|
| PCIe                                        | Mandatory              | N/A               | N/A                | Optional               |
| CXL 2.0                                     | Mandatory (for CXL.io) | Mandatory         | N/A                | N/A                    |
| CXL 3.0                                     | Mandatory (for CXL.io) | Mandatory         | Mandatory          | Mandatory (for CXL.io) |

a. The same table applies to derivative version numbers for the specifications.

The Die-to-Die (D2D) Adapter negotiates the protocol with the remote Link partner and communicates it to the Protocol Layer(s). For each protocol, UCIe supports multiple modes of operation (that must be negotiated with the remote Link partner depending on the advertised capabilities, Physical Layer Status as well as usage models). These modes have different Flit Formats and are defined to enable different trade-offs around efficiency, bandwidth and interoperability. The spectrum of supported protocols, advertised modes and Flit Formats must be determined at SoC integration time or during the Die-specific reset bring up flow. The Die-to-Die Adapter uses this information to negotiate the operational mode as a part of Link Training and informs the Protocol Layer over the Flit-aware Die-to-Die Interface (FDI). See [Section 3.2](#) for parameter exchange rules in the Adapter.

The subsequent sections provide an overview of the different modes from the Protocol Layer's perspective, hence they cover the supported formats of operation as subsections per protocol. The Protocol Layer is responsible for transmitting data over FDI in accordance with the negotiated mode and Flit Format. The illustrations of the Flit Formats in this chapter show an example configuration of a 64B data path in the Protocol Layer mapped to a 64-Lane module of Advanced Package configuration on the Physical Link of UCIe. Certain Flit Formats have dedicated bit positions filled in by the Adapter, and details associated with these are illustrated separately in [Chapter 3.0](#). For other Link widths, see the Byte to Lane mappings defined in [Section 4.1.1](#). [Figure 2-1](#) shows the legend for color-coding convention used when showing bytes within a Flit in the Flit Format examples in the UCIe Specification.

**Figure 2-1. Color-coding Convention in Flit Format Byte Map Figures**

| Color Shading | Description                                                                    |
|---------------|--------------------------------------------------------------------------------|
| Light Green   | Some bits populated by the Protocol Layer, some bits populated by the Adapter. |
| Light Orange  | All bits populated by Adapter.                                                 |
| Light Blue    | All bits populated by the Protocol Layer.                                      |

## 2.1 PCIe

UCIe supports the Flit Mode defined in *PCIe Base Specification*. See *PCIe Base Specification* for the protocol definition. UCIe supports the non-Flit Mode using the CXL.io 68B Flit Formats as the transport mechanism. There are five UCIe operating formats supported for PCIe, and these are defined in the subsections that follow.

### 2.1.1 Raw Format

This format is optional. All bytes are populated by the Protocol Layer. The intended usage is for UCIe Retimers transporting PCIe protocol. An example usage of this format is where a CPU and an I/O Device are in different Rack/chassis and connected through a UCIe Retimer using Off-Package Interconnect as shown in [Figure 1-2](#). Retry, CRC and FEC (if applicable) are taken care of by the Protocol Layer when using Raw Format. It is strongly recommended for the UCIe Retimers to check and count errors using either the parity bits of the 6B FEC or the Flit Mode 8B CRC defined in *PCIe Base Specification* for this mode to help characterize the Off Package Interconnect (to characterize or debug the Link that is the dominant source of errors). See [Section 3.3.1](#) as well.

### 2.1.2 Standard 256B End Header Flit Format

This format is mandatory when PCIe Flit Mode protocol is supported. It is the standard Flit Format defined in *PCIe Base Specification* for Flit Mode and the main motivation of supporting this Flit Format is to enable interoperability with vendors that only support the standard PCIe Flit Formats. The Protocol Layer must follow the Flit Formats for Flit transfer on FDI, driving 0 on the fields reserved for Die-to-Die Adapter. The PM and Link Management DLLPs are not used over UCIe. The other DLLPs (that are applicable for PCIe Flit Mode) and Flit Status definitions follow the same rules including packing as defined in *PCIe Base Specification*. It is strongly recommended for implementations to optimize out any 8b/10b, 128b/130b, and non-Flit Mode related CRC/Retry or framing logic from the Protocol Layer in order to obtain area and power efficient designs for UCIe applications. Portions of the DLP bytes must be driven by the Protocol Layer for Flit\_Marker assignment; see [Section 3.3.3](#) for details of the Flit Format.

### 2.1.3 68B Flit Format

This mode is mandatory when PCIe protocol or CXL protocol is supported. The transport mechanism for this is the same as CXL.io 68B Flit Formats. See [Section 2.3.2](#) for the CXL.io DLLP rules that apply for Non-Flit Mode for PCIe as well. It is strongly recommended for implementations to optimize out any 8b/10b, 128b/130b and non-Flit Mode related CRC/Retry logic from the Protocol Layer in order to obtain area and power efficient designs for UCIe applications. To keep the framing rules consistent, Protocol Layer for PCIe non-Flit mode must still drive the LCRC bytes with a fixed value of 0, and the Receiver must ignore these bytes and never send any Ack or Nak DLLPs. Framing tokens are applied as defined for CXL.io 68B Flit Mode operation in *CXL Specification*. It is recommended for the transmitter to drive the sequence number, DLLP CRC, Frame CRC and Frame parity in STP to 0; the receiver must ignore these fields. Given that UCIe Adapter provides reliable Flit transport, framing errors, if detected by the Protocol Layer, are likely due to uncorrectable internal errors and it is permitted to treat them as such.

### 2.1.4 Standard 256B Start Header Flit Format

This is an optional format for PCIe Flit Mode, supported if Standard Start Header for PCIe protocol Capability is supported. The Protocol Layer must follow the Flit Formats for Flit transfer on FDI, driving 0 on the fields reserved for Die-to-Die Adapter. The PM and Link Management DLLPs are not used over UCIe. The other DLLPs (that are applicable for PCIe Flit Mode) and Flit Status definitions follow the same rules including packing as defined in *PCIe Base Specification*. It is strongly recommended for implementations to optimize out any 8b/10b, 128b/130b and non-Flit Mode related CRC/Retry or framing logic from the Protocol Layer in order to obtain area and power efficient designs for UCIe applications. Portions of the DLP bytes must be driven by the Protocol Layer for Flit\_Marker assignment; see [Section 3.3.3](#) for details of the Flit Format.

## 2.1.5 Latency-Optimized 256B with Optional Bytes Flit Format

This is an optional format for PCIe Flit Mode, supported if Latency-Optimized Flit with Optional Bytes for PCIe protocol capability is supported. It is the Latency-Optimized Flit with Optional Bytes Flit Format for PCIe, as defined in [Section 3.3.4](#). The Protocol Layer must follow the Flit Formats for Flit transfer on FDI, driving 0 on the fields reserved for Die-to-Die Adapter. The PM and Link Management DLLPs are not used over UCIe. The other DLLPs (that are applicable for PCIe Flit Mode) and Flit Status definitions follow the same rules including packing as defined in *PCIe Base Specification*. It is strongly recommended for implementations to optimize out any 8b/10b, 128b/130b and non-Flit Mode related CRC/Retry or framing logic from the Protocol Layer in order to obtain area and power efficient designs for UCIe applications. Portions of the DLP bytes must be driven by the Protocol Layer for Flit\_Marker assignment; see [Section 3.3.4](#) for details of the Flit Format.

## 2.2 CXL 256B Flit Mode

See *CXL Specification* for details on the protocol layer messages and slot formats for "CXL 256B Flit Mode". There are four possible operational formats for this protocol mode (there are two formats in [Section 2.2.3](#)), defined in the subsections that follow. The light orange bytes are inserted by the Adapter (see [Figure 2-1](#)). In cases where these are shown as part of the main data path (e.g., in the Standard 256B Flit Format), the Protocol Layer must drive 0 on them on the Transmitter, and ignore them on the Receiver.

### 2.2.1 Raw Format

This format is optional. All bytes are populated by the Protocol Layer. The intended usage is for UCIe Retimers transporting CXL 256B Flit Mode protocol. An example usage of this format is where a CPU and an I/O Device are in different Rack/chassis and connected through a UCIe Retimer using Off-Package Interconnect. Retry, CRC and FEC are taken care of by the Protocol Layer. It is strongly recommended for the UCIe Retimers to check and count errors using either the parity bits of the 6B FEC or the Flit Mode 8B CRC or 6B CRC; depending on which Flit Format was enabled. This helps to characterize and debug the Off-Package Interconnect which is the dominant source of errors. For CXL.cachemem, Viral or poison containment (if applicable) must be handled within the Protocol Layer for this format. See [Section 3.3.1](#) as well.

### 2.2.2 Latency-Optimized 256B Flit Formats

The support for this format is strongly recommended for "CXL 256B Flit Mode" over UCIe. Two Flit Formats are defined, which provide two independent operating points. These formats are derived from the Latency-Optimized Flits defined in *CXL Specification*. The only difference for the second Flit Format is that it gives higher Flit packing efficiency by providing Protocol Layer with extra bytes. For CXL.io this results in extra 4B of TLP information, and for CXL.cachemem it results in an extra 14B H-slot that can be packed in the Flit. This slot is ordered between Slots 7 and 8. It is included in both Groups B and C, similar to Slot 7. See *CXL Specification* for reference of the packing rules. Support for the first or second format is negotiated at the time of Link bring up. See [Section 3.3.4](#) for the details for the Flit Formats.

The Latency-Optimized formats enable the Protocol Layer to consume the Flit at 128B boundary, reducing the accumulation latency significantly. When this format is negotiated, the Protocol Layer must follow this Flit Format for Flit transfer on FDI, driving 0 on the fields reserved for Die-to-Die Adapter.

The Ack, Nak, PM, and Link Management DLLPs are not used over UCIe for CXL.io for any of the 256B Flit Modes. The other DLLPs and Flit\_Marker definitions follow the same rules as defined in *CXL Specification*. Portions of the DLP bytes must be driven by the Protocol Layer for Flit\_Marker assignment; see [Section 3.3.3](#) for details on how DLP bytes are driven.

For CXL.cachemem for this mode, FDI provides an `lp_corrupt_crc` signal to help optimize for latency while guaranteeing Viral containment. See [Chapter 10.0](#) for details of interface rules for Viral containment.

### 2.2.3 Standard 256B Start Header Flit Format

This format is mandatory when “CXL 256B Flit Mode” protocol is supported. It is the Standard 256B Flit Format defined in *CXL Specification* for 256B Flit Mode and the main motivation of supporting this Flit Format is to enable interoperability with vendors that only support the Standard 256B Flit Formats. The Protocol Layer must follow the Flit Formats for Flit transfer on FDI, driving 0 on the fields reserved for Die-to-Die Adapter. The Ack, Nak, PM, and Link Management DLLPs are not used over UCIE for CXL.io. The other DLLPs and Flit Status definitions follow the same rules and packing as defined in *CXL Specification*. Portions of the DLP bytes must be driven by the Protocol Layer for Flit\_Marker assignment; see [Section 3.3.3](#) for details of the Flit Formats and on how DLP bytes are driven.

For CXL.cachemem in this format, FDI provides an `lp_corrupt_crc` signal to help optimize for latency while guaranteeing Viral containment. See [Section 10.2](#) for details of interface rules for Viral containment.

See [Section 3.3.3](#) for details about this Flit Format.

## 2.3 CXL 68B Flit Mode

The *CXL Specification* provides details on the protocol layer messages and slot formats for CXL 68B Flit Mode. There are two operational formats possible for this protocol, and these are defined in the subsections that follow. The light orange bytes are inserted by the Adapter (see [Figure 2-1](#)).

### 2.3.1 Raw Format

This format is optional. All bytes are populated by the Protocol Layer. The intended usage is for UCIE Retimers transporting “CXL 68B Flit Mode” protocol. An example usage of this format is where a CPU and an I/O Device are in different Rack/chassis and connected through a UCIE Retimer using an Off-Package Interconnect. Retry and CRC are taken care of by the Protocol Layer. See [Section 3.3.1](#) as well.

### 2.3.2 68B Flit Format

This format is mandatory when CXL 68B Flit Mode protocol is negotiated. This follows the corresponding 68B Flit Format defined in *CXL Specification* and the main motivation of supporting this Flit Format is to enable interoperability with vendors that only support the baseline CXL formats. The Protocol Layer presents 64B of the Flit (excluding the Protocol ID and CRC) on FDI (shown in [Figure 2-2](#)), and the Die-to-Die Adapter inserts a 2B Flit Header and 2B CRC and performs the byte shifting required to arrange the Flits in the format shown in [Figure 3-11](#).

The Ack, Nak, and PM DLLPs are not used for CXL.io in this mode. Credit updates and other remaining DLLPs for CXL.io are transmitted in the Flits as defined in *CXL Specification*. For CXL.io, the Transmitter must not implement Retry in the Protocol Layer (because Retry is handled in the Adapter). To keep the framing rules consistent, Protocol Layer for CXL.io must still drive the LCRC bytes with a fixed value of 0, and the Receiver must ignore these bytes and never send any Ack or Nak DLLPs. Framing tokens are applied as defined for CXL.io 68B Flit Mode operation. It is recommended for the transmitter to drive the sequence number, DLLP CRC, Frame CRC and Frame parity in STP to 0. The receiver must ignore these fields. Given that UCIE Adapter provides reliable Flit

transport, framing errors, if detected by the Protocol Layer are likely due to uncorrectable internal errors and it is permitted to treat them as such.

For CXL.cachemem, the “Ak” field defined by *CXL Specification* in the Flit is reserved, and the Retry Flits are not used (because Retry is handled in the Adapter). Link Initialization begins with sending the INIT.Param Flit without waiting for any received Flits. Viral containment (if applicable) must be handled within the Protocol Layer for the 68B Flit Mode. *CXL Specification* introduced Error Isolation as a way to reduce the blast radius of downstream component fatal errors compared to CXL Viral Handling and provide a scalable way to handle device failures across a network of switches shared between multiple Hosts. Specifically, Viral relies on a complete host reset to recover whereas Error Isolation may recover by resetting the virtual hierarchy below the root port. Because CXL-defined Retry Flits (which carry the viral notification for 68B Flits in CXL) are not used in 68B Flit mode in UCIE, it is recommended for implementations to rely on error isolation at the CXL Root Port for fatal errors on CXL.cachemem downstream components in 68B Flit mode (similar to Downstream Port Containment for CXL.io).

**Figure 2-2. 68B Flit Format on FDI<sup>a</sup>**



a. See [Figure 2-1](#) for color mapping.

## 2.4 Streaming Protocol

This is the default protocol that must be advertised if none of the PCIe or CXL protocols are going to be advertised and negotiated with the remote Link partner. If Streaming Flit Format capability is not supported, then the operational formats that can be used are either Raw Format or vendor defined extensions. Streaming Flit Format capability is supported if any of 68B Flit Format for Streaming Protocol, Standard 256B End Header Flit Format for Streaming Protocol, Standard 256B Start Header Flit Format for Streaming Protocol, Latency-Optimized 256B Flit Format without Optional Bytes for Streaming Protocol or Latency-Optimized 256B Flit Format with Optional Bytes for Streaming Protocol bits are set in the UCIE Link Capability register.

### 2.4.1 Raw Format

This is mandatory for Streaming protocol support in Adapter implementations. Protocol Layer interoperability is vendor defined. All bytes are populated by the Protocol Layer. See [Section 3.3.1](#) as well.

### 2.4.2 68B Flit Format

This format is only applicable if Streaming Flit Format capability is supported. It is an optional format that permits implementations to utilize the 68B Flit Format from the Adapter for Streaming protocols. See [Section 3.3.2](#) for details of the Flit Format.

The Protocol Layer presents 64B per Flit on FDI, and the Die-to-Die Adapter inserts a 2B Flit Header and 2B CRC and performs the byte shifting required to arrange the Flits in the format shown in [Figure 3-11](#). On the receive data path, the Adapter strips out the Flit Header and CRC bytes to only present the 64B per Flit to the Protocol Layer on FDI.

### 2.4.3 Standard 256B Flit Formats

This format is only applicable if Streaming Flit Format capability is supported. Implementations are permitted to utilize the Standard 256B Start Header Flit Format or Standard 256B End Header Flit

Format from the Adapter for Streaming protocols. See [Section 3.3.3](#) for details of the Flit Format and to see which of the reserved fields in the Flit Header are driven by the Protocol Layer. The Protocol Layer presents 256B per Flit on FDI, driving 0b on the bits reserved for the Adapter. The Adapter fills in the applicable Flit Header and CRC bytes. On the Rx datapath, the Adapter forwards the Flit received from the Link as it is, and the Protocol Layer must ignore the bits reserved for the Adapter (for example the CRC bits).

#### **2.4.4 Latency-Optimized 256B Flit Formats**

This format is applicable only when Streaming Flit Format capability is supported. Implementations are permitted to utilize the Latency-Optimized 256B with Optional Bytes Flit Format or Latency-Optimized 256B without Optional Bytes Flit Format for Streaming protocols. See [Section 3.3.4](#) for details of the Flit Format and to see which of the reserved fields in the Flit Header are driven by the Protocol Layer. The Protocol Layer presents 256B per Flit on FDI, driving 0b on the bits reserved for the Adapter. The Adapter fills in the applicable Flit Header and CRC bytes. On the Rx datapath, the Adapter forwards the Flit received from the Link as is, and the Protocol Layer must ignore the bits reserved for the Adapter (e.g., the CRC bits).

### **2.5 Management Transport Protocol**

This protocol is used to carry management network packets over the mainband. The format for these packets is shown in [Section 8.2.2.2](#). The 68B Flit Format is not permitted for this protocol. Raw mode and any of the 256B Flit Formats are permitted for this protocol. When using the 256B Flit Formats, the Protocol Layer presents 256B per Flit on the FDI, driving 0 on the bits that are reserved for the Adapter. The Adapter fills in the applicable Flit Header and CRC bytes. On the Rx data path, the Adapter forwards the Flit received from the Link as is, and the Management Port Gateway must ignore the bits reserved for the Adapter (e.g., the CRC bits).

See [Section 8.2.5.2.3](#) for details of mapping the Management Transport Packets (MTPs) over Management Flits.

§ §

## 3.0 Die-to-Die Adapter

---

The Die-to-Die Adapter is responsible for:

- Reliable data transfer (performing CRC computation and Retry, or parity computation when applicable)
- Arbitration and Muxing (in case of multiple Protocol Layers)
- Link State Management
- Protocol and Parameter negotiation with the remote Link partner.

Figure 3-1 shows a high level description of the functionality of the Adapter.

**Figure 3-1. Functionalities in the Die-to-Die Adapter**



The Adapter interfaces to the Protocol Layer using one or more instances of the Flit-aware Die-to-Die interface (FDI), and it interfaces to the Physical Layer using the raw Die-to-Die interface (RDI). See Chapter 10.0 for interface details and operation.

The D2D Adapter must follow the same rules as the Protocol Layer for protocol interoperability requirements. Figure 3-2 shows example configurations for the Protocol Layer and the Adapter, where the Protocol identifiers (e.g., PCIe) only signify the protocol, and not the Flit Formats. To provide cost

and efficiency trade-offs, UCIe allows configurations in which two protocol stacks are multiplexed onto the same physical Link.

### 3.1 Stack Multiplexing

If the Multi\_Protocol\_Enable parameter is negotiated, two stacks multiplexed on the same physical Link is supported when each protocol stack needs half the bandwidth that the Physical Layer provides. Both stacks must be of the same protocol with the same protocol capabilities. When Multi\_Protocol\_Enable and Management Transport protocol are negotiated for mainband and the Protocol Layer implements the Management Port Gateway multiplexer (MPG mux), the MPG mux must be present on both stacks and the same protocols must be present in both stacks. For example, in [Figure 8-27](#) the Multi\_Protocol\_Enable parameter can be negotiated for config b if both stacks in this configuration have PCIe or both stacks have Streaming. Similarly, the Multi\_Protocol\_Enable parameter can be negotiated for config d in [Figure 8-27](#) if both CXL stacks are identical.

When Multi\_Protocol\_Enable is supported and negotiated, the Adapter must guarantee that it will not send consecutive flits from the same protocol stack on the Link. This applies in all cases including when Flits are sourced from FDI, from Retry Buffer, and when the data stream is paused and restarted. Adapter is permitted to insert NOP Flits to guarantee this (these Flits bypass the Tx Retry buffer, and are not forwarded to the Protocol Layer on the receiver). When Flits are transmitted from the Retry Buffer, it is required to insert NOP Flits as needed to avoid sending consecutive Flits from the same Protocol stack. When Management Transport protocol is negotiated for mainband with Multi\_Protocol\_Enable, the Management Flit carries the same stack identifier as the Protocol Layer it is multiplexed with. From the Adapter perspective, for the purposes of throttling and interleaving, it is treated the same as flits received from the corresponding Protocol Layer. Note that there is no fixed pattern of Flits alternating from different Protocol Layers. For example, a Flit from Protocol Stack 0 followed by a NOP Flit, followed by a Flit from Protocol Stack 0 is a valid transmit pattern. A NOP Flit is defined as a Flit where the protocol identifier in the Flit Header corresponds to the D2D Adapter, and the body of the Flit is filled with all 0 data (the NOP Flit is defined for all Flit Formats supported by the Adapter, for all cases when it is operating in Raw Format). It is permitted for NOP flits to bypass the Retry buffer, as long as the Adapter guarantees that it is not sending consecutive Flits for any of the Protocol Layers. On the receiving side, the Adapter must not forward these NOP flits to the Protocol Layer. The receiving Protocol Layer must be capable of receiving consecutive chunks of the same Flit at the maximum Link speed, but it will not receive consecutive Flits. In addition to the transfer rate, both protocol stacks must operate with the same protocol and Flit Formats. Multi\_Protocol\_Enable and Raw Format are mutually exclusive. Each stack is given a single bit stack identifier that is carried along with the Flit header for de-multiplexing of Flits on the Receiver. The Stack Mux shown maintains independent Link state machines for each protocol stack. Link State transition-related sideband messages have unique message codes to identify which stack's Link State Management is affected by that message.

#### IMPLEMENTATION NOTE

The primary motivation for enabling the Multi\_Protocol\_Enable parameter is to allow implementations to take advantage of the higher bandwidth provided by the UCIe Link for lower-bandwidth individual Protocol Layers, without the need to make a lot of changes to the UCIe Link. For example, two Protocol Layers that support the maximum bandwidth for CXL 68B Flit Mode (i.e., the equivalent of 32 GT/s CXL SERDES bandwidth) can be multiplexed over a UCIe Link that supports their aggregate bandwidth.

If the Enhanced Multi\_Protocol\_Enable parameter is negotiated, dynamic multiplexing between two stacks of the same or different protocols on the same physical Link is supported. When Enhanced

Multi\_Protocol\_Enable and Management Transport protocol are negotiated, each stack can have different protocols with or without MPG mux. For example, in [Figure 8-27](#), the Enhanced Multi\_Protocol\_Enable parameter must be negotiated for configs e, f, and h. The parameter is also negotiated for configs b and d if the two stacks have different protocol pairs. Both protocol stacks and the Adapter must support a common Flit Format for this feature to be enabled. “Enhanced Multi\_Protocol\_Enable” and Raw Format are mutually exclusive. The Adapter must advertise the maximum percentage of bandwidth that the receiver for each Protocol Layer can accept. The Adapter transmitter must support 100% (no throttling) and throttling one or both Protocol Layer(s) to 50% of maximum bandwidth. When 50% of the maximum bandwidth is advertised for a stack by an Adapter, the remote Link partner must guarantee that it will not send consecutive Flits for the same stack on the Link. This applies in all cases including when Flits are sourced from FDI, from Retry Buffer, and when the data stream is paused and restarted. Adapter is permitted to insert NOP Flits to guarantee this (these Flits bypass the Tx Retry buffer, and are not forwarded to the Protocol Layer on the receiver). When Flits are transmitted from the Retry Buffer, it is required to insert NOP Flits as needed to avoid exceeding the negotiated maximum bandwidth. The receiving Protocol Layer must be capable of sinking Flits at the advertised maximum bandwidth percentage; in addition, Protocol Layer must be able to receive consecutive chunks of the same Flit at the maximum advertised Link speed. When this capability is supported, the Adapter must be capable of allowing each Protocol Layer to independently utilize 100% of the Link bandwidth. Furthermore, the arbitration is per Flit, and the Adapter must support round robin arbitration between the Protocol Layers if both of them are permitted to use 100% of the Link bandwidth. Additional implementation specific arbitration schemes are permitted as long as they are per Flit and do not violate the maximum bandwidth percentage advertised by the remote Adapter for a given stack. The Flit header has a single bit stack identifier to identify the destination stack for the flit. The Stack Mux maintains independent Link state machines for each protocol stack. Link State transition-related sideband messages have unique message codes to identify which stack’s Link State Management is affected by that message.

**Figure 3-2. Example Configurations**

## 3.2 Link Initialization

Link Initialization consists of four stages before protocol Flit transfer can begin on mainband. Figure 3-3 shows the high-level steps involved in the Link initialization flow for UCIe. Stage 0 is die-specific and happens independently for each die; the corresponding boxes in Figure 3-3 are of different sizes to denote that different die can take different amount of time to finish Stage 0. Stage 1 involves sideband initialization. Stage 2 involves mainband training and repair. Details of Stage 1 and Stage 2 are provided in Chapter 4.0. Stage 3 involves parameter exchanges between Adapters to negotiate the protocol and Flit Formats and is covered in Section 3.2.1.

**Figure 3-3. Stages of UCIe Link Initialization**



### 3.2.1 Stage 3 of Link Initialization: Adapter Initialization

Stage 2 is complete when the RDI state machine moves to Active State. The initialization flow on RDI to transition the state from Reset to Active is described in Section 10.1.6. Once Stage 2 is complete, the Adapter must follow a sequence of steps in order to determine Local Capabilities, complete Parameter Exchanges, and bring FDI state machine to Active.

#### 3.2.1.1 Part 1: Determine Local Capabilities

The Adapter must determine the results of Physical Layer training and if Retry is needed for the given Link speed and configuration. See Section 3.8 for the rules on when Retry must be enabled for Link operation. If the Adapter is capable of supporting Retry, it must advertise this capability to the remote

Link partner during Parameter Exchanges. For UCIe Retimers, the Adapter must also determine the credits to be advertised for the Retimer Receiver Buffer. Each credit corresponds to 256B of Mainband data storage.

### 3.2.1.2 Part 2: Parameter Exchange with Remote Link Partner

The following list of capabilities must be negotiated between Link partners. The capabilities (if enabled) are transmitted to the remote Link partner using a sideband message. In the section below, “advertised” means that the corresponding bit is 1b in the {AdvCap.Adapter} sideband message.

**Table 3-1. Capabilities that Must Be Negotiated between Link Partners (Sheet 1 of 2)**

| Capability              | Description and Requirements                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| “Raw Format”            | This parameter is advertised if the corresponding bit in the UCIe Link Control register is 1b. Software/Firmware enables this based on system usage scenario. If the PCIe or CXL protocols are not supported, and Streaming protocol is to be negotiated without any vendor-specific extensions and without Streaming Flit Format capability support, “Raw Format” must be 1b and advertised. If Streaming Flit Format capability or Enhanced Multi-Protocol capability is supported, then this must be advertised as 1b only if Raw Format is the intended format of operation. Software/firmware-based control on setting the corresponding UCIe Link Control is permitted to enable this. |
| “68B Flit Mode”         | This is a protocol parameter. This must be advertised if the Adapter and Protocol Layer support CXL 68B Flit mode (mandatory for CXL) or PCIe Non-Flit mode (mandatory for PCIe). If PCIe Non-Flit mode is the final negotiated protocol, it will use the CXL.io 68B Flit mode formats as defined in <i>CXL Specification</i> . This is an advertised Protocol for Stack 0 if “Enhanced Multi_Protocol_Enable” is supported and enabled.                                                                                                                                                                                                                                                     |
| “CXL 256B Flit Mode”    | This is a protocol parameter. This must be advertised if the Adapter and Protocol Layer support CXL 256B Flit mode. This is an advertised Protocol for Stack 0 if Enhanced Multi-Protocol capability is supported and enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| “PCIe Flit Mode”        | This is a protocol parameter. This must be advertised if the Adapter and Protocol Layer support PCIe Flit mode. This is an advertised Protocol for Stack 0 if Enhanced Multi-Protocol capability is supported and enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| “Streaming”             | This is a protocol parameter. This must be advertised if the Adapter and Protocol Layer support Streaming protocol in Raw Format or Streaming Flit Format capability is supported and the corresponding capabilities are enabled. This is an advertised Protocol for Stack 0 if Enhanced Multi-Protocol capability is supported and enabled. PCIe or CXL protocol must not be advertised if Streaming is advertised for a given Protocol Layer.                                                                                                                                                                                                                                              |
| “Retry”                 | This must be advertised if the Adapter supports Retry. With the exception of the Link operating in Raw Format, the Link cannot be operational if the Adapter has determined Retry is needed, but “Retry” is not advertised or negotiated. See also <a href="#">Section 3.8</a> .                                                                                                                                                                                                                                                                                                                                                                                                             |
| “Multi_Protocol_Enable” | This must only be advertised if the Adapter is connected to multiple FDI instances corresponding to two sets of Protocol Layers. It must only be advertised if the Adapter (or SoC firmware in Stage 0 of Link Initialization) has determined that the UCIe Link must be operated in this mode. Both “Stack0_Enable” and “Stack1_Enable” must be 1b if this bit is advertised.                                                                                                                                                                                                                                                                                                               |
| “Stack0_Enable”         | This must be advertised if the Protocol Layer corresponding to Stack 0 exists and is enabled for operation with support for the advertised protocols.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| “Stack1_Enable”         | This must be advertised if the Protocol Layer corresponding to Stack 1 exists and is enabled for operation with support for the advertised protocols.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| “CXL_LatOpt_Fmt5”       | This must be advertised if the Adapter and Protocol Layer support <i>Format 5</i> defined in <a href="#">Section 3.3.4</a> . The Protocol Layer does not take advantage of the spare bytes in this Flit Format. This must not be advertised if CXL protocol and CXL 256B Flit mode are not supported or enabled.                                                                                                                                                                                                                                                                                                                                                                             |
| “CXL_LatOpt_Fmt6”       | This must be advertised if the Adapter and Protocol Layer support <i>Format 6</i> defined in <a href="#">Section 3.3.4</a> . The Protocol Layer takes advantage of the spare bytes in this Flit Format. This must not be advertised if CXL protocol and CXL 256B Flit mode are not supported or enabled.                                                                                                                                                                                                                                                                                                                                                                                     |
| “Retimer”               | This must be advertised if the Adapter of a UCIe Retimer is performing Parameter Exchanges with a UCIe Die within its package.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| “Retimer_Credits”       | This is a 9-bit value advertising the total credits available for Retimer’s Receiver Buffer. Each credit corresponds to 256B data. This parameter is applicable only when “Retimer” is 1b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Table 3-1. Capabilities that Must Be Negotiated between Link Partners (Sheet 2 of 2)**

| Capability                                                  | Description and Requirements                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "DP"                                                        | This is set by Downstream Ports to inform the remote Link partner that it is a Downstream Port. It is useful for Retimers to identify whether they are connected to a Downstream Port PCIe die. It is currently only applicable for PCIe and CXL protocols; however, Streaming protocols are not precluded from utilizing this bit. If Enhanced Multi-Protocol capability is supported, this bit is applicable if either of the Protocol Layers is PCIe or CXL. This bit must be set to 0b if "Retimer" is set to 1b.                                                       |
| "UP"                                                        | This is set by Upstream Ports to inform the remote Link partner that it is an Upstream Port. It is useful for Retimers to identify whether they are connected to an Upstream Port PCIe die. It is currently only applicable for PCIe and CXL protocols; however, Streaming protocols are not precluded from utilizing this bit. If Enhanced Multi-Protocol capability is supported, this bit is applicable if either of the Protocol Layers is PCIe or CXL. This bit must be set to 0b if "Retimer" is set to 1b.                                                           |
| "68B Flit Format"                                           | This must be advertised if any of the following are true: <ul style="list-style-type: none"> <li>Enhanced Multi-Protocol capability is supported and enabled, AND the 68B Flit Format is supported and enabled</li> <li>The 68B Flit Format for Streaming Protocol capability is supported and enabled</li> </ul> Otherwise, it must be set to 0b.                                                                                                                                                                                                                          |
| "Standard 256B End Header Flit Format"                      | This must be advertised if any of the following are true: <ul style="list-style-type: none"> <li>Enhanced Multi-Protocol capability is supported and enabled, AND the Standard 256B End Header Flit Format is supported and enabled</li> <li>The Standard 256B End Header Flit Format for Streaming Protocol capability is supported and enabled</li> </ul> Otherwise, it must be set to 0b.                                                                                                                                                                                |
| "Standard 256B Start Header Flit Format"                    | This must be advertised if any of the following are true: <ul style="list-style-type: none"> <li>PCIe Flit mode is advertised and Standard Start Header for PCIe protocol capability is supported and enabled</li> <li>Enhanced Multi-Protocol capability is supported and enabled, AND the Standard 256B Start Header Flit Format is supported and enabled</li> <li>The Standard 256B Start Header Flit Format for Streaming Protocol capability is supported and enabled</li> </ul> Otherwise, it must be set to 0b.                                                      |
| "Latency-Optimized 256B without Optional Bytes Flit Format" | This must be advertised if any of the following are true: <ul style="list-style-type: none"> <li>Enhanced Multi-Protocol capability is supported and enabled, AND the Latency-Optimized 256B without Optional Bytes Flit Format is supported and enabled</li> <li>The Latency-Optimized 256B without Optional Bytes Flit Format for Streaming Protocol capability is supported and enabled</li> </ul> Otherwise, it must be set to 0b.                                                                                                                                      |
| "Latency-Optimized 256B with Optional Bytes Flit Format"    | This must be advertised if any of the following are true: <ul style="list-style-type: none"> <li>PCIe Flit mode is advertised and Latency-Optimized Flit with Optional Bytes for PCIe protocol capability is supported and enabled</li> <li>Enhanced Multi-Protocol capability is supported and enabled, AND the Latency-Optimized 256B with Optional Bytes Flit Format is supported and enabled</li> <li>The Latency-Optimized 256B with Optional Bytes Flit Format for Streaming Protocol capability is supported and enabled</li> </ul> Otherwise, it must be set to 0b. |
| "Enhanced Multi_Protocol_Enable"                            | This must only be advertised if the Adapter is connected to multiple FDI instances corresponding to two sets of Protocol Layers. The two sets of Protocol Layers are permitted to be different protocols, but must support at least one common Flit Format. This must only be advertised if the Enhanced Multi-Protocol capability is supported and enabled; otherwise, it must be set to 0b. Both "Stack0_Enable" and "Stack1_Enable" must be 1b if this bit is advertised.                                                                                                |
| "Stack 0 Maximum Bandwidth_Limit"                           | This must be advertised if Enhanced Multi_Protocol_Enable is advertised and the Stack 0 protocol Receiver is limited to 50% of the maximum bandwidth; otherwise, it must be set to 0b.                                                                                                                                                                                                                                                                                                                                                                                      |
| "Stack 1 Maximum Bandwidth_Limit"                           | This must be advertised if Enhanced Multi_Protocol_Enable is advertised and the Stack 1 protocol Receiver is limited to 50% of the maximum bandwidth; otherwise, it must be set to 0b.                                                                                                                                                                                                                                                                                                                                                                                      |
| "Management Transport Protocol"                             | This bit must be set to 1 if the Protocol Layer and Adapter both support Management Transport protocol (either as the only protocol or multiplexed with one of CXL.io, PCIe, or Streaming). The mechanism by which this bit is set to 1 is implementation-specific.                                                                                                                                                                                                                                                                                                         |

Once local capabilities are established, the Adapter sends the {AdvCap.Adapter} sideband message advertising its capabilities to the remote Link partner.

If PCIe or CXL protocol support is going to be advertised, the Upstream Port (UP) Adapter must wait for the first {AdvCap.Adapter} message from the Downstream Port (DP) Adapter, review the capabilities advertised by DP and then send its own sideband message of advertised capabilities. UP is permitted to change its advertised capabilities based on DP capabilities. Once the DP receives the capability advertisement message from the UP, the DP responds with the Finalized Configuration using {FinCap.Adapter} sideband message to the UP as shown in [Figure 3-4](#). See [Section 7.1.2.3](#) to see the message format for the relevant sideband messages.

Final determination for Protocol parameters:

- If “68B Flit Mode” is advertised by both Link partners, it is set to 1 in the {FinCap.Adapter} message
- If “CXL 256B Flit Mode” is advertised by both Link partners, it is set to 1 in the {FinCap.Adapter} message
- If “PCIe Flit Mode” is advertised by both Link partners, “PCIe Flit Mode” bit is set to 1 in the {FinCap.Adapter} message
- If Streaming protocol is negotiated, no {FinCap.Adapter} messages are exchanged for that stack.

If “68B Flit Mode” or “CXL 256B Flit Mode” is set in the {FinCap.Adapter} message, there must be another handshake of Parameter Exchanges using the {AdvCap.CXL} and the {FinCap.CXL} messages to determine the details associated with this mode. Note that because CXL 68B Flit Mode protocol is mandatory for CXL, and because PCIe Non-Flit Mode protocol is mandatory for PCIe, the “68B Flit Mode” parameter is always set to 1 for CXL or PCIe protocols. This additional handshake is shown in [Figure 3-4](#). The combination of {FinCap.CXL} and {FinCap.Adapter} determine the Protocol and Flit Format. See [Section 7.1.2.3](#) for the message format of the relevant sideband messages. See [Section 3.4](#) for how Protocol and Flit Formats are determined.

Final determination for other parameters if CXL or PCIe protocol is negotiated:

- If “Raw Format” is advertised by both Link partners, “Raw Format” is set to 1 in the {FinCap.Adapter} message.
- If both Link partners advertised “Retry” and “Raw Format” is not negotiated, Adapter Retry is enabled and “Retry” is set to 1 in the {FinCap.Adapter} message.
- If both Link partners advertised “Enhanced Multi\_Protocol\_Enable”, both Stack 0 and Stack 1 are enabled by the adapter, and all three parameters (“Enhanced Multi\_Protocol\_Enable”, “Stack0\_Enable” and “Stack1\_Enable”) are each set to 1 in the {FinCap.Adapter} message (if a {FinCap.Adapter} message is required to be sent).
- If both Link partners advertised “Multi\_Protocol\_Enable” and “Enhanced Multi\_Protocol\_Enable” is not negotiated, both Stack 0 and Stack 1 are enabled by the Adapter, and all three parameters (“Multi\_Protocol\_Enable”, “Stack0\_Enable”, and “Stack1\_Enable”) are each set to 1 in the {FinCap.Adapter} message.
- If neither “Enhanced Multi\_Protocol\_Enable” nor “Multi\_Protocol\_Enable” is negotiated, then the lowest common denominator is used to determine whether Stack 0 or Stack 1 is enabled, and the corresponding bit is set to 1 in the {FinCap.Adapter} message. If both Stack enables are advertised, then Stack 0 is selected for operational mode and only Stack0\_Enable is set to 1 in the {FinCap.Adapter} message.
- If CXL\_LatOpt\_Fmt5 is advertised by both Link partners, then it is set to 1 in the {FinCap.Adapter} message.

- If CXL\_LatOpt\_Fmt6 is advertised by both Link partners, then it is set to 1 in the {FinCap.Adapter} message.

**Figure 3-4. Parameter Exchange for CXL or PCIe (i.e., “68B Flit Mode” or “CXL 256B Flit Mode” is 1 in {FinCap.Adapter})**



If Streaming protocol is negotiated, there is no notion of DP and UP for parameter exchanges and each side independently advertises its capabilities. Additional Vendor Defined sideband messages are permitted to be exchanged to negotiate vendor-specific extensions. See [Table 7-8](#) and [Table 7-10](#) for additional descriptions of Vendor Defined sideband messages. Similarly, if Management Transport protocol is negotiated on a stack without “Streaming protocol,” “CXL 256B Flit mode,” or “PCIe Flit mode,” there is no notion of DP and UP for parameter exchanges and each side independently advertises its capabilities.

The Finalized Configuration is implicitly determined based on the intersection of capabilities advertised by each side:

- Flit Formats are chosen based on the Truth Table resolution provided in [Table 3-10](#)
- If both Link partners advertised Retry, and “Raw Format” is not negotiated, then Adapter Retry is enabled
- If “Multi\_Protocol\_Enable” is negotiated, both Stack 0 and Stack 1 are enabled by the adapter
- If neither “Multi\_Protocol\_Enable” nor “Enhanced Multi\_Protocol\_Enable” is advertised by at least one of the Link partners, then the lowest common denominator is used to determine whether Stack 0 or Stack 1 is enabled (i.e., if both Stack enables are advertised, then Stack 0 is selected for operational mode)

{FinCap.\*} messages are not sent for Streaming protocol. Adapter must determine vendor specific requirements in an implementation specific manner.

If "Enhanced Multi\_Protocol\_Enable" is negotiated, the {AdvCap.Adapter} and if applicable, the {FinCap.Adapter} messages determine the negotiated Flit Format of operation as well as the protocol for Stack 0. The Adapter uses {MultiProtAdvCap.Adapter} and if applicable, the {MultiProtFinCap.Adapter} sideband messages to negotiate the Stack 1 protocol. For Stack 1, if PCIe or CXL protocol support is going to be advertised, the UP Adapter must wait for the first message from the DP Adapter, review the capabilities advertised by DP and then send its own sideband message of advertised capabilities. UP is permitted to change its advertised capabilities based on DP capabilities. In the section below, "advertised" means that the corresponding bit is 1b in the {MultiProtAdvCap.Adapter} sideband message.

- "68B Flit Mode": This must be advertised if the Adapter and Protocol Layer support CXL 68B Flit Mode or PCIe Non-Flit Mode on Stack 1.
- "CXL 256B Flit Mode": This must be advertised if the Adapter and Protocol Layer support CXL 256B Flit Mode on Stack 1.
- "PCIe Flit Mode": This must be advertised if the Adapter and Protocol Layer support PCIe Flit Mode on Stack 1.
- "Streaming": This must be advertised if the Adapter and Protocol Layer support Streaming Flit Mode on Stack 1.
- "Management Transport Protocol": This must be advertised if the Protocol Layer supports Management Transport protocol on Stack 1.

If "68B Flit Mode" or "CXL 256B Flit Mode" is set in the {MultiProtFinCap.Adapter} message, there must be another handshake of Parameter Exchanges using the {AdvCap.CXL} and the {FinCap.CXL} messages to determine the details associated with this mode. The non-Stall {\*}.CXL} messages are sent with a MsgInfo encoding of 0001h indicating that these messages are for Stack 1 negotiation.

[Figure 3-5](#) to [Figure 3-9](#) represent examples of different scenarios where Stack 0 and Stack 1 are of different protocols.

**Figure 3-5. Both Stacks are CXL or PCIe**

**Figure 3-6. Stack 0 is PCIe, Stack 1 is Streaming****Figure 3-7. Stack 0 is Streaming, Stack 1 is PCIe**

**Figure 3-8. Both Stacks are Streaming**

**Figure 3-9. Stack 0 is Streaming, Stack 1 is CXL**

The Adapter must implement a timeout of 8 ms (-0%/+50%) for successful Parameter Exchange completion. For the purposes of measuring a timeout for Parameter Exchange completion, all steps in Part 1 and Part 2 of Stage 3 of Link Initialization are included. The timer only increments while RDI is in Active state. The timer must reset if the Adapter receives an {AdvCap.\*.Stall}, {FinCap.\*.Stall}, {MultiProtAdvCap.\*.Stall}, or {MultiProtFinCap.\*.Stall} message from the remote Link partner. The 8-ms timeouts for Parameter Exchanges or Link State Machine transitions are treated as UIE and the Adapter must take the RDI to LinkError state. UCIe Retimers must ensure that they resolve the capability advertisement with remote Retimer partner (and merge with their own capabilities) before responding/initiating parameter exchanges with the UCIe die within its package. While resolution is in progress, they must send the corresponding stall message once every 4 ms to ensure that a timeout does not occur on the UCIe die within its package.

### 3.2.1.3 Part 3: FDI bring up

Once Parameter Exchanges have successfully completed, the Adapter reflects the result to the Protocol Layers on FDI, and moves on to carry out the FDI bring up flow as defined in [Section 10.2.8](#). Once FDI is in Active state, it concludes Stage 3 of Link Initialization and protocol Flit transfer can begin. When multiple stacks are enabled on the same Adapter, each stack may finish the FDI bring up flow (see [Section 10.2.8](#)) at different times.

The data width on FDI is a function of the frequency of operation of the UCIe stack as well as the total bandwidth being transferred across the UCIe physical Link (which in turn depends on the number of Lanes and the speed at which the Lanes are operating). The data width on RDI is fixed to at least one byte per physical Lane per module that is controlled by the Adapter. The illustrations of the formats in this chapter are showing an example configuration of RDI mapped to a 64 Lane module of Advanced Package configuration on the Physical Layer of UCIe.

### 3.3 Operation Formats

In subsequent sections, when referring to CRC computation, a byte mapping of the Flit to CRC message (CRC message is the 128B input to CRC computation logic) is provided. See [Section 3.7](#) for more details.

#### 3.3.1 Raw Format for All Protocols

Raw Format can only be used for scenarios in which Retry support from the Adapter is not required. If Raw Format is negotiated for CXL or PCIe protocols, the Adapter transfers data from Protocol Layer to Physical Layer without any modification. [Figure 3-10](#) shows an example of this for a 64B data path on FDI and RDI. This is identified as *Format 1* during parameter negotiation.

**Figure 3-10. Format 1: Raw Format<sup>a</sup>**



a. See [Figure 2-1](#) for color mapping.

#### 3.3.2 68B Flit Format

This Flit Format is identified as *Format 2* on UCIe. Support for this is mandatory when CXL 68B Flit Mode protocol or PCIe Non-Flit Mode protocol is supported. 68B Flit Format support is optional for Streaming protocols.

The Protocol Layer sends 64B of protocol information. The Adapter adds a two byte prefix of Flit Header and a two byte suffix of CRC. [Table 3-3](#) gives the Flit Header format for *Format 2* when Retry from the Adapter is required. If Retry from the Adapter is not required, then the Flit Header format is as provided in [Table 3-2](#).

Even if Retry is not required, the Adapter still computes and drives CRC bytes — the Receiver is strongly recommended to treat a CRC error as an Uncorrectable Internal Error in this situation. For CRC computation, Flit Byte 0 (i.e., Flit Header Byte 0) is assigned to CRC message Byte 0, Flit Byte 1 (i.e., Flit Header Byte 1) is assigned to CRC message Byte 1 and so on until Flit Byte 65 is assigned to CRC message Byte 65.

Retry is performed over this 68B Flit.

**Table 3-2. Flit Header for Format 2 without Retry**

| Byte                | Bit   | Description                                                                                                                                                                      |                                                                                                                          |
|---------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
|                     |       | PCIe or CXL                                                                                                                                                                      | Streaming Protocol                                                                                                       |
| Byte 0              | [7:6] | Protocol Identifier:<br>2'b00 : D2D Adapter NOP Flit or PDS Flit Header<br>2'b01 : CXL.io Flit<br>2'b10 : CXL.cachemem Flit<br>2'b11 : ARB/MUX Flit (Reserved encoding for PCIe) | Protocol Identifier:<br>2'b00 : D2D Adapter NOP Flit<br>2'b01 : Protocol Layer Flit<br>Remaining encodings are Reserved. |
|                     | [5]   | Stack Identifier:<br>1'b0 : Stack 0<br>1'b1 : Stack 1                                                                                                                            |                                                                                                                          |
|                     | [4]   | 1'b0 : Regular Flit Header<br>1'b1 : Pause of Data Stream (PDS) Flit Header                                                                                                      |                                                                                                                          |
|                     | [3:0] | Reserved                                                                                                                                                                         |                                                                                                                          |
| Byte 1 <sup>a</sup> | [7]   | 1'b0 : Regular Flit Header<br>1'b1 : Pause of Data Stream (PDS) Flit Header                                                                                                      |                                                                                                                          |
|                     | [6:0] | Reserved                                                                                                                                                                         |                                                                                                                          |

a. For a Test Flit, bits [7:6] of Byte 1 are 01b. See [Section 11.2](#) for more details.

**Table 3-3. Flit Header for Format 2 with Retry**

| Byte                | Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                          |
|---------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
|                     |       | PCIe or CXL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Streaming Protocol                                                                                                       |
| Byte 0              | [7:6] | Protocol Identifier:<br>2'b00 : D2D Adapter NOP Flit or PDS Flit Header<br>2'b01 : CXL.io Flit<br>2'b10 : CXL.cachemem Flit<br>2'b11 : ARB/MUX Flit (Reserved encoding for PCIe)                                                                                                                                                                                                                                                                                                                                       | Protocol Identifier:<br>2'b00 : D2D Adapter NOP Flit<br>2'b01 : Protocol Layer Flit<br>Remaining encodings are Reserved. |
|                     | [5]   | Stack Identifier:<br>1'b0 : Stack 0<br>1'b1 : Stack 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                          |
|                     | [4]   | 1'b0 : Regular Flit Header<br>1'b1 : Pause of Data Stream (PDS) Flit Header                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                          |
|                     | [3:0] | The upper four bits of Sequence number "S" (i.e., S[7:4])                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                          |
| Byte 1 <sup>a</sup> | [7:6] | 2'b00 : Regular Flit Header<br>2'b11 : Pause of Data Stream (PDS) Flit Header<br>Other encodings are reserved                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                          |
|                     | [5:4] | Ack or Nak information<br>2'b00 : Explicit Sequence number "S" of Flit if not PDS, otherwise the bitwise inverted value of "NEXT_TX_FLIT_SEQ_NUM - 1". (See <i>PCIe Base Specification</i> for the definition of NEXT_TX_FLIT_SEQ_NUM and the subtraction operation for sequence numbers)<br>2'b01 : Ack. The Sequence number "S" carries the Ack'ed sequence number.<br>2'b10 : Nak. The Sequence number "S" carries 255 if N=1, otherwise it carries N-1, where N is the Nak'ed sequence number.<br>2'b11 : Reserved |                                                                                                                          |
|                     | [3:0] | The lower four bits of Sequence number "S" (i.e., S[3:0])<br>Sequence number 0 is reserved and if present, it implies no Ack or Nak is sent.                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                          |

a. For a Test Flit, bits [7:6] of Byte 1 are 01b. See [Section 11.2](#) for more details.

### 3.3.2.1 68B Flit Format Alignment and Padding Rules

Because of the four bytes added by D2D Adapter, the alignment of the Flit does not always match the number of Lanes of the physical Link. The bytes added by D2D Adapter require the Adapter to shift the data arriving over FDI by four bytes for consecutive Flits transmitted over RDI. Data is always transferred in multiples of 256B (note that Retimer credits have a 256B data granularity). A mechanism to Pause the Data Stream is provided as a way to save power when the Link is idle. Before pausing the data stream, the data stream is terminated with a Pause of Data Stream (PDS) Flit Header followed by 0b padding to the next 64B count multiple boundary and at least two subsequent 64B chunks of all 0 value data. If the transfer is not at a 256B count multiple boundary, additional 64B chunks of all 0 value data are required to bring the transferred bytes to a 256B count multiple. The subsequent transfers of all 0 data mentioned above give the Receiver at least two 64B chunks to reset the receiving byte shifter. The PDS Flit Header and the 0 padding bytes following it must not be forwarded to the Protocol Layer. The PDS token is a variable-size Flit that carries a 2B special Flit Header (referred to as the PDS Flit Header), and 0 bytes padded as described above. The Transmitter of PDS drives the following on the Flit header:

1. Bit [4] of Byte 0 as 1
2. Bit [7] of Byte 1 as 1
3. Bit [6] of Byte 1 as 1
4. Bits [5:4] of Byte 1 as 00b and the sequence number[7:0] is matching the expected value for a PDS Flit Header in this position as defined in [Table 3-3](#).

The Adapter may optionally insert continuous NOPs instead of terminating the data stream with a PDS when no other flits are available to transmit. There is a trade-off between the longer idle latency for a new flit to be transmitted after a PDS vs. the power consumption of continuously transmitting NOP flits. It is the responsibility of the transmitting Adapter to make the determination between transmitting NOP flits vs. inserting a PDS in an implementation-specific manner.

If Retry is enabled, the Receiver must interpret this Flit header as PDS if any two of the above four conditions are true. If Retry is disabled, the Receiver must interpret this Flit header as a PDS if conditions (1) and (2) are true.

A PDS must be inserted when Retry is triggered or RDI state goes through Retrain. The transmitter must insert PDS Flit Header and corresponding padding of 0s as it would for an actual PDS and start the replayed Flit from fresh alignment (i.e., flit begins from a 256B-aligned boundary). Note that for Retry, this should occur before the Transmitter begins replaying the Flits from the Retry buffer; and for Retrain entry, this should occur before asserting `lp_stallack` to the Physical Layer.

For Retry and Retrain scenarios, the Receiver must also look for the expected sequence number in Byte 0 and Byte 1 of the received data bus with a corresponding valid Flit (i.e., CRC passes). Note that for a Retrain scenario, a PDS might not be received at the receiver before the RDI state changes to Retrain, and the Adapter must discard any partially received 68B Flits after state change.

When resuming the data stream after a PDS token (i.e., a PDS Flit Header and the corresponding padding of 0s), the first Flit is always 256B aligned; any valid Flit transfer after a PDS token will resume the data stream. After a PDS Flit Header has been transmitted, the corresponding padding of 0b to satisfy the PDS token padding requirements must be finished before resuming the data stream with new Flits.

### IMPLEMENTATION NOTE — BIT ERRORS AND ALIASING

When Retry is disabled, the BER of the Link is 1E-27 or lower. In these cases, any bit error is an uncorrectable error for the Link. As a best practice, it is strongly recommended for receiver implementations to have an uncorrectable internal error condition for scenarios in which neither a valid Flit Header nor a valid PDS Flit Header is detected.

When Retry is enabled, the BER is 1E-15 or lower, which results in the probability of two or more bit errors within the Flit Header is very low. However, implementations must consider the following two scenarios:

- **PDS Flit Header aliasing to a regular Flit Header:** Checking for two out of the four conditions guarantees that at least three bit errors must occur within the two bytes of the PDS Flit Header for it to alias to a regular Flit Header. Even for three bit errors, there will be a CRC which will result in a retry and will be handled seamlessly through the retry rules.
- **Regular Flit Header aliasing to a PDS Flit Header:** It is possible for two bit errors to cause a Regular Flit Header to alias to a PDS Flit Header. This will likely result in a CRC error for future Flits. However, to reduce the probability of a data corruption that escapes CRC even further, it is strongly recommended that if a PDS Flit Header was detected without all four conditions being satisfied (i.e., two out of four or three out of four were satisfied), the receiver checks for an explicit sequence number Flit with the expected sequence number in Byte 0 and Byte 1 of the first received data transfer and that it is a valid Flit (i.e., CRC passes) after the PDS (including the PDS token and the corresponding padding) have completed; and triggers a Retry if it does not pass the check. Note that this is the same check a Receiver performs after a Retry or Retrain.

Figure 3-11 shows the 68B Flit Format. Figure 3-12 and Figure 3-13 provide examples of PDS insertion.

**Figure 3-11. Format 2: 68B Flit Format<sup>a</sup>**



- See Figure 2-1 for color mapping.
- Flit 1 Header Byte 0, Flit 1 Header Byte 1, Flit 2 Header Byte 0, Flit 2 Header Byte 1, Flit 3 Header Byte 0, and Flit 3 Header Byte 1 respectively.
- Flit 1 Byte 62 and Byte 63, respectively (from Protocol Layer).
- Flit 1 CRC Byte 0, Flit 1 CRC Byte 1, Flit 2 CRC Byte 0, and Flit 2 CRC Byte 1, respectively.

**Figure 3-12. Format 2: 68B Flit Format PDS Example 1<sup>a</sup>**

|                 |                                   |                     |                     |                     |                     |    |    |                |
|-----------------|-----------------------------------|---------------------|---------------------|---------------------|---------------------|----|----|----------------|
|                 | +0                                | +1                  | +2                  | +3                  | +4                  | +5 | +6 | +63            |
| <b>Byte 0</b>   | FH B0 <sup>b</sup>                | FH B1 <sup>b</sup>  |                     |                     |                     |    |    |                |
| <b>Byte 64</b>  | 2B<br>(from<br>Protocol<br>Layer) | CRC B0 <sup>c</sup> | CRC B1 <sup>c</sup> | PDS B0 <sup>d</sup> | PDS B1 <sup>d</sup> |    |    |                |
| <b>Byte 128</b> |                                   |                     |                     |                     |                     |    |    | 64B all 0 data |
| <b>Byte 192</b> |                                   |                     |                     |                     |                     |    |    | 64B all 0 data |

a. See [Figure 2-1](#) for color mapping.

b. Flit Header Byte 0 and Byte 1, respectively.

c. CRC Byte 0 and Byte 1, respectively.

d. PDS Flit Header Byte 0 and Byte 1, respectively.

**Figure 3-13. Format 2: 68B Flit Format PDS Example 2 — Extra 0s Padded to Make the Data Transfer a Multiple of 256B<sup>a</sup>**

|                 |                     |                     |                     |                     |                     |                     |                    |                    |                     |                     |     |                |
|-----------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--------------------|--------------------|---------------------|---------------------|-----|----------------|
|                 | +0                  | +1                  | +2                  | +3                  | +4                  | +5                  | +6                 | +7                 | +8                  | +9                  | +10 | +63            |
| <b>Byte 0</b>   | F1H B0 <sup>b</sup> | F1H B1 <sup>b</sup> |                     |                     |                     |                     |                    |                    |                     |                     |     |                |
| <b>Byte 64</b>  | F1 B62 <sup>c</sup> | F1 B63 <sup>c</sup> | C1 B0 <sup>d</sup>  | C1 B1 <sup>d</sup>  | F2H B0 <sup>b</sup> | F2H B1 <sup>b</sup> |                    |                    |                     |                     |     |                |
| <b>Byte 128</b> | F2 B58 <sup>e</sup> | F2 B59 <sup>e</sup> | F2 B60 <sup>e</sup> | F2 B61 <sup>e</sup> | F2 B62 <sup>e</sup> | F2 B63 <sup>e</sup> | C2 B0 <sup>d</sup> | C2 B1 <sup>d</sup> | PDS B0 <sup>f</sup> | PDS B1 <sup>f</sup> |     | 54B all 0 data |
| <b>Byte 192</b> |                     |                     |                     |                     |                     |                     |                    |                    |                     |                     |     | 64B all 0 data |
| <b>Byte 256</b> |                     |                     |                     |                     |                     |                     |                    |                    |                     |                     |     | 64B all 0 data |
| <b>Byte 320</b> |                     |                     |                     |                     |                     |                     |                    |                    |                     |                     |     | 64B all 0 data |
| <b>Byte 384</b> |                     |                     |                     |                     |                     |                     |                    |                    |                     |                     |     | 64B all 0 data |
| <b>Byte 448</b> |                     |                     |                     |                     |                     |                     |                    |                    |                     |                     |     | 64B all 0 data |

a. See [Figure 2-1](#) for color mapping.

b. Flit 1 Header Byte 0, Flit 1 Header Byte 1, Flit 2 Header Byte 0, and Flit 2 Header Byte 1, respectively.

c. Flit 1 Byte 62 and Byte 63, respectively (from Protocol Layer).

d. Flit 1 CRC Byte 0, Flit 1 CRC Byte 1, Flit 2 CRC Byte 0, and Flit 2 CRC Byte 1, respectively.

e. Flit 2 Bytes 58 through Byte 63, respectively (from Protocol Layer).

f. PDS Flit Header Byte 0 and Byte, respectively.

### 3.3.3 Standard 256B Flit Formats

These are the Standard Flit Formats defined in *PCIe Base Specification* for PCIe Flit Mode and *CXL Specification* for CXL 256B Flit Mode. These are identified as “Standard 256B End Header Flit Format” (or *Format 3*) and “Standard 256B Start Header Flit Format” (or *Format 4*), respectively. Support for this is mandatory when PCIe Flit Mode or CXL 256B Flit Mode protocols are negotiated. Standard 256B Flit Formats (Start Header or End Header) support is optional with Streaming protocols.

The Protocol Layer sends data in 256B Flits, but it drives 0 on the bytes reserved for the Adapter (shown in light orange in [Figure 3-14](#) through [Figure 3-19](#)). The 6B of DLP defined in *PCIe Base Specification* exist in *Format 3* and *Format 4* as well for PCIe and CXL.io protocols. However, since

DLLPs are required to bypass the Tx Retry buffer in PCIe and CXL.io protocols, the DLP bytes end up being unique since they are partially filled by the Protocol Layer and partially by the Adapter. DLP0 and DLP1 are replaced with the Flit Header for UCIe and are driven by UCIe Adapter. However, if the Flit carries a Flit Marker, the Protocol Layer must populate bit 4 of Flit Header Byte 0 to 1b, as well as the relevant information in the Flit\_Marker bits (these are driven as defined in *PCIe Base Specification*). Protocol Layer must also populate the Protocol Identifier bits in the Flit Header for the Flits it generates.

For Streaming protocols, [Figure 3-17](#) shows the applicable Flit Format. Protocol Layer only populates bits [7:6] of Byte 0 of the Flit Header, and it must never set 00b for bits [7:6].

Standard 256B Start Header Flit Format is optional for PCIe Flit Mode protocol. [Figure 3-18](#) shows the Flit Format example.

FDI provides a separate interface for DLLP transfer from the Protocol Layer to the Adapter and vice-versa. The Adapter is responsible for inserting DLLP into DLP Bytes 2:5 if a Flit Marker is not present. The credit update information is transferred as regular Update\_FC DLLPs over FDI from the Protocol Layer to the Adapter. The Adapter is also responsible for formatting these updates as Optimized\_Update\_FC format when possible and driving them on the relevant DLP bytes. The Adapter is also responsible for adhering to all the DLLP rules defined for Flit Mode in *PCIe Base Specification*. On the receive path, the Adapter is responsible for extracting the DLLPs or Optimized\_Update\_FC from the Flit and driving it on the dedicated DLLP interface provided on FDI.

Two sets of CRC are computed (CRC0 and CRC1). The same 2B over 128B CRC computation as previous formats is used.

For PCIe, CXL, and Streaming:

- For *Format 3*, CRC0 is computed using Flit Bytes 0 to 127 assigned to the corresponding bytes of the CRC message input. CRC1 is computed using Flit Bytes 128 to 241 as the message input with Flit Byte 128 assigned to CRC message Byte 0, Flit Byte 129 assigned to CRC message Byte 1 and so on until Flit Byte 241 is assigned to CRC message Byte 113 (including the Flit Header bits inserted by the Adapter, which for PCIe and CXL.io, includes the DLP bytes inserted by the Adapter).
- For *Format 4*, CRC0 is computed using Flit Bytes 0 to 127 assigned to the corresponding bytes of the CRC message input (including the Flit Header bits inserted by the Adapter). CRC1 is computed using Flit Bytes 128 to 241 as the message input with Flit Byte 128 assigned to CRC message Byte 0, Flit Byte 129 assigned to CRC message Byte 1 and so on until Flit Byte 241 is assigned to CRC message Byte 113 (for PCIe and CXL.io, this includes the DLP bytes inserted by the Adapter).

If Retry is not required, the Adapter still computes and drives CRC bytes — the Receiver is strongly recommended to treat a CRC error as an Uncorrectable Internal Error (UIE) in this situation.

The Flit Header byte formats are shown in [Table 3-5](#) when Retry is required; otherwise, it is as shown in [Table 3-4](#).

The Protocol Layer must drive bits [7:6] in Byte 1 of Flit Header to 00b for CXL/PCIe/Streaming protocol Flits and to 10b for Management Flits (when successfully negotiated).

For Management Flits, Bytes 238 to 241 are driven from the Protocol Layer with Management Transport Credit Return DWORD (CRD) Bytes 0 to 3 (see [Section 8.2.5.2.2](#) for CRD format). Bytes 232 to 235 in *Format 3* and Bytes 234 to 237 in *Format 4* are driven from the Protocol Layer with 0s for Management Flits. See [Figure 3-16](#) and [Figure 3-19](#) for details of *Format 3* and *Format 4* for Management Flits, respectively.

If PCIe/CXL.io is negotiated along with Management Transport protocol on the same stack:

- If bits [7:6] of Byte 1 are 10b, the Adapter passes through Bytes 238 to 241 from the Protocol Layer to the Link
- If bits [7:6] of Byte 1 are 00b, Bytes 238 to 241 are treated per PCIe/CXL.io DLP rules for this flit format

**Figure 3-14. Format 3: Standard 256B End Header Flit Format for PCIe<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 3-15. Format 3: Standard 256B End Header Flit Format for Streaming Protocol<sup>a</sup>**

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

**Figure 3-16. Format 3: Standard 256B End Header Flit Format for Management Transport Protocol<sup>a</sup>**

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

**Figure 3-17. Format 4: Standard 256B Start Header Flit Format for CXL.cachemem or Streaming Protocol<sup>a</sup>**



a. See Figure 2-1 for color mapping.

b. Flit Header Byte 0 and Byte 1, respectively.

c. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Figure 3-18. Format 4: Standard 256B Start Header Flit Format for CXL.io or PCIe<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 3-19. Format 4: Standard 256B Start Header Flit Format for Management Transport Protocol<sup>a</sup>**



a. See Figure 2-1 for color mapping.

b. Flit Header Byte 0 and Byte 1, respectively.

c. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Table 3-4. Flit Header for Format 3, Format 4, Format 5, and Format 6 without Retry**

| Byte | Bit   | Description                                                                                                                                                               |                                                                                                               |                                                                                                                                                                                                                      |                                                                                                                |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
|      |       | CXL 256B Flit Mode                                                                                                                                                        | PCIe Flit Mode                                                                                                | Streaming Protocol                                                                                                                                                                                                   | Management Transport Protocol                                                                                  |
| 0    | [7:6] | Protocol Identifier:<br>00b: D2D Adapter/CXL.io NOP Flit<br>01b: CXL.io Flit<br>10b: CXL.cachemem Flit<br>11b: ARB/MUX Flit                                               | Protocol Identifier:<br>00b: D2D Adapter/PCIe NOP Flit<br>01b: PCIe Flit<br>All other encodings are reserved. | Protocol Identifier:<br>00b: D2D Adapter NOP Flit<br>Remaining encodings are permitted to be used by Protocol Layer in a vendor defined manner. Protocol Layer must never set this to 00b for Flits sent across FDI. | Protocol Identifier:<br>00b: D2D Adapter NOP Flit<br>01b: Management Flit<br>All other encodings are reserved. |
|      | [5]   | Stack Identifier:<br>0: Stack 0<br>1: Stack 1                                                                                                                             |                                                                                                               |                                                                                                                                                                                                                      |                                                                                                                |
|      | [4]   | Reserved for CXL.cachemem<br>For CXL.io or PCIe Flit Mode:<br>0: DLLP Payload in DLP 2..5<br>1: Optimized_Update_FC or Flit_Marker in DLP2..5                             |                                                                                                               | Reserved                                                                                                                                                                                                             |                                                                                                                |
|      | [3:0] | Reserved                                                                                                                                                                  |                                                                                                               |                                                                                                                                                                                                                      |                                                                                                                |
| 1    | [7:6] | Flit Type:<br>00b: CXL/PCIe/Streaming Flit/D2D Adapter NOP Flit<br>01b: Test Flit (see <a href="#">Section 11.2</a> for details)<br>10b: Management Flit<br>11b: Reserved |                                                                                                               |                                                                                                                                                                                                                      |                                                                                                                |
|      | [5:0] | Reserved                                                                                                                                                                  |                                                                                                               |                                                                                                                                                                                                                      |                                                                                                                |

**Table 3-5. Flit Header for Format 3, Format 4, Format 5, and Format 6 with Retry**

| Byte | Bit   | Description                                                                                                                                                                                                                                                                                                       |                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
|      |       | CXL 256B Flit Mode                                                                                                                                                                                                                                                                                                | PCIe Flit Mode                                                                                               | Streaming Protocol                                                                                                                                                                                                   | Management Transport Protocol                                                                                  |
| 0    | [7:6] | Protocol Identifier:<br>00b: D2D Adapter/CXL.io NOP Flit<br>01b: CXL.io Flit<br>10b: CXL.cachemem Flit<br>11b: ARB/MUX Flit                                                                                                                                                                                       | Protocol Identifier:<br>00b: D2D Adapter/PCIe NOP Flit<br>01b: PCIe Flit<br>All other encodings are reserved | Protocol Identifier:<br>00b: D2D Adapter NOP Flit<br>Remaining encodings are permitted to be used by Protocol Layer in a vendor defined manner. Protocol Layer must never set this to 00b for Flits sent across FDI. | Protocol Identifier:<br>00b: D2D Adapter NOP Flit<br>01b: Management Flit<br>All other encodings are reserved. |
|      | [5]   | Stack Identifier:<br>0: Stack 0<br>1: Stack 1                                                                                                                                                                                                                                                                     |                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                |
|      | [4]   | Reserved for CXL.cachemem<br>For CXL.io or PCIe Flit Mode:<br>0: DLLP Payload in DLP 2..5<br>1: Optimized_Update_FC or Flit_Marker in DLP2..5                                                                                                                                                                     |                                                                                                              | Reserved                                                                                                                                                                                                             |                                                                                                                |
|      | [3:0] | The upper four bits of Sequence number "S" (i.e., S[7:4])                                                                                                                                                                                                                                                         |                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                |
| 1    | [7:6] | Flit Type:<br>00b: CXL/PCIe/Streaming Flit/D2D Adapter NOP Flit<br>01b: Test Flit (see <a href="#">Section 11.2</a> for details)<br>10b: Management Flit<br>11b: Reserved                                                                                                                                         |                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                |
|      | [5:4] | Ack or Nak Information:<br>00b: Explicit Sequence number "S" of the current Flit is present.<br>01b: Ack. The sequence number "S" carries the Ack'ed sequence number.<br>10b: Nak. The sequence number "S" carries 255 if N=1; otherwise, it carries N-1; where N is the Nak'ed sequence number.<br>11b: Reserved |                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                |
|      | [3:0] | The lower four bits of Sequence number "S" (i.e., S[3:0]).<br>Sequence number 0 is reserved and if present, it implies no Ack or Nak is sent.                                                                                                                                                                     |                                                                                                              |                                                                                                                                                                                                                      |                                                                                                                |

### 3.3.4 Latency-Optimized 256B Flit Formats

Two Latency-Optimized 256B Flit Formats are defined: *Format 5* and *Format 6*. It is strongly recommended that UCIe implementations support *Format 6* for CXL 256B Flit Mode protocol to get the best latency benefits.

Both formats look the same from the Adapter perspective, the only difference is whether the Protocol Layer is filling in the optional bytes of protocol information . The Latency-Optimized 256B without Optional bytes Flit Format (or *Format 5*) is when the Protocol Layer is not filling in the optional bytes, whereas the Latency-Optimized 256B with Optional bytes Flit Format (or *Format 6*) is when the Protocol Layer is filling in the optional bytes.

Latency-Optimized 256B Flit Formats (with Optional bytes or without Optional bytes) support is optional with Streaming protocols. Protocol Layer only populates bits [7:6] of the Flit Header, and it must never set 00b for bits [7:6].

Latency-Optimized Flit with Optional Bytes Flit Format is optional for PCIe Flit Mode protocol. [Figure 3-23](#) shows the Flit Format example.

Two sets of CRC are computed. CRC0 is computed using Flit Bytes 0 to 125 assigned to the corresponding bytes of the CRC message input (including the Flit Header bits and if applicable, the DLP bits inserted by the Adapter). CRC1 is computed using Flit Bytes 128 to 253 as the message input with Flit Byte 128 assigned to CRC message Byte 0, Flit Byte 129 assigned to CRC message Byte 1 and so on until Flit Byte 253 assigned to CRC message Byte 125. If Retry is not required, the Adapter still computes and drives CRC bytes — the Receiver is strongly recommended to treat a CRC error as UIE in this situation.

For Management Flits (when successfully negotiated), the Protocol Layer must drive bits [7:6] in Byte 1 of Flit Header to 00b for Protocol Flit and to 10b.

For Management Flits using *Format 5*, Bytes 240 to 243 are driven from the Protocol Layer with Management Transport Credit Return DWORD (CRD) Bytes 0 to 3 (see [Section 8.2.5.2.2](#) for CRD format). See [Figure 3-22](#) for details.

If CXL.io is negotiated along with Management Transport protocol on the same stack for *Format 5*:

- If bits [7:6] of Byte 1 are 10b, the Adapter drives 0 on Bytes 122 to 125 and 244 to 253
- If bits [7:6] of Byte 1 are 00b, then Bytes 122 to 125 are treated per the CXL.io DLP rules of this flit format and Bytes 250 to 253 are treated per the CXL.io FM rules of this flit format

For Management Flits using *Format 6*, Bytes 250 to 253 are driven from the Protocol Layer with Management Transport Credit Return DWORD (CRD) Bytes 0 to 3 (see [Section 8.2.5.2.2](#) for CRD format). Similarly, Bytes 244 to 249 are driven from the Protocol Layer as 0. See [Figure 3-26](#) for details.

If PCIe/CXL.io is negotiated along with Management Transport protocol on the same stack for *Format 6*:

- If bits [7:6] of Byte 1 are 10b, the Adapter passes through Bytes 122 to 125 and 248 to 253
- If bits [7:6] of Byte 1 are 00b, then Bytes 122 to 125 are treated per the PCIe/CXL.io DLP rules of this flit format, Bytes 250 to 253 are treated per the PCIe/CXL.io FM rules of this flit format, and the Adapter drives 0 on Bytes 248 and 249

**Figure 3-20. Format 5: Latency-Optimized 256B without Optional Bytes Flit Format for CXL.io<sup>a</sup>**

|                                                           |                                           |                                           |  |  |                                                                                                                                      |                                                                                                                                  |                          |  |  |  |
|-----------------------------------------------------------|-------------------------------------------|-------------------------------------------|--|--|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|
| <b>Byte 0</b><br>FH B0 <sup>b</sup><br>FH B1 <sup>b</sup> | +0<br>+1<br>+2                            | 62B of Flit Chunk 0 (from Protocol Layer) |  |  |                                                                                                                                      | +51<br>+52                                                                                                                       | +57<br>+58               |  |  |  |
| <b>Byte 64</b>                                            | 58B of Flit Chunk 1 (from Protocol Layer) |                                           |  |  | DLP B2 <sup>c</sup><br>DLP B3 <sup>c</sup><br>DLP B4 <sup>c</sup><br>DLP B5 <sup>c</sup><br>CO B0 <sup>d</sup><br>CO B1 <sup>d</sup> | +64<br>+65<br>+66<br>+67                                                                                                         |                          |  |  |  |
| <b>Byte 128</b>                                           | Flit Chunk 2 64B (from Protocol Layer)    |                                           |  |  | DLP B6 <sup>c</sup><br>DLP B7 <sup>c</sup><br>DLP B8 <sup>c</sup><br>DLP B9 <sup>c</sup><br>CO B1 <sup>d</sup><br>CO B2 <sup>d</sup> | +68<br>+69<br>+70<br>+71                                                                                                         |                          |  |  |  |
| <b>Byte 192</b>                                           | 52B of Flit Chunk 3 (from Protocol Layer) |                                           |  |  | 6B Reserved                                                                                                                          | FM B0 <sup>e</sup><br>FM B1 <sup>e</sup><br>FM B2 <sup>e</sup><br>FM B3 <sup>e</sup><br>C1 B0 <sup>d</sup><br>C1 B1 <sup>d</sup> | +74<br>+75<br>+76<br>+77 |  |  |  |

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.

e. Flit\_Marker or Optimized\_Update\_FC Byte 0, Byte 1, Byte 2, and Byte 3, respectively.

**Figure 3-21. Format 5: Latency-Optimized 256B without Optional Bytes Flit Format for CXL.cachemem and Streaming Protocol<sup>a</sup>**

|                                                           |                                           |                                           |              |                                          |            |            |     |
|-----------------------------------------------------------|-------------------------------------------|-------------------------------------------|--------------|------------------------------------------|------------|------------|-----|
| <b>Byte 0</b><br>FH B0 <sup>b</sup><br>FH B1 <sup>b</sup> | +0<br>+1<br>+2                            | 62B of Flit Chunk 0 (from Protocol Layer) |              | +51<br>+52                               | +57<br>+58 | +61<br>+62 | +63 |
| <b>Byte 64</b>                                            | 58B of Flit Chunk 1 (from Protocol Layer) |                                           | 4B Reserved  | C0 B0 <sup>c</sup><br>C0 B1 <sup>c</sup> |            |            |     |
| <b>Byte 128</b>                                           | Flit Chunk 2 64B (from Protocol Layer)    |                                           |              |                                          |            |            |     |
| <b>Byte 192</b>                                           | 52B of Flit Chunk 3 (from Protocol Layer) |                                           | 10B Reserved | C1 B0 <sup>c</sup><br>C1 B1 <sup>c</sup> |            |            |     |

a. See Figure 2-1 for color mapping.

b. Flit Header Byte 0 and Byte 1, respectively.

c. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Figure 3-22. Format 5: Latency-Optimized 256B without Optional Bytes Flit Format for Management Transport Protocol<sup>a</sup>**

|                                                           |                                           |            |                                    |                                          |                                          |     |  |
|-----------------------------------------------------------|-------------------------------------------|------------|------------------------------------|------------------------------------------|------------------------------------------|-----|--|
| <b>Byte 0</b><br>FH B0 <sup>b</sup><br>FH B1 <sup>b</sup> | +0<br>+1<br>+2                            | +47<br>+48 | +51<br>+52                         | +57<br>+58                               | +61<br>+62                               | +63 |  |
| <b>Byte 64</b>                                            | 58B of Flit Chunk 1 (from Protocol Layer) |            | 4B Reserved                        | C0 B0 <sup>c</sup><br>C0 B1 <sup>c</sup> |                                          |     |  |
| <b>Byte 128</b>                                           | Flit Chunk 2 64B (from Protocol Layer)    |            |                                    |                                          |                                          |     |  |
| <b>Byte 192</b>                                           | 48B of Flit Chunk 3 (from Protocol Layer) |            | 4B CRD<br>(from Protocol<br>Layer) | 10B Reserved                             | C1 B0 <sup>c</sup><br>C1 B1 <sup>c</sup> |     |  |

a. See Figure 2-1 for color mapping.

b. Flit Header Byte 0 and Byte 1, respectively.

c. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Figure 3-23. Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for CXL.io or PCIe<sup>a</sup>**

|                                                           |                                           |                   |                                                                                          |                                                                                                                                                        |                   |  |  |
|-----------------------------------------------------------|-------------------------------------------|-------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--|--|
| <b>Byte 0</b><br>FH B0 <sup>b</sup><br>FH B1 <sup>b</sup> | +0<br>+1<br>+2                            | +55<br>+56<br>+57 | +58                                                                                      | +61<br>+62                                                                                                                                             | +63               |  |  |
| <b>Byte 64</b>                                            | 58B of Flit Chunk 1 (from Protocol Layer) |                   | DLP B2 <sup>c</sup><br>DLP B3 <sup>c</sup><br>DLP B4 <sup>c</sup><br>DLP B5 <sup>c</sup> | C0 B0 <sup>d</sup><br>C0 B1 <sup>d</sup>                                                                                                               |                   |  |  |
| <b>Byte 128</b>                                           | Flit Chunk 2 64B (from Protocol Layer)    |                   |                                                                                          |                                                                                                                                                        |                   |  |  |
| <b>Byte 192</b>                                           | 56B of Flit Chunk 3 (from Protocol Layer) |                   | 2B Rsvd                                                                                  | FM B0 <sup>e</sup><br>FM B1 <sup>e</sup><br>FM B2 <sup>e</sup><br>FM B3 <sup>e</sup><br>FM B4 <sup>e</sup><br>C1 B0 <sup>d</sup><br>C1 B1 <sup>d</sup> | +61<br>+62<br>+63 |  |  |

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.

e. Flit\_Marker Byte 0, Byte 1, Byte 2, and Byte 3, respectively.

**Figure 3-24. Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for CXL.cachemem<sup>a</sup>**

|          |                    |                    |    |                                           |     |     |
|----------|--------------------|--------------------|----|-------------------------------------------|-----|-----|
|          |                    |                    | +0 | +51                                       | +58 | +61 |
| Byte 0   | FH B0 <sup>d</sup> | FH B1 <sup>b</sup> | +1 | +52                                       | +59 | +62 |
|          |                    |                    | +2 |                                           |     | +63 |
|          |                    |                    |    | 62B of Flit Chunk 0 (from Protocol Layer) |     |     |
| Byte 64  |                    |                    |    | 58B of Flit Chunk 1 (from Protocol Layer) |     |     |
| Byte 128 |                    |                    |    | Flit Chunk 2 64B (from Protocol Layer)    |     |     |
| Byte 192 |                    |                    |    | 52B of Flit Chunk 3 (from Protocol Layer) |     |     |

- a. See Figure 2-1 for color mapping.
  - b. Flit Header Byte 0 and Byte 1, respectively.
  - c. H-slot Byte 0 through Byte 13, respectively (from Protocol Layer).
  - d. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Figure 3-25.** Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for Streaming Protocol<sup>a</sup>

|          |                                          |                |                                           |                                          |
|----------|------------------------------------------|----------------|-------------------------------------------|------------------------------------------|
|          | FH B0 <sup>a</sup><br>FH B1 <sup>b</sup> | +0<br>+1<br>+2 | 62B of Flit Chunk 0 (from Protocol Layer) | +61                                      |
| Byte 0   |                                          |                |                                           | +62<br>+63                               |
| Byte 64  |                                          |                | 62B of Flit Chunk 1 (from Protocol Layer) | C0 B0 <sup>c</sup><br>C0 B1 <sup>c</sup> |
| Byte 128 |                                          |                | Flit Chunk 2 64B (from Protocol Layer)    |                                          |
| Byte 192 |                                          |                | 62B of Flit Chunk 3 (from Protocol Layer) | C1 B0 <sup>c</sup><br>C1 B1 <sup>c</sup> |

- a. See Figure 2-1 for color mapping.
  - b. Flit Header Byte 0 and Byte 1, respectively.
  - c. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

**Figure 3-26.** Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for Management Transport Protocol<sup>a</sup>

|                 |                                           |          |    |     |         |                              |                                          |     |     |                                          |
|-----------------|-------------------------------------------|----------|----|-----|---------|------------------------------|------------------------------------------|-----|-----|------------------------------------------|
|                 | FH B0 <sup>b</sup><br>FH B1 <sup>b</sup>  | +0<br>+1 | +2 | +51 | +52     | +57                          | +58                                      | +61 | +62 | +63                                      |
| <b>Byte 0</b>   | 62B of Flit Chunk 0 (from Protocol Layer) |          |    |     |         |                              |                                          |     |     |                                          |
| <b>Byte 64</b>  | 62B of Flit Chunk 1 (from Protocol Layer) |          |    |     |         |                              |                                          |     |     | C0 B0 <sup>c</sup><br>C0 B1 <sup>c</sup> |
| <b>Byte 128</b> | Flit Chunk 2 64B (from Protocol Layer)    |          |    |     |         |                              |                                          |     |     |                                          |
| <b>Byte 192</b> | 52B of Flit Chunk 3 (from Protocol Layer) |          |    |     | 6B Rsvd | 4B CRD (from Protocol Layer) | C1 B0 <sup>c</sup><br>C1 B1 <sup>c</sup> |     |     |                                          |

- a. See Figure 2-1 for color mapping.
  - b. Flit Header Byte 0 and Byte 1, respectively.
  - c. CRC0 Byte 0, CRC0 Byte 1, CRC1 Byte 0, and CRC1 Byte 1, respectively.

The Flit Header byte formats are the same as [Table 3-5](#) when Retry is required; otherwise, they are the same as [Table 3-4](#). The DLP rules are also the same as defined in [Section 3.3.3](#) for CXL protocol, except that Flit\_Marker/Optimized\_Update\_FC has dedicated space in the Flit (i.e., bit [4] of Byte 0 corresponds to the Flit\_Marker bytes, and not the DLP bytes). If Optimized\_Update\_FC is sent, the DLP Bytes 2:5 shown in [Figure 3-20](#) must be reserved. If bit [4] of Byte 0 in the Flit Header is 0b, then the Flit\_Marker bytes are reserved.

### 3.3.5 Flit Format-related Implementation Requirements for Protocol Layer and Adapter

[Table 3-6](#) lists the different Flit Formats supported in UCIe.

**Table 3-6. Summary of Flit Formats**

| Format Number   | Name                                               | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | For Details, See Also                                                                                                                                                                                  |
|-----------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>Format 1</i> | Raw                                                | Protocol Layer populates all the bytes on FDI. Adapter passes to RDI without modifications or additions.                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <ul style="list-style-type: none"> <li>• <a href="#">Section 3.3.1</a></li> <li>• <a href="#">Figure 3-10</a></li> </ul>                                                                               |
| <i>Format 2</i> | 68B Flit                                           | Protocol Layer transmits 64B per Flit on FDI. Adapter inserts two bytes of Flit header and two bytes of CRC and performs the required barrel shifting of bytes before transmitting on RDI. On the Rx, Adapter strips out the Flit header and CRC only sending the 64B per Flit to the Protocol Layer on FDI.                                                                                                                                                                                                                                                  | <ul style="list-style-type: none"> <li>• <a href="#">Section 3.3.2</a></li> <li>• <a href="#">Figure 3-11</a></li> <li>• <a href="#">Figure 3-12</a></li> </ul>                                        |
| <i>Format 3</i> | Standard 256B End Header Flit                      | Protocol Layer transmits 256B of Flit on FDI, while driving 0b on the bits reserved for the Adapter. Adapter fills in the relevant Flit header and CRC information before transmitting on RDI. On the Rx, Adapter forwards the Flit received from the Link to the Protocol Layer without modifying any bits applicable to the Protocol Layer, and the Protocol Layer must ignore any bits not applicable for it. Flit Header is located on Byte 236 and Byte 237 of the Flit.                                                                                 | <ul style="list-style-type: none"> <li>• <a href="#">Section 3.3.3</a></li> <li>• <a href="#">Figure 3-14</a></li> <li>• <a href="#">Figure 3-15</a></li> </ul>                                        |
| <i>Format 4</i> | Standard 256B Start Header Flit                    | Protocol Layer transmits 256B of Flit on FDI, while driving 0b on the bits reserved for the Adapter. Adapter fills in the relevant Flit header and CRC information before transmitting on RDI. On the Rx, Adapter forwards the Flit received from the Link to the Protocol Layer without modifying any bits applicable to the Protocol Layer, and the Protocol Layer must ignore any bits not applicable for it. Flit Header is located on Byte 0 and Byte 1 of the Flit.                                                                                     | <ul style="list-style-type: none"> <li>• <a href="#">Section 3.3.3</a></li> <li>• <a href="#">Figure 3-17</a></li> <li>• <a href="#">Figure 3-18</a></li> </ul>                                        |
| <i>Format 5</i> | Latency-Optimized 256B without Optional Bytes Flit | Protocol Layer transmits 256B of Flit on FDI, while driving 0b on the bits reserved for the Adapter. Adapter fills in the relevant Flit header and CRC information before transmitting on RDI. On the Rx, Adapter forwards the Flit received from the Link to the Protocol Layer without modifying any bits applicable to the Protocol Layer, and the Protocol Layer must ignore any bits not applicable for it. CRC bytes sent with each 128B of the Flit. The optional Protocol Layer bytes are reserved in this format and not used by the Protocol Layer. | <ul style="list-style-type: none"> <li>• <a href="#">Section 3.3.4</a></li> <li>• <a href="#">Figure 3-20</a></li> <li>• <a href="#">Figure 3-21</a></li> </ul>                                        |
| <i>Format 6</i> | Latency-Optimized 256B with Optional Bytes Flit    | Protocol Layer transmits 256B of Flit on FDI, while driving 0b on the bits reserved for the Adapter. Adapter fills in the relevant Flit header and CRC information before transmitting on RDI. On the Rx, Adapter forwards the Flit received from the Link to the Protocol Layer without modifying any bits applicable to the Protocol Layer, and the Protocol Layer must ignore any bits not applicable for it. CRC bytes sent with each 128B of the Flit, and optional bytes are used by the Protocol Layer.                                                | <ul style="list-style-type: none"> <li>• <a href="#">Section 3.3.4</a></li> <li>• <a href="#">Figure 3-23</a></li> <li>• <a href="#">Figure 3-24</a></li> <li>• <a href="#">Figure 3-25</a></li> </ul> |

**Table 3-7** gives the implementation requirements and Protocol Mapping for the different Flit Formats. For PCIe and CXL protocols, the implementation requirements must be followed by the Protocol Layer as well as the Adapter implementations. For Streaming protocols, the implementation requirements are for the Adapter only; Protocol Layer interoperability and implementation requirements are vendor specific.

**Table 3-7. Protocol Mapping and Implementation Requirements**

| Format Number | Flit Format Name                              | PCIe Non-Flit Mode | PCIe Flit Mode                    | CXL 68B Flit Mode | CXL 256B Flit Mode   | Streaming Protocol                | Management Transport Protocol |
|---------------|-----------------------------------------------|--------------------|-----------------------------------|-------------------|----------------------|-----------------------------------|-------------------------------|
| 1             | Raw                                           | Optional           | Optional                          | Optional          | Optional             | Mandatory                         | Optional                      |
| 2             | 68B                                           | Mandatory          | N/A                               | Mandatory         | N/A                  | Optional <sup>a</sup>             | N/A                           |
| 3             | Standard 256B End Header                      | N/A                | Mandatory                         | N/A               | N/A                  | Optional <sup>a</sup>             | Optional                      |
| 4             | Standard 256B Start Header                    | N/A                | Optional <sup>b</sup>             | N/A               | Mandatory            | Optional <sup>a</sup>             | Optional                      |
| 5             | Latency-Optimized 256B without Optional Bytes | N/A                | N/A                               | N/A               | Optional             | Optional <sup>a</sup>             | Optional                      |
| 6             | Latency-Optimized 256B with Optional Bytes    | N/A                | Strongly Recommended <sup>c</sup> | N/A               | Strongly Recommended | Strongly Recommended <sup>a</sup> | Optional                      |

a. If Streaming Flit Format capability is supported, else it is N/A.

b. If Standard Start Header for PCIe protocol capability is supported, else it is N/A.

c. If Latency-Optimized Flit with Optional Bytes for PCIe protocol capability is supported, else it is N/A.  
If Enhanced Multi-Protocol capability is supported where at least one of the stacks supports PCIe, this format and the corresponding capability are strongly recommended.

### 3.4 Decision Table for Flit Format and Protocol

**Table 3-8** shows the Truth Table for determining Protocol. Once the protocol and Flit Format have been negotiated during initial Link bring up, they cannot be changed until the UCIe Physical Layer transitions to Reset state.

If a valid Protocol and Flit Format are not negotiated, then the Adapter takes the Link down and reports the error if applicable.

**Table 3-8. Truth Table for Determining Protocol<sup>a</sup>**

| {FinCap.Adapter} bits or {MultiProtFinCap.Adapter} bits <sup>b</sup> |                    |                |                    |                               | {FinCap.CXL} bits |                | Protocol                                                             |
|----------------------------------------------------------------------|--------------------|----------------|--------------------|-------------------------------|-------------------|----------------|----------------------------------------------------------------------|
| 68B Flit Mode                                                        | CXL 256B Flit Mode | PCIe Flit Mode | Streaming Protocol | Management Transport Protocol | PCIe              | CXL.io         |                                                                      |
| 1                                                                    | 0                  | 0              | x                  | x                             | 0                 | 1              | CXL <sup>c</sup> without Management Transport protocol               |
| 1                                                                    | 1                  | 1              | x                  | 0                             | 0                 | 1 <sup>d</sup> | CXL <sup>c</sup> without Management Transport protocol               |
| 1                                                                    | 1                  | 1              | x                  | 1                             | 0                 | 1 <sup>d</sup> | CXL <sup>c</sup> with Management Transport protocol                  |
| 1                                                                    | 0                  | 0              | x                  | x                             | 1                 | 0              | PCIe <sup>e</sup> without Management Transport protocol              |
| 1                                                                    | 0                  | 1              | x                  | 0                             | 1 <sup>f</sup>    | 0              | PCIe without Management Transport protocol                           |
| 1                                                                    | 0                  | 1              | x                  | 1                             | 1 <sup>f</sup>    | 0              | PCIe with Management Transport protocol                              |
| N/A                                                                  | N/A                | N/A            | N/A                | N/A                           | N/A               | N/A            | Streaming <sup>g</sup> with or without Management Transport protocol |
| N/A                                                                  | N/A                | N/A            | N/A                | N/A                           | N/A               | N/A            | Management Transport protocol <sup>h</sup>                           |

- a. x indicates don't care in this Table.
- b. If Enhanced\_Multi-Protocol capability is negotiated then {MultiProt\*.Adapter} messages are used to determine the protocol for Stack 1. Stack 0 protocol is determined using the {FinCap.\*} messages.
- c. For CXL protocol, the specific combination of Single Protocol vs Type 1 vs. Type 2 vs. Type 3 is determined using the CXL.cache and CXL.mem capable/enable bits in addition to the CXL.io capable/enable bit in {FinCap.CXL}. The rules for that follow *CXL Specification*. When CXL is the protocol, if CXL 256B Flit mode is 1, then the protocol follows CXL 256B Flit mode rules; otherwise, the protocol follows CXL 68B Flit mode rules.
- d. CXL.io capable/enable must be 1 if CXL 256B Flit mode is negotiated.
- e. For PCIe protocol, if PCIe Flit mode is 1, then the protocol follows PCIe Flit mode rules; otherwise, the protocol follows PCIe Non-Flit mode rules.
- f. PCIe capable/enable must be 1 if PCIe Flit mode is 1 but CXL 256B Flit mode is 0.
- g. No {FinCap.\*} message is sent for Streaming protocol negotiation, Streaming is the negotiated protocol if PCIe or CXL are not advertised, but Streaming protocol is advertised. If Management Transport protocol was also advertised along with Streaming protocol, then Management Transport protocol is enabled along with Streaming protocol.
- h. No {FinCap.\*} message is sent for Management Transport protocol negotiation, Management Transport is the negotiated protocol if PCIe or CXL or Streaming are not advertised, but Management Transport protocol is advertised.

### IMPLEMENTATION NOTE

The “68B Flit Mode” parameter is advertised as set to 1 for both the CXL and PCIe protocols in {AdvCap.Adapter} sideband messages. As seen in [Table 3-8](#), this parameter is set to 1 in {FinCap.Adapter} sideband messages whenever the CXL OR PCIe protocols are negotiated.

The “CXL.io” and “PCIe” bits in the {AdvCap.CXL} sideband message disambiguate between CXL support vs. PCIe support. It is permitted to set both to 1 in {AdvCap.CXL} sideband messages. However, as seen in [Table 3-8](#), only one of these must be set in the {FinCap.CXL} sideband message to reflect the final negotiated protocol for the corresponding stack. For example:

- If the DP and UP both support CXL and PCIe protocols, then both “CXL.io” and “PCIe” will be set to 1 in the {AdvCap.CXL} sideband message
- If the DP decides to operate in CXL, the DP will set “CXL.io” to 1 and clear “PCIe” to 0 in the {FinCap.CXL} sideband message, in which case the remaining CXL-related bits in the {FinCap.CXL} sideband message are also applicable and are assigned as per the negotiation

[Table 3-9 \(Truth Table 1\)](#) shows the truth table for deciding the Flit format in which to operate if PCIe or CXL protocols are negotiated (with or without Management Transport protocol), and none of the following are negotiated:

- Enhanced Multi\_Protocol\_Enable
- Standard 256B Start Header for PCIe protocol capability
- Latency-Optimized Flit with Optional Bytes for PCIe protocol capability

[Table 3-10 \(Truth Table 2\)](#) provides the Truth Table for determining the Flit Format for Streaming protocols if Streaming Flit Format capability is negotiated or if Management Transport protocol is negotiated without CXL or PCIe or Streaming protocols on the same stack. Note that for Streaming protocol negotiation or for Management Transport protocol negotiation without CXL or PCIe protocol multiplexed on the same stack, there are no {FinCap.\*} messages exchanged. Each side of the UCIe Link advertises its own capabilities in the {AdvCap.Adapter} message it sends. The bits in [Table 3-10](#) represent the logical AND of the corresponding bits in the sent and received {AdvCap.Adapter} messages. [Truth Table 2](#) must be followed for determining the Flit Format if both sides of the Link have any of the following capabilities are supported and enabled for both sides of the Link:

- Enhanced Multi-Protocol Capability
- Standard Start Header Flit for PCIe protocol capability
- Latency-Optimized Flit with Optional Bytes for PCIe protocol capability

For situations where {FinCap.Adapter} messages are sent, the bits in the truth table represent the bits set in the {FinCap.Adapter} message.

It is permitted for the Adapter OR the Protocol Layer to take the Link down to LinkError if the desired Flit Format is not negotiated or the negotiated Flit format and protocol combination is illegal (e.g., 68B Flit Format 2 and Management Transport protocol combination).

**Table 3-9. Truth Table 1**

| {FinCap.Adapter} bits <sup>a</sup> |               |                    |                |                 |                | Flit Format                                                                 |
|------------------------------------|---------------|--------------------|----------------|-----------------|----------------|-----------------------------------------------------------------------------|
| Raw Format                         | 68B Flit Mode | CXL 256B Flit Mode | PCIe Flit Mode | CXL_LatOpt_Fmt5 | CXL_LatOptFmt6 |                                                                             |
| 1                                  | x             | x                  | x              | x               | x              | Format 1: Raw Format                                                        |
| 0                                  | x             | 1                  | x              | 0               | 0              | Format 4: Standard 256B Start Header Flit Format for CXL                    |
| 0                                  | x             | 1                  | x              | x               | 1              | Format 6: Latency-Optimized 256B with Optional Bytes Flit Format for CXL    |
| 0                                  | x             | 1                  | x              | 1               | 0              | Format 5: Latency-Optimized 256B without Optional Bytes Flit Format for CXL |
| 0                                  | x             | 0                  | 1              | x               | x              | Format 3: Standard 256B End Header Flit Format for PCIe                     |
| 0                                  | 1             | 0                  | 0              | x               | x              | Format 2: 68B Flit Format                                                   |

a. x indicates don't care.

**Table 3-10. Truth Table 2**

| Logical AND of Corresponding Bits in the Sent and Received {AdvCap.Adapter} Message OR the Bits Sent in the {FinCap.Adapter} Message <sup>c</sup> |                              |                                      |                                        |                                                           |                                                        | Final Negotiated Flit Format <sup>a</sup>                           |
|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------------------|----------------------------------------|-----------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------------|
| Raw Format <sup>b</sup>                                                                                                                           | 68B Flit Format <sup>c</sup> | Standard 256B End Header Flit Format | Standard 256B Start Header Flit Format | Latency-Optimized 256B without Optional Bytes Flit Format | Latency-Optimized 256B with Optional Bytes Flit Format |                                                                     |
| 1                                                                                                                                                 | x                            | x                                    | x                                      | x                                                         | x                                                      | Format 1: Raw Format                                                |
| 0                                                                                                                                                 | 1                            | 0                                    | 0                                      | x                                                         | 0                                                      | Format 2: 68B Flit Format                                           |
| 0                                                                                                                                                 | x                            | 1                                    | 0                                      | x                                                         | 0                                                      | Format 3: Standard 256B End Header Flit Format                      |
| 0                                                                                                                                                 | x                            | x                                    | 1                                      | x                                                         | 0                                                      | Format 4: Standard 256B Start Header Flit Format                    |
| 0                                                                                                                                                 | 0                            | 0                                    | 0                                      | 1                                                         | 0                                                      | Format 5: Latency-Optimized 256B without Optional Bytes Flit Format |
| 0                                                                                                                                                 | x                            | x                                    | x                                      | x                                                         | 1                                                      | Format 6: Latency-Optimized 256B with Optional Bytes Flit Format    |

a. Format 6 is the highest priority format when Raw Format is not advertised because it has the best performance characteristics. Between Format 4 and Format 3, Format 4 is higher priority because it enables lower latency through the D2D Adapter when multiplexing different protocols. Format 5 has the highest overhead and therefore has the lowest priority relative to other formats.

b. Raw Format is always explicitly enabled through PCIe Link Control register and advertised only when it is the required format of operation to ensure interoperability, and therefore appears as a higher priority in the decision table.

c. x indicates don't care.

### 3.5 State Machine Hierarchy

UCIE has a hierarchical approach to Link state management in order to have well-defined functionality partitioning between the different layers and also enabling common state transitions or sequencing at FDI and RDI.

[Figure 3-27](#) shows examples of state machine hierarchy for different configurations. For CXL, the ARB/MUX vLSMs are exposed on FDI `p1_state_sts`. The Adapter LSM is used to coordinate Link states with remote Link Partner and is required for all configurations. Each protocol stack has its corresponding Adapter LSM. For PCIe or Streaming protocols, the Adapter LSM is exposed on FDI `p1_state_sts`.

The RDI state machine (SM) is used to abstract the Physical Layer states for the upper layers. The Adapter data path and RDI data width can be extended for multi-module configurations; however, there is a single RDI state machine for this configuration. The Multi-module PHY Logic creates the abstraction and coordinates between the RDI state and individual modules. The following rules apply:

- vLSM state transitions are coordinated with remote Link partner using ALMPs on mainband data path. The rules for state transitions follow the CXL 256B Flit Mode rules in the *CXL Specification*.
- Adapter LSM state transitions are coordinated with remote Link partner using `{LinkMgmt.Adapter*}` sideband messages. These messages are originated and received by the D2D Adapter.
- RDI SM state transitions are coordinated with the remote Link partner using `{LinkMgmt.RDI*}` sideband messages. These messages are originated and received by the Physical Layer.

[Figure 3-27. State Machine Hierarchy Examples](#)



General rules for State transition hierarchy are captured below. For specific sequencing, see the rules outlined in [Chapter 10.0](#).

- Active State transitions: RDI SM must be in Active before Adapter LSM can begin negotiation to transition to Active. Adapter LSM must be in Active before vLSMs can begin negotiations to transition to Active.
- Retrain State transitions: RDI SM must be in Retrain before propagating Retrain to Adapter LSMs. If RDI SM is in Retrain, Retrain must be propagated to all Adapter LSMs that are in Active state.

Adapter must not request Retrain exit on RDI before all the relevant Adapter LSMs have transitioned to Retrain.

- PM State transitions (both L1 and L2): Both CXL.io and CXL.cachemem vLSMs (if CXL), must transition to PM before the corresponding Adapter LSM can transition to PM. All Adapter LSMs (if multiple stacks are enabled on the same Adapter) must be in PM before RDI SM is transitioned to PM.
- LinkError State transitions: RDI SM must be in LinkError before Adapter LSM can transition to LinkError. RDI SMs coordinate LinkError transition with remote Link partner using sideband, and each RDI SM propagates LinkError to all enabled Adapter LSMs. Adapter LSM must be in LinkError before propagating LinkError to both vLSMs if CXL. LinkError transition takes priority over LinkReset or Disabled transitions. Adapter must not request LinkError exit on RDI before all the relevant Adapter LSMs and CXL vLSMs have transitioned to LinkError.
- LinkReset or Disabled State transitions: Adapter LSM negotiates LinkReset or Disabled transition with its remote Link partner using sideband messages. LinkReset or Disabled is propagated to RDI SM only if all the Adapter LSMs associated with it transition to LinkReset or Disabled. Disabled transition takes priority over LinkReset transition. If RDI SM moves to LinkReset or Disabled, it must be propagated to all Adapter LSMs. If Adapter LSM moves to LinkReset or Disabled, it must propagate it to both vLSMs for CXL protocol.

For UCIe Retimers, it is the responsibility of the Retimer die to negotiate state transitions with the remote Retimer partner and make sure the different UCIe Die are in sync and do not time out waiting for a response. As an example, referring to [Figure 1-18](#), if UCIe Die 0 sends an Active Request message for the Adapter LSM to UCIe Retimer 0, UCIe Retimer 0 must resolve with UCIe Retimer 1 that an Active Request message has been forwarded to UCIe Die 1 and that UCIe Die 1 has responded with an Active Status message before responding to UCIe Die 0 with an Active Status message. The Off Package Interconnect cannot be taken to a low power state unless all the relevant states on UCIe Die 0 AND UCIe Die 1 have reached the low power state. UCIe Retimers must respond with "Stall" encoding every 4ms while completing resolution with the remote Retimer partner.

## 3.6 Power Management Link States

Power management states are mandatory for PCIe and CXL protocols. FDI supports L1 and L2 power states which follow the handshake rules and state transitions of CXL 256B Flit Mode. RDI supports L1 and L2 on the interfaces for Physical Layer to perform power management optimizations; however, the Physical Layer is permitted to internally map both L1 and L2 to a common state. These together allow for global clock gating and enable system level flows like Package-Level Idle (C-states). Other Protocols are permitted to disable PM flows by always sending a PMNAK for a PM request from remote Link partner.

When Management Transport protocol is supported and negotiated with CXL.io/PCIe/Streaming on the same stack, L1 and L2 entry requests to the Adapter from the Management Port Gateway multiplexer (MPG mux) must comprehend L1 and L2 entry readiness of the Management Transport protocol as well as the co-located protocol stack, in an implementation specific manner. Additionally, the MPG mux must also follow the FDI semantics for PM rules of the co-located CXL.io/PCIe/Streaming protocol. Similarly, L1 and L2 exit would wake both the Management Transport protocol and as well as the co-located protocol stack, and exit flow semantics must adhere to the negotiated CXL.io/PCIe/Streaming protocol.

The Power management state entry sequence is as follows:

1. **Protocol Layer PM entry request:** FDI defines a common flow for PM entry request at the interface that is based on Link idle time. All protocols using UCIe must follow that flow when PM needs to be supported. For CXL protocol, D2D Adapter implements the ARB/MUX functionality and follows the handshakes defined in *CXL Specification* (corresponding to the "CXL 256B Flit Mode",

since all ALMPs also go through the Retry buffer in UCIe). Even CXL 68B Flit Mode over UCIe uses the “CXL 256B Flit Mode” ALMP formats and flows (but the Flit is truncated to 64B and two bytes of Flit header and two bytes of CRC are added by the Adapter to make a 68B Flit). For PCIe protocol in UCIe Flit Mode, PM DLLP handshakes are NOT used. Protocol Layer requests PM entry on FDI based on Link idle time. The specific algorithm and hysteresis for determining Link idle time is implementation specific.

2. **Adapter Link State Machine PM entry:** The PM transition for this is coordinated over sideband with remote Link partner. In scenarios where the Adapter is multiplexing between two protocol stacks, each stack’s Link State Machine must transition to PM independently.
3. **PM entry on RDI:** Once all the Adapter’s LSMs are in a PM state, the Adapter initiates PM entry on the RDI as defined in [Section 10.2.9](#).
4. Physical Layer moves to a deeper PM state and takes the necessary actions for power management. Note that the sideband Link must remain active because the sideband Link is used to initiate PM exit.

**Figure 3-28. Example of Hierarchical PM Entry for CXL**



PM exit follows the reverse sequence of wake up as mentioned below:

1. Active request from Protocol Layer is transmitted across the FDI and RDI to the local Physical Layer.
2. The Physical Layer uses sideband to coordinate wake up and retraining of the physical Link.
3. Once the physical Link is retrained, the RDI is in Active state on both sides, and the Adapter LSM PM exit is triggered from both sides (coordinated via sideband messages between Adapters as outlined in the FDI PM flow). For PCIe or Streaming protocol scenarios, this also transitions the Protocol Layer to Active state on FDI.
4. For CXL protocol, this step is followed by ALMP exchanges to bring the required protocol to Active state and then protocol Flit transfer can begin.

### 3.7 CRC Computation

The CRC generator polynomial is  $(x+1)*(x^{15} + x + 1) = x^{16} + x^{15} + x^2 + 1$ . This gives a 3-bit detection guarantee for random bit errors: 2 bit detection guarantee is because of the primitive polynomial  $(x^{15} + x + 1)$ , and 1 additional bit error detection guarantee is provided by making it odd parity because of the  $(x+1)$  term in the polynomial.

The CRC is always computed over 128 bytes of the message. For smaller messages, the message is zero extended in the MSB. Any bytes which are part of the 128B CRC message but are not transmitted over the Link are assigned to 0b. Whenever non-CRC bytes of the Flit populated by the Adapter are included for CRC computation (e.g., the Flit Header or DLP bytes), CRC is computed after the Adapter has assigned those bytes the values that will be sent over the UCIe Link. Any reserved bits which are part of the Flit are assigned 0b for the purpose of CRC computation.

The initial value of CRC bits for CRC LFSR computation is 0000h. The CRC calculation starts with bit 0 of byte 0 of the message, and proceeds from bit 0 to bit 7 of each byte as shown in [Figure 3-29](#). In the figure, C[15] is bit 7 of CRC Byte 1, C[14] is bit 6 of CRC Byte 1 and so on; C[7] is bit 7 of CRC Byte 0, C[6] is bit 6 of CRC Byte 0 and so on.

The Verilog code for CRC code generation is provided in `crc_gen.v` (attached to the PDF copy of this Specification). This Verilog code must be used as the golden reference for implementing the CRC during encode or decode. The code is provided for the Transmit side. It takes 1024 bits (bit 1023 is bit 7 of message Byte 127, 1022 is bit 6 of message Byte 127 and so on; bit 1015 is bit 7 of message Byte 126 and so on until bit 0 is bit 0 of message Byte 0) as an input message and outputs 16 bits of CRC. On the Receiver, the CRC is computed using the received Flit bytes with appropriate zero padding in the MSB to form a 128B message. If the received CRC does not match the computed CRC, the flit is declared Invalid and a replay must be requested.

**Figure 3-29. Diagram of CRC Calculation**



### 3.8 Retry Rules

For configurations where the raw BER is higher than 1e-27, Retry must be supported in the Adapter, unless the only format of operation is Raw Format. If Retry is not supported by the Adapter, Link speeds where the raw BER is higher than 1e-27 must NOT be advertised by the Physical Layer during Link Training, unless the format of operation is Raw Format. See [Table 5-26](#) for the raw BER characteristics of different configurations. Once Retry has been negotiated during Part 2 of Stage 3 of Link Initialization described in [Section 3.2.1.2](#), it cannot be disabled even if Link speed degrades during runtime. Retry can only be re-negotiated at the next Link Initialization (i.e., RDI moves to Reset). For multiple stacks with a common Adapter, the Tx Retry buffer is shared between the stacks.

The Retry scheme on UCIe is a simplified version of the Retry mechanism for Flit Mode defined in *PCIe Base Specification*. The rules that differ from PCIe are as follows:

- Selective Nak and associated rules are not applicable and must not be implemented. Rx Retry Buffer-related rules are also not applicable and must not be implemented.
- Throughout the duration of Link operation, when not conflicting with PCIe rules of replay, Explicit Sequence number Flits and Ack/Nak Flits alternate. This allows for faster Ack turnaround and thus smaller Retry buffer sizes. It is permitted to send consecutive Explicit Sequence number Flits if there are no pending Ack/Nak Flits to send (see also the Implementation Note below). To meet this requirement, all Explicit Sequence Number Flit transmissions described by the PCIe rules of replay that require the condition “`CONSECUTIVE_TX_EXPLICIT_SEQ_NUM_FLIT < 3`” to be met require “`CONSECUTIVE_TX_EXPLICIT_SEQ_NUM_FLIT < 1`” to be met instead, and it is not required to send three consecutive Flits with Explicit Sequence Number.
- All 10-bit retry related counters are replaced with 8-bit counters, and the maximum-permitted sequence number is 255 (hence 1023 in all calculations is replaced with 255 and any variables defined in the “Flit Sequence Number and Retry Mechanism” section of *PCIe Base Specification* which had an initial value of 1023 instead have an initial value of 255).
- `REPLAY_TIMEOUT_FLIT_COUNT` is a 9-bit counter that saturates at 1FFh.
  - In addition to incrementing `REPLAY_TIMEOUT_FLIT_COUNT` as described in *PCIe Base Specification*, the count must also be incremented when in Active state and a Flit Time (Number of Adapter clock cycles (`1c1k`) that are required to transfer 256B of data at the current Link speed and width) has elapsed since the last flit was sent and neither a Payload Flit nor a NOP flit was transmitted. The counter must be incremented for every Flit Time in which a flit was not sent (this could lead to it being incremented several times in-between flits or prior to the limit being met). The added requirement compensates for the noncontinuous transfer of NOP flits. For 64B Flit Format, data transfers are also in 256B granularity (including the PDS bytes), and thus this counter increments every time 256B of data are transmitted, OR during idle conditions in Active state, it must be incremented according to the time that is required to transfer 256B of data at the current Link speed and width.
  - Replay Schedule Rule 0 of *PCIe Base Specification* must check for `REPLAY_TIMEOUT_FLIT_COUNT ≥ 375`. Replay Timer Timeout error is logged in the Correctable Internal Error in the Adapter for UCIe.
- For the `FLIT_REPLAY_NUM` counter, it is strongly recommended to follow the rules provided in *PCIe Base Specification* for speeds  $\leq$  32.0 GT/s. This counter tracks the number of times that a Replay has occurred without making forward progress. Given the significantly lower probability of Replay for UCIe Links, the rules associated with  $\leq$  32.0 GT/s PCIe speeds are sufficient for UCIe.
- `NAK_WITHDRAWAL_ALLOWED` is always cleared to 0. Note that this requires implementations to set the flag `NAK_SCHEDULED=1` in the “Nak Schedule 0” set of rules.
- IDLE Flit Handshake Phase is not applicable. This is because the transition to Link Active (equivalent to LTSSM being in L0 for PCIe) is managed via handshakes on sideband, and there is no requirement for IDLE Flits to be exchanged. As per PCIe rules, any Flits received with all 0s in

the Flit Header bytes are discarded by the Adapter. Any variables that are initialized during the IDLE Flit Handshake Phase in *PCIe Base Specification* are initialized to the corresponding value whenever the RDI is in Reset state or Retrain state. Similarly, PCIe rules that indicate relation to “last entry to IDLE Flit Handshake Phase” would instead apply for UCIe to “last exit from Reset or Retrain state on RDI”.

- Variables applicable to Flit Sequence number and Retry mechanism that are initialized during DL\_Inactive, as with PCIe, would be initialized to their corresponding values when RDI is in Reset state for UCIe.
- Sequence Number Handshake Phase must be performed on every entry of the RDI to Active state from Reset state or Retrain state (after Flit transfers are permitted). Sequence Number Handshake Phase timeout and exit to Link Retrain is 128 Flits transmitted without exiting Sequence Number Handshake Phase. As with PCIe, both NOP flits or Payload flits are permitted to be used to complete the Sequence Number Handshake Phase. If there are no Payload flits to send, the Adapter must generate NOP flits to complete the Sequence Number Handshake Phase.
- The variable “Prior Flit was Payload” is always set to 1. This bit does not exist in the Flit Header, and thus from the Retry perspective, implementations must assume that it is always set to 1.
- MAX\_UNACKNOWLEDGED\_FLITS is set to the lesser of:
  - Number of Flits that can be stored in the Tx Retry Buffer, or
  - 127
- Flit Discard 2 rule from PCIe does not result in a Data Link Protocol Error condition in UCIe. Receiving an invalid Flit Sequence number in a received Ack or Nak flit (see the corresponding conditions in *PCIe Base Specification* with the adjusted variable widths and values) OR a Payload Flit with an Explicit Sequence number of 0 results in an Uncorrectable Internal Error in UCIe (instead of a Data Link Protocol Error).
- Conditions from the “Flit Sequence Number and Retry Mechanism” section in *PCIe Base Specification* that led to Recovery for the Port must result in the Adapter initiating Retrain on the RDI for UCIe.

### IMPLEMENTATION NOTE

In UCIe, to encourage power savings through dynamic clock gating, it is not required to continuously transmit NOP flits during periods in which there are no Payload flits or any Ack/Nak pending. Consider an example in which an Adapter’s Tx Retry Buffer is empty and it transmitted a NOP flit with an Ack as the last flit before it stopped sending additional flits to the Physical Layer. Let’s say this flit had a CRC error and hence the remote Link partner never receives this Ack. Moreover, because the remote Link partner received a flit with a CRC error, it would transmit a Nak to original sender. If the Ack is never re-sent and the remote Link partner has a corresponding Payload flit in its Tx Retry Buffer, eventually a Replay Timeout will trigger from the remote Link partner and resolve this scenario. However, rather than always relying on Replay Timeout for these kind of scenarios, it is recommended for implementations to ensure they have transmitted at least two flits with an Ack (these need not be consecutive Ack flits) before stopping flit transfer whenever a Nak is received and the transmitter has completed all the requirements of received Nak processing, including any Replay related transfers. If no new Payload Flits were received from the remote Link partner, as per PCIe rules, it is permitted to re-send the last transmitted Ack on a NOP flit as well to meet this condition.

### 3.9 Runtime Link Testing using Parity

UCIE defines a mechanism to detect Link health during runtime by periodically injecting parity bytes in the middle of the data stream when this mechanism is enabled. The receiver checks and logs parity errors for the inserted parity bytes.

When this mechanism is enabled, the Adapter inserts  $64*N$  Bytes every  $256*256*N$  Bytes of data, where N is obtained from the Error and Link Testing Control register (Field name: Number of 64 Byte Inserts). Software must set N=4 when this feature is enabled during regular Link operation for UCIE Flit mode because that makes the parity bytes also a multiple of 256B and is more consistent with the granularity of data transfer. Only bit 0 of the inserted byte has the parity information which is computed as follows:

$$\text{ParityByte } X, \text{ bit } 0 = \wedge((\text{DataByte } [X]) \wedge (\text{DataByte } [X + 64*N]) \wedge (\text{DataByte } [X + 128*N]) \wedge \dots \wedge (\text{DataByte } [X + (256*256*N - 64*N)]))$$

The remaining 7 bits of the inserted byte are Reserved.

The Transmitter and Receiver in the Adapter must independently keep track of the number of data bytes elapsed to compute or check the parity information. If the RDI state moves away from Active state, the data count and parity is reset, and both sides must renegotiate the enabling of the Parity insertion before next entry to Active from Retrain (if the mechanism is still enabled in the Error and Link Testing Control register). When entering Active state with Parity insertion enabled, the number of data bytes elapsed begins counting from 0. On the transmitter, following the insertion of the parity information, the counter for the number of bytes elapsed to compute the parity information is reset. On the Receiver, following the receipt and check of parity bytes, the counter for the number of bytes elapsed to check the parity information is reset.

This mechanism is enabled by Software writing 1b to the enable bit in the register located in both Adapters across a UCIE Link (see [Section 9.5.3.9](#) for register details). Software must trigger UCIE Link Retrain after writing to the enable bit on both the Adapters. Support for this feature in Raw Format is beyond the scope of this specification and is implementation-dependent. The Adapters exchange sideband messages while the Adapter LSMs are in Retrain to ensure the remote Link partner's receiver is prepared to receive the extra parity bytes in the data stream once the states transition to Active. The Adapter must not request Retrain exit to local RDI until the Parity Feature exchanges are completed. It is permitted to enable it during Initial Link bring up, by using sideband to access the remote Link partner's registers or other implementation specific means; however software must trigger Link Retrain for the feature to take effect.

Adapter sends a {ParityFeature.Req} sideband message to remote Link Partner if its Transmitter is enabled to send parity bytes ("Runtime Link Testing Tx Enable" bit in [Section 9.5.3.9](#)). Remote Adapter responds with a {ParityFeature.Ack} sideband message if its receiver is enabled and ready to accept parity bytes ("Runtime Link Testing Rx Enable" bit in [Section 9.5.3.9](#)). [Figure 3-30](#) shows an example of a successful negotiation. If Die 0 Adapter Transmitter is enabled to insert parity bytes, it must send a {ParityFeature.Req} from Die 0 to Die 1.

Adapter responds with a {ParityFeature.Nak} if it is not ready to accept parity bytes, or if the feature has not been enabled for it yet. The requesting Adapter must log the Nak in a status register so that Software can determine that a Nak had occurred. [Figure 3-31](#) shows an example of an unsuccessful negotiation.

**Note:** The Adapters are permitted to transition to a higher latency data path if the Parity Feature is enabled. The explicit Ack/Nak handshake is provided to ensure both sides have sufficient time to transition to alternate data path for this mechanism.

The Parity bytes do not consume Retimer receiver buffer credits. The Retimer receiver must not write the Parity bytes into its receiver buffer or forward these to remote Retimer partner over the Off Package Interconnect. This mechanism is to help characterize local UCIe Links only.

**Figure 3-30. Successful Parity Feature negotiation between Die 1 Tx and Die 0 Rx**



**Figure 3-31. Unsuccessful Parity Feature negotiation between Die 1 Tx and Die 0 Rx**

If a parity error is detected by a chiplet, the error is treated as a Correctable error and reported via the correctable error reporting mechanism. By enabling interrupt on correctable errors, SW can implement a BER counter in SW, if so desired.

When a Pause Data Stream occurs the Pause Data Stream and corresponding padding bytes are included in the number of bytes elapsed before parity injection as well as parity computation.

§ §

## 4.0 Logical Physical Layer

---

The Logical PHY comprehends the following functions:

- Link initialization, training and power management states
- Byte to Lane mapping for data transmission over Lanes
- Interconnect redundancy remapping (when required)
- Transmitting and receiving sideband messages
- Scrambling and training pattern generation
- Lane reversal
- Width degradation (when applicable)

### 4.1 Data and Sideband Transmission Flow

This specification defines clock, valid and Data to send and receive data over the physical Lanes. The transmitted data is framed by the valid signal.

#### 4.1.1 Byte to Lane Mapping

Data packets are transmitted in Bytes. Within each Byte, bit [0] is transmitted first. [Figure 4-1](#) shows an example of bit arrangement within one byte transmission over Lane 0.

**Figure 4-1.** Bit arrangement within a byte transfer



Each Byte is transmitted on a separate Lane. Byte 0 (B0) is transmitted on Lane 0, Byte 1 is transmitted on Lane 1 and so on.

[Figure 4-2](#) shows an example of a 256B Flit transmitted over a x64 interface (one x64 Advanced Package module or two x32 Advanced Package modules or four Standard Package modules). If the I/O width changes to x32 or x16 interface (Standard Package), transmission of one Byte per Lane is preserved as shown in [Figure 4-3](#) and [Figure 4-4](#) respectively.

[Figure 4-5](#) shows an example for a width degraded Standard Package module.

**Figure 4-2.** Byte map for x64 interface

| UI \ LANE | 0    | 1    | 2    | 3    | 4    | 5    | 6    | 7    | ... | 48   | 49   | 50   | 51   | 52   | 53   | 54   | 55   | 56   | 57   | 58   | 59   | 60   | 61   | 62   | 63   |
|-----------|------|------|------|------|------|------|------|------|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| 0 - 7     | B00  | B01  | B02  | B03  | B04  | B05  | B06  | B07  | ... | B48  | B49  | B50  | B51  | B52  | B53  | B54  | B55  | B56  | B57  | B58  | B59  | B60  | B61  | B62  | B63  |
| 8 - 15    | B64  | B65  | B66  | B67  | B68  | B69  | B70  | B71  | ... | B112 | B113 | B114 | B115 | B116 | B117 | B118 | B119 | B120 | B121 | B122 | B123 | B124 | B125 | B126 | B127 |
| 16 - 23   | B128 | B129 | B130 | B131 | B132 | B133 | B134 | B135 | ... | B176 | B177 | B178 | B179 | B180 | B181 | B182 | B183 | B184 | B185 | B186 | B187 | B188 | B189 | B190 | B191 |
| 24 - 31   | B192 | B193 | B194 | B195 | B196 | B197 | B198 | B199 | ... | B240 | B241 | B242 | B243 | B244 | B245 | B246 | B247 | B248 | B249 | B250 | B251 | B252 | B253 | B254 | B255 |

**Figure 4-3.** Byte map for x32 interface

| UI \ Lane | 0    | 1    | 2    | 3    | 4    | 5    | 6    | 7    | ... | 16   | 17   | 18   | 19   | 20   | 21   | 22   | 23   | 24   | 25   | 26   | 27   | 28   | 29   | 30   | 31   |
|-----------|------|------|------|------|------|------|------|------|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| 0 - 7     | B0   | B1   | B2   | B3   | B4   | B5   | B6   | B7   | ... | B16  | B17  | B18  | B19  | B20  | B21  | B22  | B23  | B24  | B25  | B26  | B27  | B28  | B29  | B30  | B31  |
| 8 - 15    | B32  | B33  | B34  | B35  | B36  | B37  | B38  | B39  | ... | B48  | B49  | B50  | B51  | B52  | B53  | B54  | B55  | B56  | B57  | B58  | B59  | B60  | B61  | B62  | B63  |
| 16 - 23   | B64  | B65  | B66  | B67  | B68  | B69  | B70  | B71  | ... | B80  | B81  | B82  | B83  | B84  | B85  | B86  | B87  | B88  | B89  | B90  | B91  | B92  | B93  | B94  | B95  |
| 24 - 31   | B96  | B97  | B98  | B99  | B100 | B101 | B102 | B103 | ... | B112 | B113 | B114 | B115 | B116 | B117 | B118 | B119 | B120 | B121 | B122 | B123 | B124 | B125 | B126 | B127 |
| 32 - 39   | B128 | B129 | B130 | B131 | B132 | B133 | B134 | B135 | ... | B144 | B145 | B146 | B147 | B148 | B149 | B150 | B151 | B152 | B153 | B154 | B155 | B156 | B157 | B158 | B159 |
| 40 - 47   | B160 | B161 | B162 | B163 | B164 | B165 | B166 | B167 | ... | B176 | B177 | B178 | B179 | B180 | B181 | B182 | B183 | B184 | B185 | B186 | B187 | B188 | B189 | B190 | B191 |
| 48 - 55   | B192 | B193 | B194 | B195 | B196 | B197 | B198 | B199 | ... | B208 | B209 | B210 | B211 | B212 | B213 | B214 | B215 | B216 | B217 | B218 | B219 | B220 | B221 | B222 | B223 |
| 56 - 63   | B224 | B225 | B226 | B227 | B228 | B229 | B230 | B231 | ... | B240 | B241 | B242 | B243 | B244 | B245 | B246 | B247 | B248 | B249 | B250 | B251 | B252 | B253 | B254 | B255 |

**Figure 4-4.** Byte map for x16 interface

| UI \ Lane | 0    | 1    | 2    | 3    | 4    | 5    | 6    | 7    | 8    | 9    | 10   | 11   | 12   | 13   | 14   | 15   |
|-----------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| 0 - 7     | B0   | B1   | B2   | B3   | B4   | B5   | B6   | B7   | B8   | B9   | B10  | B11  | B12  | B13  | B14  | B15  |
| 8 - 15    | B16  | B17  | B18  | B19  | B20  | B21  | B22  | B23  | B24  | B25  | B26  | B27  | B28  | B29  | B30  | B31  |
| 16 - 23   | B32  | B33  | B34  | B35  | B36  | B37  | B38  | B39  | B40  | B41  | B42  | B43  | B44  | B45  | B46  | B47  |
| 24 - 31   | B48  | B49  | B50  | B51  | B52  | B53  | B54  | B55  | B56  | B57  | B58  | B59  | B60  | B61  | B62  | B63  |
| 32 - 39   | B64  | B65  | B66  | B67  | B68  | B69  | B70  | B71  | B72  | B73  | B74  | B75  | B76  | B77  | B78  | B79  |
| 40 - 47   | B80  | B81  | B82  | B83  | B84  | B85  | B86  | B87  | B88  | B89  | B90  | B91  | B92  | B93  | B94  | B95  |
| 48 - 55   | B96  | B97  | B98  | B99  | B100 | B101 | B102 | B103 | B104 | B105 | B106 | B107 | B108 | B109 | B110 | B111 |
| 56 - 63   | B112 | B113 | B114 | B115 | B116 | B117 | B118 | B119 | B120 | B121 | B122 | B123 | B124 | B125 | B126 | B127 |
| 64 - 71   | B128 | B129 | B130 | B131 | B132 | B133 | B134 | B135 | B136 | B137 | B138 | B139 | B140 | B141 | B142 | B143 |
| 72 - 79   | B144 | B145 | B146 | B147 | B148 | B149 | B150 | B151 | B152 | B153 | B154 | B155 | B156 | B157 | B158 | B159 |
| 80 - 87   | B160 | B161 | B162 | B163 | B164 | B165 | B166 | B167 | B168 | B169 | B170 | B171 | B172 | B173 | B174 | B175 |
| 88 - 95   | B176 | B177 | B178 | B179 | B180 | B181 | B182 | B183 | B184 | B185 | B186 | B187 | B188 | B189 | B190 | B191 |
| 96 - 103  | B192 | B193 | B194 | B195 | B196 | B197 | B198 | B199 | B200 | B201 | B202 | B203 | B204 | B205 | B206 | B207 |
| 104 - 111 | B208 | B209 | B210 | B211 | B212 | B213 | B214 | B215 | B216 | B217 | B218 | B219 | B220 | B221 | B222 | B223 |
| 112 - 119 | B224 | B225 | B226 | B227 | B228 | B229 | B230 | B231 | B232 | B233 | B234 | B235 | B236 | B237 | B238 | B239 |
| 120 - 127 | B240 | B241 | B242 | B243 | B244 | B245 | B246 | B247 | B248 | B249 | B250 | B251 | B252 | B253 | B254 | B255 |

**Figure 4-5. Byte to Lane mapping for Standard package x16 degraded to x8**

| Lane      | 8    | 9    | 10   | 11   | 12   | 13   | 14   | 15   |
|-----------|------|------|------|------|------|------|------|------|
| or        |      |      |      |      |      |      |      |      |
| Lane UI \ | 0    | 1    | 2    | 3    | 4    | 5    | 6    | 7    |
| 0 - 7     | B0   | B1   | B2   | B3   | B4   | B5   | B6   | B7   |
| 8 - 15    | B8   | B9   | B10  | B11  | B12  | B13  | B14  | B15  |
| 16 - 23   | B16  | B17  | B18  | B19  | B20  | B21  | B22  | B23  |
| 24 - 31   | B24  | B25  | B26  | B27  | B28  | B29  | B30  | B31  |
| 32 - 39   | B32  | B33  | B34  | B35  | B36  | B37  | B38  | B39  |
| 40 - 47   | B40  | B41  | B42  | B43  | B44  | B45  | B46  | B47  |
| 48 - 55   | B48  | B49  | B50  | B51  | B52  | B53  | B54  | B55  |
| 56 - 63   | B56  | B57  | B58  | B59  | B60  | B61  | B62  | B63  |
| 64 - 71   | B64  | B65  | B66  | B67  | B68  | B69  | B70  | B71  |
| 72 - 79   | B72  | B73  | B74  | B75  | B76  | B77  | B78  | B79  |
| 80 - 87   | B80  | B81  | B82  | B83  | B84  | B85  | B86  | B87  |
| 88 - 95   | B88  | B89  | B90  | B91  | B92  | B93  | B94  | B95  |
| 96 - 103  | B96  | B97  | B98  | B99  | B100 | B101 | B102 | B103 |
| 104 - 111 | B104 | B105 | B106 | B107 | B108 | B109 | B110 | B111 |
| 112 - 119 | B112 | B113 | B114 | B115 | B116 | B117 | B118 | B119 |
| 120 - 127 | B120 | B121 | B122 | B123 | B124 | B125 | B126 | B127 |
| 128-135   | B128 | B129 | B130 | B131 | B132 | B133 | B134 | B135 |
| 136-143   | B136 | B137 | B138 | B139 | B140 | B141 | B142 | B143 |
| 144-151   | B144 | B145 | B146 | B147 | B148 | B149 | B150 | B151 |
| 152-159   | B152 | B153 | B154 | B155 | B156 | B157 | B158 | B159 |
| 160-167   | B160 | B161 | B162 | B163 | B164 | B165 | B166 | B167 |
| 168-175   | B168 | B169 | B170 | B171 | B172 | B173 | B174 | B175 |
| 176-183   | B176 | B177 | B178 | B179 | B180 | B181 | B182 | B183 |
| 184-191   | B184 | B185 | B186 | B187 | B188 | B189 | B190 | B191 |
| 192-199   | B192 | B193 | B194 | B195 | B196 | B197 | B198 | B199 |
| 200-207   | B200 | B201 | B202 | B203 | B204 | B205 | B206 | B207 |
| 208-215   | B208 | B209 | B210 | B211 | B212 | B213 | B214 | B215 |
| 216-223   | B216 | B217 | B218 | B219 | B220 | B221 | B222 | B223 |
| 224-231   | B224 | B225 | B226 | B227 | B228 | B229 | B230 | B231 |
| 232-239   | B232 | B233 | B234 | B235 | B236 | B237 | B238 | B239 |
| 240-247   | B240 | B241 | B242 | B243 | B244 | B245 | B246 | B247 |
| 248-255   | B248 | B249 | B250 | B251 | B252 | B253 | B254 | B255 |

#### 4.1.2 Valid Framing

Valid signal is used to frame the transmitted data. For each 8-bit data packet, valid is asserted for the first 4 UI and de-asserted for 4 UI. This will allow data transfer in Raw Format or various Flit Formats as described in [Chapter 3.0](#) using one or multiple valid frames. An example is shown in [Figure 4-6](#) where Transfer 1 and Transfer 2 can be from the same Flit or different Flits.

**Note:** An 8-UI block assertion is enforced by the Transmitter and tracked by the Receiver during Active state. This means that following the first valid transfer of data over mainband in Active state, each subsequent transfer is after an integer multiple of 8 UI from the rising edge of Valid of the first transfer. Note that for Retimers, this means that the first transfer after entering the Active state cannot be a 'No Flit data transfer + 1 credit release' encoding; this is acceptable because the Retimer-advertised credits are replenished or readvertised whenever the state moves away from Active.

**Figure 4-6. Valid framing example**

#### 4.1.2.1 Valid Framing for Retimers

The UCIe Retimer releases credits to its local UCIe die using the Valid wire, as described in [Table 4-1](#). Each credit tracks 256 Bytes of data (including any FEC, CRC, etc). The Valid Framing encodings ensure triple bit flip detection guarantee. It is permitted for receiver implementations to trigger Retrain on any bit error (using triple bit flip detection guarantee). It is also permitted for receiver implementations to use the encodings below to correct single bit errors (with the understanding that three bit error detection is lost, and its contribution to overall FIT is negligible).

**Table 4-1. Valid framing for Retimers**

| 8-UI Valid <sup>a</sup> | Encoding                                     |
|-------------------------|----------------------------------------------|
| 00000000b               | No Flit data transfer + no credit release    |
| 00001111b               | Flit data transfer valid + no credit release |
| 11110000b               | No Flit data transfer + 1 credit release     |
| 11111111b               | Flit data transfer valid + 1 Credit release  |

a. Note that the bits above are transmitted on the Link in order from right to left (i.e., bit 0 is transmitted on the Link first, followed by bit 1 and so on until bit 7).

#### 4.1.3 Clock Gating

Forwarded mainband clocks on the UCIe Link must be gated when Valid signal is low after providing fixed 16 UI (8 cycles) of postamble clock for half-rate clocking and 32 UI (8 cycles) of postamble clock for quarter-rate clocking, unless free running clock mode is negotiated or Runtime Recalibration has been requested by the remote Link partner. Data and Clock signal parking levels when clocks are gated are described in [Section 5.11](#).

Note that the clock postamble is required any time that the clock can toggle with Valid assertion, and the clock needs to stop toggling, regardless of LTSM state.

**Figure 4-7. Clock gating**