



## Specification for I3C Basic<sup>SM</sup>

Improved Inter Integrated Circuit

**Version 1.1.1**

**9 June 2021**

MIPI Board Adopted 23 July 2021  
**Public Release Edition**

Further technical changes to this document are expected as work continues in the I3C Ad Hoc Working Group.

**NOTICE OF DISCLAIMER**

The material contained herein is provided on an “AS IS” basis. To the maximum extent permitted by applicable law, this material is provided AS IS AND WITH ALL FAULTS, and the authors and developers of this material and MIPI Alliance Inc. (“MIPI”) hereby disclaim all other warranties and conditions, either express, implied or statutory, including, but not limited to, any (if any) implied warranties, duties or conditions of merchantability, of fitness for a particular purpose, of accuracy or completeness of responses, of results, of workmanlike effort, of lack of viruses, and of lack of negligence. ALSO, THERE IS NO WARRANTY OR CONDITION OF TITLE, QUIET ENJOYMENT, QUIET POSSESSION, CORRESPONDENCE TO DESCRIPTION OR NON-INFRINGEMENT WITH REGARD TO THIS MATERIAL.

IN NO EVENT WILL ANY AUTHOR OR DEVELOPER OF THIS MATERIAL OR MIPI BE LIABLE TO ANY OTHER PARTY FOR THE COST OF PROCURING SUBSTITUTE GOODS OR SERVICES, LOST PROFITS, LOSS OF USE, LOSS OF DATA, OR ANY INCIDENTAL, CONSEQUENTIAL, DIRECT, INDIRECT, OR SPECIAL DAMAGES WHETHER UNDER CONTRACT, TORT, WARRANTY, OR OTHERWISE, ARISING IN ANY WAY OUT OF THIS OR ANY OTHER AGREEMENT RELATING TO THIS MATERIAL, WHETHER OR NOT SUCH PARTY HAD ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES.

The material contained herein is not a license, either expressly or impliedly, to any IPR owned or controlled by any of the authors or developers of this material or MIPI. Any license to use this material is granted separately from this document. This material is protected by copyright laws, and may not be reproduced, republished, distributed, transmitted, displayed, broadcast or otherwise exploited in any manner without the express prior written permission of MIPI Alliance. MIPI, MIPI Alliance and the dotted rainbow arch and all related trademarks, service marks, tradenames, and other intellectual property are the exclusive property of MIPI Alliance Inc. and cannot be used without its express prior written permission. The use or implementation of this material may involve or require the use of intellectual property rights (“IPR”) including (but not limited to) patents, patent applications, or copyrights owned by one or more parties, whether or not members of MIPI. MIPI does not make any search or investigation for IPR, nor does MIPI require or request the disclosure of any IPR or claims of IPR as respects the contents of this material or otherwise.

Without limiting the generality of the disclaimers stated above, users of this material are further notified that MIPI: (a) does not evaluate, test or verify the accuracy, soundness or credibility of the contents of this material; (b) does not monitor or enforce compliance with the contents of this material; and (c) does not certify, test, or in any manner investigate products or services or any claims of compliance with MIPI specifications or related material.

Questions pertaining to this material, or the terms or conditions of its provision, should be addressed to:

MIPI Alliance, Inc.  
c/o IEEE-ISTO  
445 Hoes Lane, Piscataway New Jersey 08854, United States  
Attn: Managing Director

# Contents

|                                                                                           |      |
|-------------------------------------------------------------------------------------------|------|
| Figures .....                                                                             | ix   |
| Tables .....                                                                              | xiv  |
| Release History.....                                                                      | xvii |
| Preface to the I3C Basic Specification .....                                              | 1    |
| 1 What is MIPI I3C Basic?.....                                                            | 1    |
| 2 Motivation .....                                                                        | 1    |
| 3 IPR Status .....                                                                        | 1    |
| 4 Relationship to MIPI I3C v1.x Specifications.....                                       | 2    |
| 4.1 I3C v1.1.1 Functions Not Included in I3C Basic.....                                   | 2    |
| 4.2 Organization of This Specification.....                                               | 2    |
| 4.3 I3C Basic v1.1.1 as an Update of I3C Basic v1.0.....                                  | 2    |
| 5 How I3C Basic Devices Work with I3C v1.x Devices .....                                  | 2    |
| 1 Introduction.....                                                                       | 3    |
| 1.1 Scope .....                                                                           | 4    |
| 1.2 I3C Purpose.....                                                                      | 4    |
| 1.3 I3C Key Features.....                                                                 | 4    |
| 2 Terminology.....                                                                        | 8    |
| 2.1 Use of Special Terms.....                                                             | 8    |
| 2.2 Definitions.....                                                                      | 8    |
| 2.3 Abbreviations .....                                                                   | 13   |
| 2.4 Acronyms .....                                                                        | 14   |
| 3 References.....                                                                         | 15   |
| 3.1 Normative References .....                                                            | 15   |
| 3.2 Informative References .....                                                          | 15   |
| 4 Technical Overview (Informative).....                                                   | 17   |
| 4.1 I3C Fundamental Principles .....                                                      | 18   |
| 4.2 I3C Controller and Target Devices .....                                               | 21   |
| 4.2.1 I3C Controller Device.....                                                          | 22   |
| 4.2.1.1 I3C Controller Device Roles.....                                                  | 23   |
| 4.2.2 I3C Target Device .....                                                             | 24   |
| 4.2.2.1 I3C Target Device Roles .....                                                     | 25   |
| 5 I3C Protocol.....                                                                       | 27   |
| 5.1 Single Data Rate (SDR) Mode .....                                                     | 29   |
| 5.1.1 Bus Configuration.....                                                              | 30   |
| 5.1.1.1 I3C Device Characteristics .....                                                  | 31   |
| 5.1.1.2 I3C Characteristics Registers.....                                                | 34   |
| 5.1.1.2.1 Bus Characteristics Register (BCR) .....                                        | 35   |
| 5.1.1.2.2 Device Characteristics Register (DCR).....                                      | 36   |
| 5.1.1.2.3 Legacy Virtual Register (LVR) .....                                             | 36   |
| 5.1.2 Bus Communication .....                                                             | 37   |
| 5.1.2.1 Role of I3C Target .....                                                          | 39   |
| 5.1.2.1.1 Role of I3C Target Acting as an I <sup>2</sup> C Target with Static Address ... | 41   |
| 5.1.2.1.2 Composite Devices and Virtual Targets .....                                     | 42   |
| 5.1.2.1.3 Targets Supporting Group Addresses .....                                        | 43   |

|           |                                                                                                      |    |
|-----------|------------------------------------------------------------------------------------------------------|----|
| 5.1.2.2   | I3C Address Header .....                                                                             | 44 |
| 5.1.2.2.1 | I3C Address Arbitration .....                                                                        | 45 |
| 5.1.2.2.2 | I3C Address Arbitration Optimization .....                                                           | 46 |
| 5.1.2.2.3 | Consequence of Controller Starting a Frame with<br>I3C Target Address .....                          | 48 |
| 5.1.2.2.4 | Address Header Following a Repeated START is Push-Pull .....                                         | 49 |
| 5.1.2.2.5 | I3C Target Address Restrictions .....                                                                | 49 |
| 5.1.2.3   | I3C SDR Data Words .....                                                                             | 51 |
| 5.1.2.3.1 | Transition from Address ACK to SDR Controller Write Data .....                                       | 51 |
| 5.1.2.3.2 | Transition from Address ACK to Mandatory Byte during IBI .....                                       | 52 |
| 5.1.2.3.3 | Ninth Bit of SDR Controller Written Data as Parity .....                                             | 55 |
| 5.1.2.3.4 | Ninth Bit of SDR Target Returned (Read) Data as End-of-Data... <td>56</td>                           | 56 |
| 5.1.2.4   | Use of Clock Speed to Prevent Legacy I <sup>2</sup> C Devices from Seeing I3C Traffic .. <td>57</td> | 57 |
| 5.1.2.4.1 | Use of Duty Cycle to Achieve Lower Effective Speed<br>in a Mixed Fast Bus.....                       | 58 |
| 5.1.2.5   | Controller Clock Stalling .....                                                                      | 59 |
| 5.1.2.5.1 | I3C/I <sup>2</sup> C Transfer, ACK/NACK Phase .....                                                  | 60 |
| 5.1.2.5.2 | Write Data Transfer, Parity Bit.....                                                                 | 60 |
| 5.1.2.5.3 | I3C Read Transfer, Transition Bit .....                                                              | 61 |
| 5.1.2.5.4 | Dynamic Address Assignment, First Bit of Assigned Address.....                                       | 63 |
| 5.1.3     | Bus Conditions.....                                                                                  | 64 |
| 5.1.3.1   | Open Drain Pull-Up and High-Keeper.....                                                              | 64 |
| 5.1.3.2   | Bus Condition Timing.....                                                                            | 65 |
| 5.1.3.2.1 | Bus Free Condition .....                                                                             | 65 |
| 5.1.3.2.2 | Bus Available Condition.....                                                                         | 65 |
| 5.1.3.2.3 | Bus Idle Condition .....                                                                             | 65 |
| 5.1.3.3   | Activity States.....                                                                                 | 66 |
| 5.1.4     | Bus Initialization and Dynamic Address Assignment Mode.....                                          | 67 |
| 5.1.4.1   | Device Requirements for Dynamic Address Assignment .....                                             | 68 |
| 5.1.4.1.1 | Target Device 48-bit Provisioned ID.....                                                             | 68 |
| 5.1.4.1.2 | Unique Identifiability Methods .....                                                                 | 68 |
| 5.1.4.2   | Bus Initialization Sequence with Dynamic Address Assignment .....                                    | 69 |
| 5.1.4.3   | Provisioned ID Collision Detection and Correction .....                                              | 73 |
| 5.1.4.4   | Group Address Assignment Procedure .....                                                             | 74 |
| 5.1.5     | Hot-Join Mechanism.....                                                                              | 76 |
| 5.1.5.1   | Failsafe Device Pads.....                                                                            | 80 |
| 5.1.5.2   | Legacy I <sup>2</sup> C Buses and Hot-Join .....                                                     | 80 |
| 5.1.5.3   | Passive Hot-Join .....                                                                               | 81 |
| 5.1.6     | In-Band Interrupt .....                                                                              | 82 |
| 5.1.6.1   | Priority Level .....                                                                                 | 82 |
| 5.1.6.2   | I3C Target Interrupt Request.....                                                                    | 82 |
| 5.1.6.2.1 | Mandatory Data Byte .....                                                                            | 84 |
| 5.1.6.2.2 | Pending Read Notification .....                                                                      | 86 |
| 5.1.6.3   | I3C Secondary Controller Requests to be Active Controller .....                                      | 88 |
| 5.1.6.4   | I3C Active Controller Initiating a Transaction.....                                                  | 88 |
| 5.1.7     | I3C Bus with Multiple Controllers.....                                                               | 89 |
| 5.1.7.1   | Preparing for Handoff.....                                                                           | 90 |
| 5.1.7.2   | Controller to Controller Handoff Procedure .....                                                     | 93 |

|            |                                                                          |     |
|------------|--------------------------------------------------------------------------|-----|
| 5.1.7.3    | Secondary Controller Functions .....                                     | 95  |
| 5.1.7.3.1  | Hardware and Software Requirements.....                                  | 96  |
| 5.1.7.3.2  | Minimum Bus Management Procedures .....                                  | 96  |
| 5.1.7.3.3  | Bus Configuration Procedures .....                                       | 97  |
| 5.1.7.3.4  | Reduced Functionality Secondary Controllers.....                         | 97  |
| 5.1.7.3.5  | In-Band Interrupt Handling .....                                         | 98  |
| 5.1.7.3.6  | Hot-Join Management.....                                                 | 98  |
| 5.1.7.3.7  | Group Address Management.....                                            | 98  |
| 5.1.7.3.8  | Multi-Lane Management.....                                               | 99  |
| 5.1.7.3.9  | Interoperability Among Controllers Based on Different I3C Versions ..... | 100 |
| 5.1.8      | Timing Control.....                                                      | 101 |
| 5.1.8.1    | General Principles.....                                                  | 102 |
| 5.1.8.2    | Synchronous Systems and Events.....                                      | 102 |
| 5.1.8.3    | Asynchronous Systems and Events .....                                    | 103 |
| 5.1.8.3.1  | Async Mode 0: Asynchronous Basic Mode .....                              | 106 |
| 5.1.8.3.2  | Async Mode 1: Asynchronous Advanced Mode .....                           | 108 |
| 5.1.8.3.3  | Async Mode 2: Async High-Precision Low-Power Mode .....                  | 108 |
| 5.1.8.3.4  | Async Mode 3: Async High-Precision Triggerable Mode.....                 | 108 |
| 5.1.9      | Common Command Codes (CCC) .....                                         | 109 |
| 5.1.9.1    | CCC Command Formats.....                                                 | 110 |
| 5.1.9.2    | Broadcast CCCs vs Direct CCCs.....                                       | 113 |
| 5.1.9.2.1  | End of a CCC Command.....                                                | 113 |
| 5.1.9.2.2  | Framing Model for Direct CCC Commands .....                              | 114 |
| 5.1.9.2.3  | Retry Model for Direct GET CCC Commands .....                            | 116 |
| 5.1.9.3    | CCC Command Definitions.....                                             | 117 |
| 5.1.9.3.1  | Enable/Disable Target Events Command (ENECDISSEC) .....                  | 125 |
| 5.1.9.3.2  | Enter Activity State 0–3 (ENTAS0–ENTAS3).....                            | 127 |
| 5.1.9.3.3  | Reset Dynamic Address Assignment (RSTDAA) .....                          | 129 |
| 5.1.9.3.4  | Enter Dynamic Address Assignment (ENTDAA).....                           | 129 |
| 5.1.9.3.5  | Set/Get Max Write Length (SETMWL/GETMWL) .....                           | 130 |
| 5.1.9.3.6  | Set/Get Max Read Length (SETMRL/GETMRL) .....                            | 132 |
| 5.1.9.3.7  | Define List of Targets (DEFTGTS).....                                    | 134 |
| 5.1.9.3.8  | Enter Test Mode (ENTTM).....                                             | 136 |
| 5.1.9.3.9  | Enter HDR Mode 0–7 (ENTHDR0–ENTHDR7).....                                | 137 |
| 5.1.9.3.10 | Set Dynamic Address from Static Address (SETDASA) .....                  | 138 |
| 5.1.9.3.11 | Set New Dynamic Address (SETNEWDA) .....                                 | 140 |
| 5.1.9.3.12 | Get Provisioned ID (GETPID).....                                         | 141 |
| 5.1.9.3.13 | Get Bus Characteristics Register (GETBCR).....                           | 142 |
| 5.1.9.3.14 | Get Device Characteristics Register (GETDCR) .....                       | 143 |
| 5.1.9.3.15 | Get Device Status (GETSTATUS) .....                                      | 144 |
| 5.1.9.3.16 | Get Accept Controller Role (GETACCR).....                                | 150 |
| 5.1.9.3.17 | Set Bridge Targets (SETBRGTGT).....                                      | 152 |
| 5.1.9.3.18 | Get Max Data Speed (GETMXDS).....                                        | 154 |
| 5.1.9.3.19 | Get Optional Feature Capabilities (GETCAPS).....                         | 163 |
| 5.1.9.3.20 | Set Route (SETROUTE) .....                                               | 179 |
| 5.1.9.3.21 | Set Exchange Timing Information (SETXTIME) .....                         | 181 |
| 5.1.9.3.22 | Get Exchange Timing Support Information (GETXTIME) .....                 | 183 |
| 5.1.9.3.23 | Set All Addresses to Static Address (SETAASA) .....                      | 185 |
| 5.1.9.3.24 | Device to Device(s) Tunneling Control (D2DXFER) .....                    | 185 |
| 5.1.9.3.25 | Data Transfer Ending Procedure Control (ENDXFER) .....                   | 186 |
| 5.1.9.3.26 | Target Reset Action (RSTACT).....                                        | 189 |
| 5.1.9.3.27 | Set Group Address (SETGRPA).....                                         | 193 |
| 5.1.9.3.28 | Reset Group Address (RSTGRPA).....                                       | 194 |
| 5.1.9.3.29 | Define List of Group Addresses (DEFGRPA).....                            | 196 |

|            |                                                                           |     |
|------------|---------------------------------------------------------------------------|-----|
| 5.1.9.3.30 | Multi-Lane Data Transfer Control (MLANE).....                             | 197 |
| 5.1.9.3.31 | Set Bus Context (SETBUSCON).....                                          | 204 |
| 5.1.9.4    | Direct CCCs and Group Addresses.....                                      | 207 |
| 5.1.10     | Error Detection and Recovery Methods for SDR .....                        | 209 |
| 5.1.10.1   | SDR Error Detection and Recovery Methods for I3C Target Devices.....      | 209 |
| 5.1.10.1.1 | Error Type TE0.....                                                       | 210 |
| 5.1.10.1.2 | Error Type TE1.....                                                       | 211 |
| 5.1.10.1.3 | Error Type TE2.....                                                       | 211 |
| 5.1.10.1.4 | Error Type TE3.....                                                       | 211 |
| 5.1.10.1.5 | Error Type TE4.....                                                       | 211 |
| 5.1.10.1.6 | Error Type TE5.....                                                       | 212 |
| 5.1.10.1.7 | Error Type TE6 (Optional).....                                            | 212 |
| 5.1.10.1.8 | Error Type DBR (Optional).....                                            | 213 |
| 5.1.10.1.9 | Optional Recovery Method for Error Types TE0 and TE1.....                 | 214 |
| 5.1.10.2   | SDR Error Detection and Recovery Methods for I3C Controller Devices ..... | 215 |
| 5.1.10.2.1 | Error Type CE0 .....                                                      | 215 |
| 5.1.10.2.2 | Error Type CE1 (Optional).....                                            | 215 |
| 5.1.10.2.3 | Error Type CE2 .....                                                      | 216 |
| 5.1.10.2.4 | Error Type CE3 .....                                                      | 216 |
| 5.1.10.2.5 | Controller Error Detection and Escalation Handling .....                  | 217 |
| 5.1.10.2.6 | Controller Stuck SDA Handling.....                                        | 218 |
| 5.1.10.2.7 | Controller Recovery After a Crash or Unexpected Reset.....                | 219 |
| 5.1.11     | Target Reset .....                                                        | 220 |
| 5.1.11.1   | Theory of Operation.....                                                  | 220 |
| 5.1.11.2   | RSTACT CCC .....                                                          | 222 |
| 5.1.11.3   | Target Reset Pattern .....                                                | 222 |
| 5.1.11.4   | Full/Chip Reset Behavior.....                                             | 223 |
| 5.1.11.4.1 | Primary Controller Behavior After Full/Chip Reset.....                    | 224 |
| 5.1.11.5   | Wake from Target Reset Behavior .....                                     | 224 |
| 5.1.12     | Monitoring Device Early Termination Capability.....                       | 225 |
| 5.1.13     | Device to Device(s) Tunneling .....                                       | 226 |
| 5.2        | High Data Rate (HDR) Modes .....                                          | 227 |
| 5.2.1      | HDR Common Flows and Framing .....                                        | 229 |
| 5.2.1.1    | HDR Exit Pattern and HDR Restart Pattern .....                            | 229 |
| 5.2.1.1.1  | HDR Exit Pattern .....                                                    | 229 |
| 5.2.1.1.2  | HDR Restart Pattern.....                                                  | 230 |
| 5.2.1.1.3  | HDR Exit Pattern Detector.....                                            | 231 |
| 5.2.1.1.4  | HDR Restart and Exit Pattern Detector.....                                | 233 |
| 5.2.1.1.5  | Compatibility of HDR Pattern Detection and Ternary Modes .....            | 234 |
| 5.2.1.2    | CCC Framing in HDR Modes.....                                             | 235 |
| 5.2.1.2.1  | Elements, Framing and Modality .....                                      | 238 |
| 5.2.1.2.2  | Broadcast Address ACK.....                                                | 246 |
| 5.2.1.2.3  | Direct CCC ACK/NACK and Retry .....                                       | 247 |
| 5.2.1.2.4  | Implications for Device and Bus Configuration.....                        | 248 |
| 5.2.1.2.5  | Implications for Multi-Lane .....                                         | 248 |
| 5.2.1.2.6  | Implications for Group Addressing .....                                   | 250 |
| 5.2.1.2.7  | Bus Efficiency .....                                                      | 251 |
| 5.2.1.3    | Transition to HDR Mode Transfer .....                                     | 252 |
| 5.2.1.3.1  | Entering the HDR Mode After ENTHDRx CCC .....                             | 253 |
| 5.2.1.3.2  | Next HDR Mode Transfer After HDR Restart Pattern .....                    | 254 |

|           |                                                              |     |
|-----------|--------------------------------------------------------------|-----|
| 5.2.2     | HDR Double Data Rate Mode (HDR-DDR) .....                    | 255 |
| 5.2.2.1   | HDR-DDR Overview .....                                       | 259 |
| 5.2.2.2   | HDR-DDR Command Coding.....                                  | 265 |
| 5.2.2.2.1 | CCC Transmission in HDR-DDR Mode .....                       | 268 |
| 5.2.2.3   | HDR-DDR Flow Control Elements .....                          | 276 |
| 5.2.2.3.1 | Command to Write Data to Target.....                         | 276 |
| 5.2.2.3.2 | Command to Read Data from Target.....                        | 280 |
| 5.2.2.3.3 | End of a Complete Data Frame Transfer.....                   | 284 |
| 5.2.2.3.4 | HDR-DDR Early Transfer Termination Set-Up .....              | 284 |
| 5.2.2.3.5 | Controller Ends or Continues the Read Transfer.....          | 286 |
| 5.2.2.3.6 | Target Ends or Continues the Write Transfer .....            | 292 |
| 5.2.2.4   | HDR-DDR Error Detection .....                                | 298 |
| 5.2.2.5   | HDR-DDR CRC-5 Algorithm.....                                 | 299 |
| 5.2.3     | HDR Ternary Modes (HDR-TSP / HDR-TSL) .....                  | 300 |
| 5.2.4     | HDR Bulk Transport Mode (HDR-BT) .....                       | 301 |
| 5.2.4.1   | SDA Lane Bit Packing: Data Bytes (Commands, Data, CRC) ..... | 304 |
| 5.2.4.2   | SDA Lane Bit Packing: Transition Bytes.....                  | 305 |
| 5.2.4.3   | HDR-BT Mode Structured Protocol Elements .....               | 306 |
| 5.2.4.3.1 | Header Block.....                                            | 307 |
| 5.2.4.3.2 | Data Blocks .....                                            | 309 |
| 5.2.4.3.3 | CRC Block .....                                              | 310 |
| 5.2.4.3.4 | Data Block Delay Mechanism.....                              | 315 |
| 5.2.4.3.5 | Performance .....                                            | 317 |
| 5.2.4.4   | CCC Transmission in HDR-BT Mode .....                        | 318 |
| 5.2.4.4.1 | HDR-BT CCC Header Block .....                                | 320 |
| 5.2.4.4.2 | HDR-BT CCC Data Block .....                                  | 321 |
| 5.2.4.4.3 | HDR-BT CRC Block .....                                       | 321 |
| 5.2.4.4.4 | HDR-BT CCC Indicator Block ACK .....                         | 322 |
| 5.2.4.4.5 | HDR-BT CCC Write Segment .....                               | 322 |
| 5.2.4.4.6 | HDR-BT CCC Read Segment.....                                 | 323 |
| 5.2.4.4.7 | HDR-BT CCC End Procedures.....                               | 323 |
| 5.2.4.5   | Options.....                                                 | 326 |
| 5.2.4.6   | Diagrams.....                                                | 327 |
| 5.2.4.7   | Transfer Flow Control.....                                   | 333 |
| 5.3       | Multi-Lane (ML) Data Transfer .....                          | 335 |
| 5.3.1     | ML Data Transfer Setup.....                                  | 336 |
| 5.3.1.1   | ML Device Configuration.....                                 | 336 |
| 5.3.1.1.1 | ML Devices with Group Addresses.....                         | 338 |
| 5.3.1.1.2 | ML Devices with Multiple Dynamic Addresses.....              | 341 |
| 5.3.1.2   | The ML Frame .....                                           | 343 |
| 5.3.2     | ML Frame Formats .....                                       | 344 |
| 5.3.2.1   | SDR Based ML Frame Formats .....                             | 344 |
| 5.3.2.2   | HDR-DDR Based ML Frame Formats .....                         | 344 |
| 5.3.2.3   | HDR-TSP Based ML Frame Formats .....                         | 344 |
| 5.3.2.4   | HDR-BT Based ML Frame Formats.....                           | 345 |
| 5.3.2.4.1 | HDR-BT Codings and Interoperability for CCCs .....           | 349 |
| 5.3.2.4.2 | HDR-BT DUAL Coding .....                                     | 357 |
| 5.3.2.4.3 | HDR-BT QUAD Coding.....                                      | 358 |
| 6         | I3C Electrical Specifications.....                           | 359 |
| 6.1       | DC I/O Characteristics .....                                 | 359 |
| 6.2       | Timing Specification .....                                   | 364 |

|                                                                                |     |
|--------------------------------------------------------------------------------|-----|
| Annex A I3C Communication Format Details .....                                 | 385 |
| A.1 I3C CCC Transfers .....                                                    | 385 |
| A.2 I3C Private Write and Read Transfers .....                                 | 386 |
| A.3 Legacy I <sup>2</sup> C Write and Read Transfers on the I3C Bus .....      | 388 |
| A.4 Dynamic Address and Enter HDR .....                                        | 390 |
| Annex B SDR Mode Error Type Origins .....                                      | 393 |
| B.1 Error Types in I3C CCC Transfers .....                                     | 393 |
| B.2 Error Types in I3C Private Read and Write Transfers .....                  | 394 |
| B.3 Error Types in Dynamic Address Arbitration .....                           | 396 |
| Annex C I3C Controller FSMs .....                                              | 397 |
| Annex D Typical I3C Protocol Communications .....                              | 405 |
| D.1 Typical SDR Private Read .....                                             | 405 |
| D.2 Typical Direct CCC in SDR Mode .....                                       | 406 |
| D.3 Typical Broadcast CCC in SDR Mode .....                                    | 407 |
| D.4 Typical HDR-DDR Read .....                                                 | 408 |
| D.5 Typical HDR-TSL Read .....                                                 | 408 |
| D.6 Typical HDR-TSP Read .....                                                 | 408 |
| D.7 Typical HDR-BT Read .....                                                  | 409 |
| Annex E MIPI I3C Basic Specification Supplemental Patent Licensing Terms ..... | 411 |
| Attachment A .....                                                             | 413 |
| Annex F I3C Basic Development Companies .....                                  | 415 |

## Figures

|                                                                                            |     |
|--------------------------------------------------------------------------------------------|-----|
| Figure 1 I3C System Diagram .....                                                          | 3   |
| Figure 2 I3C vs. I <sup>2</sup> C FM+ Data Blocks Bit Rates in Mbps (12.5 MHz Clock) ..... | 5   |
| Figure 3 I3C vs. I <sup>2</sup> C FM+ 1 kB Effective Data Transfer Times in Ms .....       | 6   |
| Figure 4 I3C vs. I2C FM+ Energy per 1 kB Effective Data Block, in mJ .....                 | 6   |
| Figure 5 I3C Multi-Lane Effective Bit Rates, in Mbps .....                                 | 7   |
| Figure 6 Example of Data Traffic on the I3C Bus .....                                      | 18  |
| Figure 7 I3C Communication Flow .....                                                      | 19  |
| Figure 8 I3C Controller Device Block Diagram.....                                          | 22  |
| Figure 9 I3C Target Device Block Diagram.....                                              | 25  |
| Figure 10 I3C Bus with I <sup>2</sup> C Devices and I3C Devices.....                       | 30  |
| Figure 11 I3C Minimal Bus with I3C Target Devices .....                                    | 31  |
| Figure 12 Address Header Comparison.....                                                   | 38  |
| Figure 13 Address Arbitration During Header.....                                           | 47  |
| Figure 14 Transition from Address ACK to Mandatory Byte During IBI .....                   | 53  |
| Figure 15 Transition from IBI Address NACK to Repeated START or STOP.....                  | 54  |
| Figure 16 Controller Clock Stalling in ACK Phase.....                                      | 60  |
| Figure 17 Controller Clock Stalling in Write Parity Bit .....                              | 60  |
| Figure 18 Controller Clock Stalling in T-Bit Before Next Read Data .....                   | 61  |
| Figure 19 Controller Clock Stalling in T-Bit Before STOP .....                             | 61  |
| Figure 20 Controller Clock Stalling in Low T-Bit Before Repeated START .....               | 62  |
| Figure 21 Controller Clock Stalling in High T-Bit Before Repeated START .....              | 62  |
| Figure 22 Controller Clock Stalling in High T-Bit Before Repeated START and STOP .....     | 63  |
| Figure 23 Controller Clock Stalling in Dynamic Address First Bit.....                      | 63  |
| Figure 24 Bus Condition Timing .....                                                       | 65  |
| Figure 25 Dynamic Address Assignment Transaction.....                                      | 71  |
| Figure 26 IBI Sequence with Mandatory Data Byte.....                                       | 83  |
| Figure 27 Pre-Handoff Steps Flow .....                                                     | 90  |
| Figure 28 Graphical Representation of Async Mode 0 Timestamp Interpolation .....           | 104 |
| Figure 29 Example of Asynchronous Mode 0 Timestamp Data Transfer.....                      | 106 |
| Figure 30 CCC Broadcast General Frame Format.....                                          | 111 |
| Figure 31 CCC Direct General Frame Format.....                                             | 111 |
| Figure 32 ENEC/DISEC Format 1: Direct .....                                                | 125 |
| Figure 33 ENEC/DISEC Format 2: Broadcast .....                                             | 125 |
| Figure 34 ENTASx Format 1: Direct.....                                                     | 127 |
| Figure 35 ENTASx Format 2: Broadcast.....                                                  | 128 |
| Figure 36 RSTDAA Format .....                                                              | 129 |
| Figure 37 ENTDA Format.....                                                                | 129 |
| Figure 38 Direct SETMWL/GETMWL Format .....                                                | 130 |
| Figure 39 Broadcast SETMWL Format.....                                                     | 131 |
| Figure 40 Direct SETMRL/GETMRL Format .....                                                | 132 |
| Figure 41 Broadcast SETMRL Format.....                                                     | 133 |
| Figure 42 DEFTGTS Format.....                                                              | 134 |
| Figure 43 ENTTM Format .....                                                               | 136 |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| Figure 44 SETDASA Format 1: Primary.....                                | 138 |
| Figure 45 SETDASA Format 2: Point-to-Point.....                         | 139 |
| Figure 46 SETNEWDA Format .....                                         | 140 |
| Figure 47 GETPID Format.....                                            | 141 |
| Figure 48 GETBCR Format .....                                           | 142 |
| Figure 49 GETDCR Format .....                                           | 143 |
| Figure 50 GETSTATUS Format 1 .....                                      | 144 |
| Figure 51 GETSTATUS Format 2 .....                                      | 147 |
| Figure 52 GETSTATUS Format 2 with Defining Byte PRECR.....              | 149 |
| Figure 53 GETACCCR Format 1: Accepted .....                             | 151 |
| Figure 54 GETACCCR Format 2: Not Accepted .....                         | 151 |
| Figure 55 GETACCCR Format 3: Incorrect Cancel.....                      | 151 |
| Figure 56 SETBRGTGT Format .....                                        | 152 |
| Figure 57 Components of Clock-to-Data Turnaround Delay (tsc0).....      | 155 |
| Figure 58 GETMXDS Format 1: Without Turnaround .....                    | 157 |
| Figure 59 GETMXDS Format 2: With Turnaround.....                        | 157 |
| Figure 60 GETMXDS Format 3: With Defining Byte .....                    | 159 |
| Figure 61 GETMXDS Format 3 With Defining Byte CRHDLY.....               | 161 |
| Figure 62 GETCAPS Format 1 .....                                        | 163 |
| Figure 63 GETCAPS Format 2 .....                                        | 168 |
| Figure 64 GETCAPS Format 2 with Defining Byte TESTPAT.....              | 170 |
| Figure 65 GETCAPS Format 2 with Defining Byte CRCAPS.....               | 172 |
| Figure 66 GETCAPS Format 2 with Defining Byte DBGCAPS .....             | 174 |
| Figure 67 GETCAPS Format 2 with Defining Byte VTCAPS.....               | 176 |
| Figure 68 SETROUTE Format.....                                          | 179 |
| Figure 69 Example Routing Device .....                                  | 180 |
| Figure 70 SETXTIME Format 1: Broadcast .....                            | 181 |
| Figure 71 SETXTIME Format 2: Direct .....                               | 182 |
| Figure 72 GETXTIME Format.....                                          | 183 |
| Figure 73 SETAASA Format.....                                           | 185 |
| Figure 74 ENDXFER Format 1: Broadcast.....                              | 186 |
| Figure 75 ENDXFER Format 2: Direct.....                                 | 187 |
| Figure 76 RSTACT Format 1: Broadcast .....                              | 189 |
| Figure 77 RSTACT Format 2: Direct Write .....                           | 190 |
| Figure 78 RSTACT Format 3: Direct Read .....                            | 190 |
| Figure 79 SETGRPA Format.....                                           | 193 |
| Figure 80 RSTGRPA Format 1: Direct.....                                 | 194 |
| Figure 81 Resetting a Group Address with the RSTGRPA Direct CCC .....   | 195 |
| Figure 82 RSTGRPA Format 2: Broadcast.....                              | 195 |
| Figure 83 DEFGRPA Format.....                                           | 196 |
| Figure 84 MLANE Format 1: Broadcast.....                                | 197 |
| Figure 85 MLANE Format 2: Direct .....                                  | 198 |
| Figure 86 MLANE Direct GET Version of SET/GET CCC (SDR Mode Only) ..... | 198 |
| Figure 87 SETBUSCON Format.....                                         | 205 |
| Figure 88 Example Waveform for Error Type TE0 .....                     | 210 |

|                                                                                                                          |     |
|--------------------------------------------------------------------------------------------------------------------------|-----|
| Figure 89 Target Reset Operations Flow .....                                                                             | 221 |
| Figure 90 Target Reset Pattern.....                                                                                      | 222 |
| Figure 91 HDR Exit Pattern Followed by STOP.....                                                                         | 229 |
| Figure 92 HDR Restart with Next Edge.....                                                                                | 230 |
| Figure 93 Example HDR Exit Pattern Detector (Schematic) .....                                                            | 231 |
| Figure 94 Metastable Changes on SCL and SDA Do Not Break the Exit Pattern Detector .....                                 | 231 |
| Figure 95 Combined HDR Restart and Exit Pattern Detector (Schematic).....                                                | 233 |
| Figure 96 Begin Broadcast CCC Per HDR Mode .....                                                                         | 241 |
| Figure 97 Begin Direct CCC Per HDR Mode .....                                                                            | 242 |
| Figure 98 End of CCC Procedures Per HDR Mode .....                                                                       | 244 |
| Figure 99 Entering HDR Mode After ENTHDRx CCC (Dedicated Edge Clock).....                                                | 253 |
| Figure 100 Next HDR Mode Transfer After HDR Restart Pattern (Dedicated Edge Clock).....                                  | 254 |
| Figure 101 HDR-DDR Word Formats.....                                                                                     | 256 |
| Figure 102 HDR-DDR Preamble Bits State Diagram .....                                                                     | 258 |
| Figure 103 Typical HDR-DDR Mode Frame .....                                                                              | 261 |
| Figure 104 HDR-DDR CRC and HDR Restart Pattern or HDR Exit Pattern in Write Transaction .....                            | 262 |
| Figure 105 HDR-DDR CRC and HDR Restart Pattern or HDR Exit Pattern in Read Transaction.....                              | 264 |
| Figure 106 HDR-DDR Command Code After ENTHDR0 .....                                                                      | 266 |
| Figure 107 HDR-DDR Command Code After HDR Restart Pattern.....                                                           | 267 |
| Figure 108 HDR-DDR Broadcast CCC Format .....                                                                            | 268 |
| Figure 109 HDR-DDR Direct CCC Format .....                                                                               | 269 |
| Figure 110 HDR-DDR CCC End Procedures.....                                                                               | 275 |
| Figure 111 Target Accepts DDR WRITE Command from Controller.....                                                         | 277 |
| Figure 112 Target Does Not Respond to DDR WRITE Command from Controller .....                                            | 279 |
| Figure 113 Target Accepts DDR READ Command from Controller .....                                                         | 281 |
| Figure 114 Target Does Not Respond to DDR READ Command from Controller .....                                             | 283 |
| Figure 115 Controller Ends DDR Read and Provides Either HDR Restart Pattern or HDR Exit Pattern ...                      | 287 |
| Figure 116 Controller Ends DDR Read and Target Provides CRC .....                                                        | 289 |
| Figure 117 Controller Continues DDR Read from Target .....                                                               | 291 |
| Figure 118 Target Requests DDR Write Termination and Controller Provides HDR Restart Pattern<br>or HDR Exit Pattern..... | 293 |
| Figure 119 Target Requests DDR Write Termination and Controller Provides CRC .....                                       | 295 |
| Figure 120 Target Continues the DDR Write From Controller.....                                                           | 297 |
| Figure 121 HDR-BT Header Block After ENTHDR3.....                                                                        | 302 |
| Figure 122 HDR-BT Header Block After HDR Restart Pattern.....                                                            | 302 |
| Figure 123 Typical HDR-BT Mode Frame.....                                                                                | 303 |
| Figure 124 Begin Broadcast CCC in HDR-BT .....                                                                           | 318 |
| Figure 125 Begin Direct CCC in HDR-BT .....                                                                              | 319 |
| Figure 126 HDR-BT CCC End Procedure Options.....                                                                         | 325 |
| Figure 127 Header Block for Single Lane .....                                                                            | 327 |
| Figure 128 Header Block for Dual Lane and Quad Lane .....                                                                | 328 |
| Figure 129 Data Block for Single Lane.....                                                                               | 329 |
| Figure 130 Data Block for Dual Lane and Quad Lane .....                                                                  | 330 |
| Figure 131 CRC Block for Single Lane .....                                                                               | 331 |
| Figure 132 CRC Block for Dual Lane.....                                                                                  | 331 |

|                                                                                                    |     |
|----------------------------------------------------------------------------------------------------|-----|
| Figure 133 CRC Block for Quad Lane.....                                                            | 332 |
| Figure 134 HDR-BT Flow Control for Write Transfers .....                                           | 333 |
| Figure 135 HDR-BT Flow Control for Read Transfers .....                                            | 334 |
| Figure 136 Typical ML I3C Frame Based on HDR-BT Mode (Coding 0).....                               | 346 |
| Figure 137 Typical ML I3C Frame Based on HDR-BT Mode (Coding 3).....                               | 347 |
| Figure 138 Typical ML I3C Frame Based on HDR-BT Mode (Coding 7).....                               | 348 |
| Figure 139 Valid State Transitions for HDR-BT Data Transfer Codings .....                          | 353 |
| Figure 140 I3C Legacy Mode Timing .....                                                            | 370 |
| Figure 141 $t_{DIG\_H}$ and $t_{DIG\_L}$ .....                                                     | 370 |
| Figure 142 I3C Write Address ACK.....                                                              | 371 |
| Figure 143 I3C Write Address NACK.....                                                             | 372 |
| Figure 144 I3C START Timing .....                                                                  | 373 |
| Figure 145 I3C STOP Timing.....                                                                    | 373 |
| Figure 146 I3C Controller Out Timing.....                                                          | 374 |
| Figure 147 I3C SDR Target Out Timing .....                                                         | 374 |
| Figure 148 Controller SDR Timing .....                                                             | 375 |
| Figure 149 Controller DDR Timing .....                                                             | 375 |
| Figure 150 T-Bit When Target Ends Read and Controller Generates STOP .....                         | 376 |
| Figure 151 T-Bit When Target Ends Read and Controller Generates Repeated START .....               | 377 |
| Figure 152 T-Bit When Target and Controller Agree to Continue Read Message.....                    | 378 |
| Figure 153 T-Bit When Controller Ends Read with Repeated START and STOP .....                      | 379 |
| Figure 154 T-Bit When Controller Ends Read via Repeated START and Further Transfer .....           | 380 |
| Figure 155 Controller to Controller Bus Handoff.....                                               | 381 |
| Figure 156 I <sup>2</sup> C Spike Filter Behavior .....                                            | 382 |
| Figure 157 I3C CCC Transfers.....                                                                  | 385 |
| Figure 158 I3C Private Write and Read Transfers with 7'h7E Address .....                           | 386 |
| Figure 159 I3C Private Write and Read Transfers without 7'h7E Address .....                        | 387 |
| Figure 160 Legacy I <sup>2</sup> C Write and Read Transfers in I3C Bus with 7'h7E Address .....    | 388 |
| Figure 161 Legacy I <sup>2</sup> C Write and Read Transfers in I3C Bus without 7'h7E Address ..... | 389 |
| Figure 162 Dynamic Address Allocation ENTDAA CCC Bus Modal .....                                   | 390 |
| Figure 163 Enter HDR Mode CCC Bus Modal.....                                                       | 391 |
| Figure 164 Error Type Origins: I3C CCC Transfers.....                                              | 393 |
| Figure 165 Error Type Origins: I3C Private Write & Read Transfers with 7'h7E Address .....         | 394 |
| Figure 166 Error Type Origins: I3C Private Write & Read Transfers without 7'h7E Address.....       | 395 |
| Figure 167 Error Type Origins: Dynamic Address Arbitration.....                                    | 396 |
| Figure 168 I3C Primary Controller FSM.....                                                         | 397 |
| Figure 169 In-Band Interrupt (Target Interrupt) Request FSM .....                                  | 398 |
| Figure 170 Dynamic Address Assignment FSM.....                                                     | 399 |
| Figure 171 Hot-Join FSM.....                                                                       | 400 |
| Figure 172 Controller Role Request FSM .....                                                       | 401 |
| Figure 173 Controller Regaining Bus Ownership FSM .....                                            | 402 |
| Figure 174 HDR-DDR Mode FSM .....                                                                  | 403 |
| Figure 175 I <sup>2</sup> C Legacy Controller FSM .....                                            | 404 |
| Figure 176 Example Communication Using I3C SDR Mode with Private Read .....                        | 405 |
| Figure 177 Example Communication Using I3C SDR Mode with Direct CCC.....                           | 406 |

|                                                                             |     |
|-----------------------------------------------------------------------------|-----|
| Figure 178 Example Communication Using I3C SDR Mode with Broadcast CCC..... | 407 |
| Figure 179 Example Communication Using HDR-DDR Protocol.....                | 408 |
| Figure 180 Example Communication Using HDR-BT Protocol .....                | 409 |

# Tables

|                                                                                        |     |
|----------------------------------------------------------------------------------------|-----|
| Table 1 Roles for I3C Compatible Devices .....                                         | 21  |
| Table 2 I3C Devices Roles vs Responsibilities .....                                    | 32  |
| Table 3 I <sup>2</sup> C Features Allowed in I3C Targets .....                         | 33  |
| Table 4 Legacy I <sup>2</sup> C-Only Target Categories and Characteristics.....        | 33  |
| Table 5 Bus Characteristics Register (BCR).....                                        | 35  |
| Table 6 I3C Device Characteristics Register (DCR) .....                                | 36  |
| Table 7 Legacy I <sup>2</sup> C Virtual Register (LVR).....                            | 36  |
| Table 8 I3C Target Address Restrictions .....                                          | 50  |
| Table 9 Available Options for Bus Operating Parameters, Per I3C Bus Configuration..... | 57  |
| Table 10 Controller Clock Stall Times .....                                            | 59  |
| Table 11 Activity States .....                                                         | 66  |
| Table 12 Mandatory Data Byte Field Format .....                                        | 84  |
| Table 13 Mandatory Data Byte Value Ranges .....                                        | 85  |
| Table 14 Asynchronous Timing Control Mode Supported in I3C Basic .....                 | 103 |
| Table 15 CCC Frame Field Definitions.....                                              | 112 |
| Table 16 I3C Common Command Codes .....                                                | 118 |
| Table 17 Enable/Disable Target Events Command Codes (ENECD/DISEC) .....                | 125 |
| Table 18 Enable Target Events Command Byte Format.....                                 | 126 |
| Table 19 Disable Target Events Command Byte Format.....                                | 126 |
| Table 20 Enter Activity State 0–3 Command Codes (ENTAS0–ENTAS3).....                   | 127 |
| Table 21 Enter Activity State CCCs (ENTASx) .....                                      | 128 |
| Table 22 Set/Get Max Write Length Command Codes (SETMWL/GETMWL).....                   | 130 |
| Table 23 Set/Get Max Read Length Command Codes (SETMRL/GETMRL) .....                   | 132 |
| Table 24 DEFTGTS Data Bytes for Target or Group .....                                  | 135 |
| Table 25 ENTTM Test Mode Byte Values.....                                              | 136 |
| Table 26 Enter HDR Mode CCCs (ENTHDRx).....                                            | 137 |
| Table 27 GETSTATUS MSB-LSB Format 1 .....                                              | 145 |
| Table 28 GETSTATUS Format 2 Defining Byte Values.....                                  | 147 |
| Table 29 Status Bytes for GETSTATUS Format 2 with Defining Byte PRECR .....            | 149 |
| Table 30 maxWr Byte Format .....                                                       | 158 |
| Table 31 maxRd Byte Format.....                                                        | 158 |
| Table 32 maxRdTurn Format.....                                                         | 159 |
| Table 33 GETMXDS Defining Byte Values.....                                             | 160 |
| Table 34 CRHDLY1 Byte Format .....                                                     | 162 |
| Table 35 GETCAP1 Byte Format.....                                                      | 164 |
| Table 36 GETCAP2 Byte Format.....                                                      | 165 |
| Table 37 GETCAP3 Byte Format.....                                                      | 166 |
| Table 38 GETCAP4 Byte Format.....                                                      | 167 |
| Table 39 GETCAPS Format 2 Defining Byte Values .....                                   | 169 |
| Table 40 TESTPAT Message Format.....                                                   | 171 |
| Table 41 CRCAP1 Byte Format .....                                                      | 172 |
| Table 42 CRCAP2 Byte Format .....                                                      | 173 |
| Table 43 DBGCAPS Message Format .....                                                  | 175 |

|                                                                                                                       |     |
|-----------------------------------------------------------------------------------------------------------------------|-----|
| Table 44 VTCAP1 Byte Format .....                                                                                     | 177 |
| Table 45 VTCAP2 Byte Format .....                                                                                     | 178 |
| Table 46 Set Exchange Timing Information Command Codes (SETXTIME) .....                                               | 181 |
| Table 47 SETXTIME Sub-Command Byte Values .....                                                                       | 182 |
| Table 48 GETXTIME Supported Modes Byte Fields.....                                                                    | 183 |
| Table 49 GETXTIME State Byte Fields.....                                                                              | 184 |
| Table 50 Data Transfer Ending Procedure Control Command Codes (ENDXFER) .....                                         | 186 |
| Table 51 ENDXFER Defining Byte Values.....                                                                            | 188 |
| Table 52 Target Reset Action Command Codes (RSTACT).....                                                              | 189 |
| Table 53 RSTACT Defining Byte Values .....                                                                            | 191 |
| Table 54 Reset Group Address Command Codes (RSTGRPA).....                                                             | 194 |
| Table 55 Multi-Lane Data Transfer Control Command Codes (MLANE).....                                                  | 197 |
| Table 56 MLANE Defining Bytes and Data Bytes.....                                                                     | 199 |
| Table 57 SETBUSCON Context Values.....                                                                                | 206 |
| Table 58 Direct CCC Support for Group Addresses.....                                                                  | 208 |
| Table 59 SDR Target Error Types.....                                                                                  | 209 |
| Table 60 SDR Controller Error Types .....                                                                             | 215 |
| Table 61 CCCs Permitted in HDR Modes, with Notes and Limitations.....                                                 | 236 |
| Table 62 CCCs Not Permitted in HDR Modes .....                                                                        | 237 |
| Table 63 HDR CCC Details Per HDR Mode.....                                                                            | 245 |
| Table 64 HDR-DDR Preamble Values.....                                                                                 | 257 |
| Table 65 HDR-DDR Word Format: Command, Data, Reserved .....                                                           | 259 |
| Table 66 HDR-DDR Word Formats .....                                                                                   | 260 |
| Table 67 HDR-DDR Command Word Format .....                                                                            | 265 |
| Table 68 Read and Write Command Spaces for HDR-DDR Mode .....                                                         | 265 |
| Table 69 ENDXFER CCC Additional Data Byte for Sub-Command 0xF7 (HDR-DDR Protocol) .....                               | 285 |
| Table 70 Data Byte Bit Packing: Single Lane .....                                                                     | 304 |
| Table 71 Data Byte Bit Packing: Dual Lane.....                                                                        | 304 |
| Table 72 Data Byte Bit Packing: Quad Lane.....                                                                        | 304 |
| Table 73 Transition Byte Bit Packing: Single Lane.....                                                                | 305 |
| Table 74 Transition Byte Bit Packing: Dual Lane with Bit2 Swizzle.....                                                | 305 |
| Table 75 Transition Byte Bit Packing: Quad Lane with Bit4 Swizzle.....                                                | 305 |
| Table 76 Example CRC Checksum Calculations .....                                                                      | 312 |
| Table 77 Bus Efficiency .....                                                                                         | 317 |
| Table 78 ML Lane Configurations.....                                                                                  | 337 |
| Table 79 All ML Frame Formats .....                                                                                   | 344 |
| Table 80 HDR-BT Frame Formats in Multi-Lane .....                                                                     | 345 |
| Table 81 HDR-BT Frame Format Details and Coding Interoperability for CCCs in Multi-Lane .....                         | 349 |
| Table 82 I3C I/O Stage Characteristics Common to Push-Pull Mode and Open Drain Mode .....                             | 360 |
| Table 83 I3C Low Voltage / High Capacitive Load I/O Stage Characteristics for Push-Pull Mode and Open Drain Mode..... | 362 |
| Table 84 Legacy I <sup>2</sup> C Device Requirements When Operating on I3C.....                                       | 363 |
| Table 85 I3C Timing Requirements When Communicating With I <sup>2</sup> C Legacy Devices .....                        | 365 |
| Table 86 I3C Open Drain Timing Parameters .....                                                                       | 366 |
| Table 87 I3C Push-Pull Timing Parameters for SDR, ML, HDR-DDR, and HDR-BT Modes .....                                 | 368 |

|                                                                                |     |
|--------------------------------------------------------------------------------|-----|
| Table 88 Timing and Drive for Start of New Frame: No Contention on A6.....     | 383 |
| Table 89 Timing and Drive for Start of New Frame: With Contention on A6.....   | 383 |
| Table 90 Timing and Drive for Continuation of Frame Using Repeated START ..... | 383 |

## Release History

| Date        | Version | Description                                      |
|-------------|---------|--------------------------------------------------|
| 08-Oct-2018 | v1.0    | Initial Board Adopted release.                   |
| –           | v1.1    | ( <b>Note:</b> Version number 1.1 was not used.) |
| 23-Jul-2021 | v1.1.1  | Board Adopted release.                           |

This page intentionally left blank.

## Preface to the I3C Basic Specification

### 1 What is MIPI I3C Basic?

1 MIPI I3C Basic is a feature-reduced, lower-complexity version of the powerful, flexible, and efficient MIPI  
2 I3C interface [*MIPI02*], suitable for a broad range of device interconnect applications including sensor and  
3 memory interfacing.

### 2 Motivation

4 MIPI Alliance considers I3C technology to have significant advantages over the widely adopted legacy  
5 interfaces currently used for similar applications, and wishes to see I3C technology broadly deployed in the  
6 industry. Being aware that some advanced I3C v1.x features are not needed for many common applications,  
7 and that some potential users might regard MIPI Alliance membership as a barrier, the MIPI Board of  
8 Directors decided to make the I3C Basic Specification freely available without requiring a MIPI Alliance  
9 membership, and to facilitate a royalty free licensing environment for all implementers, as described further  
10 below.

### 3 IPR Status

11 MIPI Alliance's regular intellectual property rights-related terms apply only by and among members. To  
12 address this issue, MIPI Alliance created a set of supplemental patent licensing terms for the current and  
13 future versions of the I3C Basic Specification, attached to this document as *Annex E*. MIPI required that all  
14 members participating in the development of the I3C Basic Specification agree to these additional terms.  
15 These terms include an obligation to license applicable patent claims to both member and non-member  
16 implementers, for uses both in mobile devices and otherwise, on "RAND-Z" terms: that is, under royalty free  
17 (the Z references zero royalty) and otherwise reasonable and non-discriminatory terms.

18 As described in *Annex E*, any implementer that wishes to benefit from the RAND-Z obligation must also  
19 commit to license other implementers under the same RAND-Z terms. This reciprocity requirement is  
20 intended to expand royalty free license obligations through the broader I3C Basic ecosystem.

21 The MIPI member companies that joined the I3C Basic Specification development effort and manifest  
22 agreement to the terms in *Annex E* are listed in *Annex F*. *Annex F* also notes if and when any party  
23 terminates their agreement to these terms (subject to certain ongoing license obligations, as described in the  
24 terms).

25 The I3C Basic IPR terms are intended to create a robust royalty free environment for implementers. However,  
26 no set of IPR terms can comprehensively address all potential risks. The terms apply only to those parties  
27 that agree to them, and the scope of application is limited to what is described in the terms. Implementers  
28 must ultimately make their own risk assessment, and the disclaimers described elsewhere in this document  
29 remain in full force and effect.

## 4 Relationship to MIPI I3C v1.x Specifications

The MIPI I3C Basic v1.1.1 Specification is a subset of the MIPI I3C v1.1.1 Specification. In the I3C Basic Specification, the terms “I3C,” “I3C Device,” and “I3C Bus” should be interpreted as referring to both I3C v1.1.1 and I3C Basic v1.1.1.

In addition, I3C Basic v1.1.1:

- Addresses all issues addressed by Errata 01 for I3C v1.1
- Includes numerous fixes, clarifications, and editorial improvements planned for inclusion in v1.1.1 of the MIPI I3C Specification. In general, these are not new feature additions, but represent the latest understanding and definition of I3C v1.1.1 features and capabilities.

### 4.1 I3C v1.1.1 Functions Not Included in I3C Basic

The following functions of the I3C v1.1.1 Specification have been removed from the I3C Basic v1.1.1 Specification. Companies interested in implementing these functions should [join MIPI Alliance](#) to enjoy member IPR licensing.

- Timing Control (*Section 5.1.8*), namely the portions addressing:
  - Synchronous Time Control
  - Asynchronous Time Control (Modes 1–3)
- Monitoring Device Early Termination Capability (*Section 5.1.12*)
- Device to Device(s) Tunneling (*Section 5.1.13*)
- HDR Ternary Modes (HDR-TSP and HDR-TSL) (*Section 5.2.3*)
- Multi-Lane support for SDR Mode, HDR-DDR Mode, and HDR-TSP Mode (*Section 5.3.2*)

### 4.2 Organization of This Specification

The structure of this Specification, i.e., the naming and numbering of Section headings, is consistent with the I3C v1.1.1 Specification. In order to preserve alignment with the I3C v1.1.1 Specification’s structure, numerous references to I3C v1.1.1 functions and capabilities that were removed for I3C Basic v1.1.1 are retained. In many cases the associated section headings are retained with a note that the content is only available in the full I3C v1.1.1 Specification.

### 4.3 I3C Basic v1.1.1 as an Update of I3C Basic v1.0

I3C Basic v1.1.1 is an updated, clarified version of I3C Basic with a simpler relationship to the full I3C Specification.

While I3C Basic v1.0 represented a reduced set of the full I3C v1.0 Specification’s features, it also included a number of additional functions not present in the full I3C v1.0. That is, I3C Basic v1.0 was not a strict subset of the full I3C v1.0.

In Version 1.1, the full I3C Specification incorporated all of these additional functions; further, all new features in I3C Basic v1.1.1 are also included in the full I3C v1.1.1 Specification. As a result, I3C Basic v1.1.1 is a strict subset of the full I3C v1.1.1 Specification.

## 5 How I3C Basic Devices Work with I3C v1.x Devices

MIPI I3C Basic Devices, whether Primary Controller, Secondary Controller, or Target, are intended to be interoperable with I3C v1.x Devices for the set of optional features that are mutually supported by the connected Devices. It is easiest to view I3C Basic as a subset of I3C, with a specific set of additional, optional features that are only offered to MIPI Alliance Members.

## 1 Introduction

I<sup>2</sup>C was introduced many years ago to provide a low cost method for connecting a processor to a set of devices to support the needs of consumer electronics; various flavors of I<sup>2</sup>C have continued to be widely used in many industries where its low cost ability to connect a set of devices (AKA Multi-Drop) has served the needs reasonably well, although often with the need for side-band pins, and often with interoperability challenges.

In mobile wireless devices the I<sup>2</sup>C tradition continued, but changing requirements had made I<sup>2</sup>C more and more problematic: with the increasing use of sensors, this started creating fragmentation in terms of choice of bus, including I<sup>2</sup>C, SPI, and UART to address bandwidth and other issues. Further, none of those buses addressed the pin count problems made far worse with more complex end-devices, including the need for various per-device GPIOs in parallel to the bus to cover interrupt (Target Device notifying Controller), sleep and reset signals, and so on. On top of that, the increasing number of devices with increasing amounts of data to send/receive has put pressure on bus bandwidth and latency. Adding more buses adds more pins, more traces, and more power.

The MIPI I3C interface has been developed to address these sensor integration concerns, as well as those historically encountered while using I<sup>2</sup>C, SPI, and UART in any product, by providing a fast, low cost, low power and managed, two-wire digital interface. MIPI worked to address a set of key issues across: performance, power, extraneous pins (e.g., Targets interrupting and reset control), interoperability, bus management, and error-handling/stuck-bus protections; it chose to do all of this while maintaining backwards compatibility with legacy I<sup>2</sup>C, to aid in transition and evolution.



**Figure 1 I3C System Diagram**

## 1.1 Scope

The following topics are in scope for this Specification:

- I3C interface protocols and commands
- Electrical specifications, such as timing and voltage levels
- Support for specific classes of Devices (e.g., sensors)

The following topics are out of scope for this Specification:

- Mechanical, system, and implementation details within an I3C Device
- ESD (Electrostatic Discharge) structures
- System power management
- Use case specific data or format definitions besides Bus management command codes

## 1.2 I3C Purpose

The I3C interface is intended to improve upon the features of the I<sup>2</sup>C interface *[NXP01]*, preserving backward compatibility. This Specification defines a standard Multi-Drop interface between Host processors and peripheral Devices (e.g., sensors).

Implementing the I3C Specification greatly increases the flexibility system designers have to supplant incumbent interfaces (i.e., I<sup>2</sup>C, SPI, UART) and support a wide array of Devices of increasing complexity and diversity in their system (e.g., sensor subsystem) and at as low a cost as possible.

## 1.3 I3C Key Features

Two main concerns are paramount for the I3C interface: The use of as little energy as possible in transporting data and control, while reducing the number of physical pins used by the interface.

Therefore, the I3C interface features:

- Two-wire serial interface up to 12.5 MHz using Push-Pull
- Legacy I<sup>2</sup>C Device co-existence on the same Bus (with some limitations)
- Dynamic Addressing while supporting Static Addressing for Legacy I<sup>2</sup>C Devices
- Legacy I<sup>2</sup>C messaging
- I<sup>2</sup>C-like Single Data Rate messaging (SDR)
- Optional High Data Rate messaging Modes (HDR):
  - HDR-DDR for Double Data Rate
  - **NOT INCLUDED IN I3C BASIC:** HDR-TSL for Ternary Symbol Legacy-inclusive-Bus (I<sup>2</sup>C Devices allowed)
  - **NOT INCLUDED IN I3C BASIC:** HDR-TSP for Ternary Symbol for Pure Bus (no I<sup>2</sup>C Devices allowed)
  - HDR-BT for Bulk Transport
- Multi-Drop a multitude of physically and virtually attached Devices
- Multi-Controller capability
- In-Band Interrupt support
- Hot-Join support
- **NOT INCLUDED IN I3C BASIC:** Synchronous Timing Support
- Asynchronous Time Stamping (for Mode 0 only)
- Grouped Addressing
- Target Reset without additional wires
- **NOT INCLUDED IN I3C BASIC:** Monitoring Device Early Termination

- **NOT INCLUDED IN I3C BASIC:** Device to Device(s) Tunneling
- Multi-Lane Data Transfer, for some HDR Modes included in I3C Basic

**Note:**

*Multi-Lane Data Transfers for SDR Mode and HDR-DDR Mode is not included in I3C Basic*

The I3C interface provides major efficiencies in Bus power while providing greater significant speed improvements over I<sup>2</sup>C. **Figure 2** through **Figure 5** show different Bus Mode options that provide tradeoffs for performance/power vs. target Device complexity. The following conditions were assumed for all calculations:

- Devices are in close vicinity:
  - Targets clustered close to Controller
  - No delay on the wires
- Total leakage on each wire: 4  $\mu$ A
- Driver's internal resistance: 90  $\Omega$
- Total Bus capacitance: 50 pF
- Bus main clock: 12.5 MHz
- $V_{DD} = 1.8V$
- Pull-Up resistor on Open-Drain: 2833  $\Omega$
- Equal probability for 1 and 0 on data transmission

**Figure 2** shows the Raw and Effective single-Lane bit rates of the I3C Modes compared to I<sup>2</sup>C FM+ (1 MHz).

**Note:**

*HDR-TSP Mode and HDR-TSL Mode are not included in I3C Basic.*

*To gain access to these HDR Modes, please contact MIPI Alliance.*

**Figure 2 I3C vs. I<sup>2</sup>C FM+ Data Blocks Bit Rates in Mbps (12.5 MHz Clock)**

148 **Figure 3** shows the effective single lane transfer time of 1 kB block of data for the I3C Modes compared to  
149 I<sup>2</sup>C FM+ (1 MHz).



150 **Note:**

151 *HDR-TSP Mode and HDR-TSL Mode are not included in I3C Basic.*

152 *To gain access to these HDR Modes, please contact MIPI Alliance.*

153 **Figure 3 I3C vs. I<sup>2</sup>C FM+ 1 kB Effective Data Transfer Times in Ms**

155 **Figure 4** shows the amount of Energy (mJ) consumed for an effective single lane of 1 kB block of data for  
156 the I3C Modes compared to I<sup>2</sup>C FM+ (1 MHz).



157 **Note:**

158 *HDR-TSP Mode and HDR-TSL Mode are not included in I3C Basic.*

159 *To gain access to these HDR Modes, please contact MIPI Alliance.*

160 **Figure 4 I3C vs. I<sup>2</sup>C FM+ Energy per 1 kB Effective Data Block, in mJ**

162 **Figure 5** shows the Effective Bitrates (Mbps) of the different I3C Modes over Multi-Lane.



163  
164 **Note:**  
165 *Multi-Lane support for HDR-TSP Mode and SDR Mode are not included in I3C Basic.*  
166 *To gain access to these capabilities, please contact MIPI Alliance.*

167 **Figure 5 I3C Multi-Lane Effective Bit Rates, in Mbps**

## 2 Terminology

### 2.1 Use of Special Terms

The MIPI Alliance has adopted Section 13.1 of the *IEEE Standards Style Manual*, which dictates use of the words ‘shall’, ‘should’, ‘may’, and ‘can’ in the development of documentation, as follows:

The word *shall* is used to indicate mandatory requirements strictly to be followed in order to conform to the Specification and from which no deviation is permitted (*shall* equals *is required to*).

The use of the word *must* is deprecated and shall not be used when stating mandatory requirements; *must* is used only to describe unavoidable situations.

The use of the word *will* is deprecated and shall not be used when stating mandatory requirements; *will* is only used in statements of fact.

The word *should* is used to indicate that among several possibilities one is recommended as particularly suitable, without mentioning or excluding others; or that a certain course of action is preferred but not necessarily required; or that (in the negative form) a certain course of action is deprecated but not prohibited (*should* equals *is recommended that*).

The word *may* is used to indicate a course of action permissible within the limits of the Specification (*may* equals *is permitted to*).

The word *can* is used for statements of possibility and capability, whether material, physical, or causal (*can* equals *is able to*).

All sections are normative, unless they are explicitly indicated to be informative.

All quoted voltage and frequency values in the informative sections represent their typical values.

### 2.2 Definitions

**1-Wire:** A communication bus protocol.

**ACK:** Short for ‘acknowledge’. See also **NACK**.

**Active Controller:** The I3C Device that presently has control (i.e., the Controller Role) of the I3C Bus.

**Address Arbitration:** Process for determining arbitrated Addresses to resolve contention.

**Address:** A set of bits designating a Device or the location of a register.

**Arbitrable:** Subject to decision by Arbitration.

**Arbitration:** If two Devices start transmission at the same time, then Arbitration is required to determine Bus control. Arbitration could also be required during a Target transmission if a Controller addresses multiple Targets.

**Bit Banged:** When GPIOs are manually changed by software to follow a protocol. For example, software could operate in I<sup>2</sup>C Controller mode quite easily by writing the SCL pin and reading/writing the SDA pin in between.

**Bridge Device:** Device on the I3C Bus that allows conversion from the native I3C Bus protocol to another protocol (such as SPI, UART etc.).

**Broadcast:** A command intended for multiple Target Devices, using the Broadcast Address 7'h7E.

**Bus:** The physical and logical implementation of the SCL and SDA lines.

**Bus Available Condition:** A period during which the Bus Free Condition, after a STOP and before a START, is sustained continuously for a duration of at least t<sub>VAL</sub> (see **Table 86** and **Section 5.1.3.2.2**).

205 **Bus Free Condition:** A period after a STOP and before a START with a duration of at least  $t_{CAS}$  (see **Table 86**  
206 for a Pure Bus, and at least  $t_{BUF}$  (see **Table 85**, **Table 86**, and **Section 5.1.3.2**) for a Mixed Bus.

207 **Bus Idle Condition:** A period during which the Bus Free Condition, after a STOP and before a START, is  
208 sustained continuously for a duration of at least  $t_{IDLE}$  (see **Table 86** and **Section 5.1.3.2.3**).

209 **Bus Turnaround:** When a transmitting Device sends a command, and then the receiving Device takes over  
210 the I3C Bus in order to respond.

211 **Characteristics:** Quantification of a Device's available features and capabilities.

212 **Clock to Data Turnaround Time:** The time duration between reception of an SCL edge and the start of  
213 driving an SDA change. See  $t_{SCO}$  in **Table 87**.

214 **Coding:** See Data Transfer Coding.

215 **Controller:** An I3C Device that is capable of controlling the I3C Bus.

216 **Note:**

217 *In previous versions of the I3C and I3C Basic Specifications, a Controller Device was called a "Master  
218 Device". This version of the I3C Basic Specification (as well as the I3C v1.1.1 Specification) has  
219 deprecated the term "Master", and now uses the updated normative term "Controller." Please note  
220 that the technical definition of such a Device, and its Role on an I3C Bus, are unchanged.*

221 *Unless specified otherwise, a Controller as a Device (or its Role) is a generic term between I3C Basic  
222 and I3C. Such a Device may comply with either this I3C Basic Specification or a compatible version  
223 of the full I3C Specification [MIPI08] in cases where this distinction is not technically pertinent.*

224 **Controller Role:** Control of the I3C Bus, in a Controller role. See **Active Controller**.

225 **Controller Role Request:** A method whereby a Controller-capable Device (i.e., a Secondary Controller)  
226 requests to become the next Active Controller of the Bus, using a form of interrupt request (i.e., In-Band  
227 Interrupt).

228 **CRC-5:** Cyclic Redundancy Check with fifth-order polynomial length:

$$\text{CRC-5} = X^5 + X^2 + X^0$$

230 **CRC-16:** Cyclic Redundancy Check with sixteenth-order polynomial length, as defined by ANSI and used  
231 in USB (also known as CRC-16-IBM):

$$\text{CRC-16} = X^{16} + X^{15} + X^2 + 1$$

233 **CRC-32:** Cyclic Redundancy Check with thirty-second-order polynomial length:

$$\text{CRC-32} = X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$$

235 **Data Transfer Coding:** A specific contract for extending an I3C Mode to use additional Data Lanes (i.e.,  
236 Multi-Lane). The contract may include changes to the framing, flow, and data bit/byte packing of the  
237 structured protocol elements. In some sections of this Specification related to Multi-Lane, a Data Transfer  
238 Coding may also be referred to as simply a Coding.

239 **Device:** A Controller or Target.

240 **Device ID:** Defines a Device's characteristic or function within a sensor system.

241 **Dynamic Address:** A Device Address that is assigned or allocated during initialization of the Bus. Usually  
242 occurs after power up.

243 **Failsafe:** An I3C Device Bus pad is considered Failsafe if its leakage does not increase when it is unpowered.  
244 A pad may be unpowered because the Device is unpowered, because its IO rail is unpowered or clamped, or  
245 both. Failsafe only matters for some Hot-Join Devices.

246 **Flow Element:** A structured protocol element, such as a Word or a Block, used as portion of the framing of  
247 a given flow to indicate various phases of data transmission to define the Frame, as well as other necessary  
248 conditions such as Bus Turnaround.

249     **Frame:** A Frame begins with a START, followed by the Address of the Target(s), Data, and finally a STOP.  
250     **High:** Defines a signal level that is a logical ‘1’.  
251     **High Data Rate (HDR):** High Data Rate Modes that achieve higher speed by transferring data on both clock  
252     edges.  
253     **High-Keeper:** A weak Pull-Up type Device used when SDA, and sometimes SCL, is in High-Z with respect  
254     to all Devices.  
255     **Host:** Hardware and software that provides the core functionality of a mobile device.  
256     **Hot-Join:** Targets that join the Bus after it is already started, whether because they were not powered  
257     previously or because they were physically inserted into the Bus; the Hot-Join mechanism allows the Target  
258     to notify the Controller that it is ready to get a Dynamic Address.  
259     **Hot-Join Request:** A method whereby a Target joins the Bus and requests a Dynamic Address from the  
260     Controller, using a special Interrupt request with a reserved I3C Address.  
261     **Hot-Joining Device:** A Device that is currently attempting to join the Bus (i.e., as a Target or Secondary  
262     Controller) using the Hot-Join Request.  
263     **In-Band Interrupt (IBI):** A method whereby a Target Device emits its Address into the arbitrated Address  
264     header on the I3C Bus to notify the Controller of an interrupt.  
265     **I<sup>2</sup>C Device:** A Controller or Target that meets the requirements of the I<sup>2</sup>C Specification [*NXP01*].  
266     **I3C Basic Device:** A Controller or Target that meets the requirements of this I3C Basic specification (not the  
267     full I3C Specification [*MIPI08J*]). That is, an I3C Basic Device supports only the I3C Basic core capabilities  
268     plus any optional features and capabilities defined in this I3C Basic Specification; it does not support any  
269     optional features defined only in the full I3C Specification.  
270     **Note:**  
271         *An I3C Basic Device is defined to be interoperable with I3C with respect to the core capabilities that  
272         I3C and I3C Basic share, and with respect to I3C Basic’s optional features and capabilities.*  
273         *See the **Preface** for an overview of I3C v1.1.1 functions not included in I3C Basic and how I3C Basic  
274         Devices work with I3C v1.x Devices; see also other sections in this Specification that define the  
275         specific features.*  
276     **I3C Basic Controller:** An I3C Basic Device that is Controller-capable, i.e., that can hold the Controller Role  
277     of an I3C Bus. See also Controller and I3C Basic Device.  
278     **I3C Controller:** See Controller.  
279     **I3C Device:** A Controller or Target that meets the requirements of either this I3C Basic Specification, or of  
280     a version of the full I3C Specification that is interoperable with I3C Basic (e.g., I3C v1.1.1 [*MIPI08J*]).  
281     **Note:**  
282         *In this Specification, I3C Device typically describes compatibility with I3C in a generic sense. An I3C  
283         Device does not always imply an I3C Basic Device, since an I3C Device can support either I3C or I3C  
284         Basic where such distinctions are not technically pertinent. However, in cases where an I3C Bus  
285         contains both I3C Basic Devices and other I3C Devices that comply with the full I3C Specification and  
286         that also use features or capabilities that are not included in I3C Basic, there might be restrictions on  
287         which features or capabilities can be used with such an I3C Basic Device, and certain compatibility  
288         concerns should be understood and addressed. See the **Preface** for an overview.*  
289     **I3C Master:** Deprecated term, see Controller.  
290     **I3C Slave:** Deprecated term, see Target.  
291     **I3C Target:** See Target.  
292     **Legacy I<sup>2</sup>C:** I3C maintains the industry standard architecture of I<sup>2</sup>C and supports existing I<sup>2</sup>C Target Devices.  
293     I3C does not support I<sup>2</sup>C Bus Controllers.

294      **Note:**

295      A Legacy I<sup>2</sup>C “Target” Device is defined to have the same meaning as an I<sup>2</sup>C “Slave” Device, as  
296      defined in the current version of the I<sup>2</sup>C Specification [NXP01].

297      **Low:** Defines a signal level that is a logical ‘0’.

298      **Master:** Deprecated term, see Controller.

299      **Message:** A packetized communication between Devices.

300      **Minimal Bus:** An I3C Bus with one Controller Device (potentially with reduced functionality), and one  
301      active Target Device with a fixed and reserved Target Address value of 7'h01. Additional Read-only Target  
302      Devices may optionally also be present in a Minimal Bus, but there can be no additional Read-Write Target  
303      Devices.

304      **MIPI Manufacturer ID:** A two-byte/16-bit unique identifier for a vendor of a MIPI compliant Device  
305      [MIPI01].

306      **Mixed Bus:** An I3C Bus topology with both I<sup>2</sup>C and I3C Devices present on the I3C Bus. May be either a  
307      Mixed Fast Bus or a Mixed Slow/Limited Bus.

308      **Mixed Fast Bus:** I3C Bus topology with both I<sup>2</sup>C and I3C Devices present on the I3C Bus, where the I<sup>2</sup>C  
309      Devices have a true I<sup>2</sup>C 50 ns Spike Filter on the SCL line.

310      **Mixed Slow/Limited Bus:** I3C Bus topology with both I<sup>2</sup>C and I3C Devices present on the I3C Bus, where  
311      the I<sup>2</sup>C Devices do not have a true I<sup>2</sup>C 50 ns Spike Filter on the SCL line.

312      **Mode:** Distinguishes different data transfer methods used in I3C and I3C Basic, including Legacy I<sup>2</sup>C Mode,  
313      Single Data Rate Mode (SDR), High Data Rate Mode (HDR), Dual Data Rate Mode (HDR-DDR), and HDR  
314      Bulk Transport Mode (HDR-BT). Note that I3C Basic does not include support for the HDR Ternary Modes  
315      that are defined in the full I3C Specification: Ternary Symbol Legacy Mode (HDR-TSL) and Ternary Symbol  
316      for Pure Bus Mode (HDR-TSP).

317      **Multi-Controller:** Multiple Bus Controllers present on the Bus. Used when multiple nodes on the Bus need  
318      to initiate a transfer.

319      **Multi-Drop:** A Bus that communicates through a process of Arbitration to determine which Device sends  
320      information at any point. The other Devices listen for data they are intended to receive.

321      **Multi-Lane:** A method of using more physical wires (i.e., additional Data Lanes along with the SDA Lane)  
322      to achieve higher data transfer rates in various I3C Modes.

323      **NACK:** Short for “not acknowledge”, which means No ACK was asserted. See also **ACK**.

324      **Offline Capable:** An Offline Capable Device is able to disconnect from the physical I3C Bus and/or is able  
325      to ignore I3C traffic on the I3C Bus. A Device’s Offline capability is one of the capabilities reflected in its  
326      Bus Characterization Register.

327      **Open Drain:** High-Z with an active Pull-Down. Typically used in conjunction with a passive Pull-Up.

328      **Park:** Logic level High set by the Controller (or Target on Read) before turning around the Bus to allow the  
329      other to drive to Logic level Low or not (will be held High by weak Pull-Up).

330      **Peripheral:** The portion of the logic of a Device that implements the I3C Bus protocol, usually including  
331      any FIFOs or other buffers, and an interface to the rest of the system, such as an internal bus to a processor.

332      **Preamble:** The bits preceding the data Words in HDR-DDR.

333      **Primary Controller:** The Controller-capable I3C Device that initializes the I3C Bus and performs  
334      configuration of all Target Devices. It acts as the authority for the Bus in its initial state, and becomes the  
335      first Active Controller once the Bus is configured.

336      **Pull-Down:** Active mechanism used to pull the Bus to a logical Low state.

337      **Pull-Up:** Mechanism used to pull the Bus to a logical High state. The mechanism may be either active or  
338      passive.

- 339   **Pure Bus:** A Bus topology with only I3C Devices present. No I<sup>2</sup>C Devices are permitted on a Pure Bus.
- 340   **Push-Pull:** Active Pull-Down and active Pull-Up on output driver.
- 341   **Read Segment:** A series of Flow Elements that comprise a Read transaction addressing a Target, within the  
342   framing of a given HDR Mode. Usually part of a Direct SET CCC flow.
- 343   **Repeated START:** Two or more instances of a START in a row without an intervening STOP. A Repeated  
344   START is used in circumstances where the Controller wishes to continue communicating on the I3C Bus  
345   without having to first generate a STOP. In this Specification, a Repeated START is abbreviated as ‘Sr’. This  
346   is equivalent to Repeated START in I<sup>2</sup>C [**NXP01**].
- 347   **Route:** Path through a Device connecting two different I3C Buses. A given Device may contain one or more  
348   Routes.
- 349   **Routing Device:** Device on the I3C Bus that allows conversations between two or more different I3C Buses  
350   through integrated logic on the given Device. The Routing Device (as distinct from a Bridge Device)  
351   buffers/queues the transactions, causing the Device to be non-transparent.
- 352   **SDR-Only:** An SDR-Only Device supports only SDR Mode, i.e., does not support HDR Mode.
- 353   **Secondary Controller:** A Controller-capable I3C Device that initially acts as a Target, but can also accept  
354   the Controller Role from any Active Controller (including the Primary Controller). Once a Secondary  
355   Controller accepts the Controller Role it becomes the new Active Controller, and may then pass the Controller  
356   Role along: either back to the previous Active Controller, or on to any other Controller-capable Device  
357   present on the I3C Bus.
- 358   **Segment:** A series of Flow Elements that comprise either a Read or Write transaction addressing a Target or  
359   Group, within the framing of a given HDR Mode. Usually part of a Direct CCC flow.
- 360   **Single Data Rate (SDR):** Single Data Rate transfers data on only one edge of the clock.
- 361   **Slave:** Deprecated term; see **Target**.
- 362   **Spike Filter:** A filter that removes SCL (and SDA) spikes shorter than 50 ns in duration. See Input Filter (*t<sub>SP</sub>*  
363   parameter) in the I<sup>2</sup>C Specification [**NXP01**]. Also known as a glitch filter.
- 364   **Stall:** The act of the I3C Controller holding the SCL line Low under specific transitory conditions.
- 365   **START:** START is the I3C Bus condition of a High to Low transition on the SDA line while the SCL line  
366   remains High. In this Specification, a START is abbreviated as ‘S’.
- 367   **START Request:** A method for a Target to force the Controller to issue a START on an idled I3C Bus.
- 368   **Static Address:** A Device Address that is fixed and cannot be changed.
- 369   **STOP:** STOP is the I3C Bus condition of a Low to High transition on the SDA line while the SCL line  
370   remains High. In this Specification, a STOP is abbreviated as ‘P’.
- 371   **Swizzle:** To swap or interleave bits.
- 372   **T-Bit:** Transition bit, an alternative to the ACK/NACK mechanism.
- 373   **Target:** A Target Device can only respond to either Common or individual commands from a Controller.
- 374   **Note:**
- 375   *In previous versions of the I3C Basic Specification (as well as some previous versions of the full  
376   I3C Specification), a Target Device was called a “Slave” Device. This version of the I3C Basic  
377   Specification has deprecated the term “Slave” and now uses the updated normative term “Target”.  
378   Please note that the technical definition of such a Device, and its Role on an I3C Bus, are  
379   unchanged. Unless specified otherwise, a Target as a Device (or its Role) is a generic term  
380   between I3C Basic and I3C. Such a Device may comply with either this I3C Basic Specification or  
381   a compatible version of the full I3C Specification [**MIP108**] in cases where this distinction is not  
382   technically pertinent.*
- 383   **Target Reset:** The Target Reset mechanism allows the Controller to request a reset of specific Target Devices,  
384   including: reset of the I3C Peripheral, reset of the whole Device, and wake from deepest sleep. Target Reset

385 uses a specialized pattern of Bus activity (specifically, an extension of the HDR Exit pattern) that cannot  
386 occur in any other way in the I3C protocol.

387 **Termination Marker:** A Flow Element or other unique HDR Pattern that signifies the end of a specific Flow  
388 Element, a Segment, or the data message sent by the Controller as part of a Broadcast CCC flow.

389 **Ternary Mode:** These Modes are defined in the full I3C Specification, and I3C Basic does not include  
390 support for them: HDR-TSP (Ternary Symbol for Pure Bus) Mode and HDR-TSL (Ternary Symbol Legacy)  
391 Mode.

392 **Timestamping:** The act of determining and assigning the time at which an event occurred.

393 **Timing Control:** Methods of exchanging and controlling system timing information, with the intent to  
394 synchronize and/or Timestamp I3C Bus Devices and events. See *Section 5.1.8*.

395 **Virtual Target:** A physical Device that represents multiple I3C Targets, often implemented as multiple Target  
396 Devices sharing a common set of I3C pads. Additionally, there can be multiple Virtual Targets inside a single  
397 Device or a Bridge/Hub that manages the Bus connection. See also *Table 5*, *Section 5.1.2.1.2*, and  
398 *Section 5.1.9.3.19*.

399 **Virtual Target Detect Operation:** A method for determining which Virtual Targets share the same Peripheral  
400 logic within a particular I3C Device.

401 **Word:** Transmission containing 16 payload bits and two parity bits.

402 **Write Segment:** A series of Flow Elements that comprise a Write transaction addressing a Target or Group,  
403 within the framing of a given HDR Mode. Usually part of a Direct SET CCC flow.

## 2.3 Abbreviations

|     |        |                                                                                     |
|-----|--------|-------------------------------------------------------------------------------------|
| 404 | ACK    | Acknowledge                                                                         |
| 405 | e.g.   | For example (Latin: exempli gratia)                                                 |
| 406 | High-Z | An output driver that is set to high impedance mode (cannot source or sink current) |
| 407 | i.e.   | That is (Latin: id est)                                                             |
| 408 | NACK   | Not Acknowledge                                                                     |
| 409 | P      | STOP                                                                                |
| 410 | PHY    | Physical Layer                                                                      |
| 411 | S      | START                                                                               |
| 412 | Sr     | Repeated START                                                                      |
| 413 | T      | Transition Bit                                                                      |

## 2.4 Acronyms

|     |         |                                                           |
|-----|---------|-----------------------------------------------------------|
| 414 | AXI     | Advanced eXtensible Interface                             |
| 415 | BCR     | Bus Characteristics Register                              |
| 416 | CCC     | Common Command Code                                       |
| 417 | CRC     | Cyclic Redundancy Check                                   |
| 418 | CRR     | Controller Role Request                                   |
| 419 | D2DT    | Device to Device(s) Tunneling                             |
| 420 | DCR     | Device Characteristics Register                           |
| 421 | DDR     | Double Data Rate                                          |
| 422 | ESD     | Electro Static Discharge                                  |
| 423 | FSM     | Finite State Machine                                      |
| 424 | HDR     | High Data Rate                                            |
| 425 | HDR-DDR | HDR Double Data Rate Mode                                 |
| 426 | IBI     | In-Band Interrupt                                         |
| 427 | IMU     | Inertial Measurement Unit                                 |
| 428 | LCR     | Legacy Characteristics Register                           |
| 429 | LIN     | Local Interconnect Network                                |
| 430 | LSB     | Least Significant Byte                                    |
| 431 | LSb     | Least Significant Bit                                     |
| 432 | Mbps    | Megabits per second                                       |
| 433 | MHz     | Mega Hertz                                                |
| 434 | MID     | MIPI Manufacturer Identification [ <i>MIPI01</i> ]        |
| 435 | MSB     | Most Significant Byte                                     |
| 436 | MSb     | Most Significant Bit                                      |
| 437 | NVMEM   | Non-Volatile Memory                                       |
| 438 | OCP     | Open Core Protocol                                        |
| 439 | OD      | Open Drain                                                |
| 440 | SCL     | Serial Clock                                              |
| 441 | SDA     | Serial Data                                               |
| 442 | SDR     | Single Data Rate                                          |
| 443 | SPI     | Serial Peripheral Interface                               |
| 444 | SRFF    | State Retention Flip-Flop                                 |
| 445 | TSL     | Ternary Symbol Legacy                                     |
| 446 | TSP     | Ternary Symbol for Pure Bus (no I <sup>2</sup> C Devices) |
| 447 | UART    | Universal Asynchronous Receiver Transmitter               |

## 3 References

### 3.1 Normative References

- 448 [MCTP01] *MCTP I3C Transport Binding Specification*, version 1.0 or newer, DMTF, In Press.
- 449 [MIPI01] MIPI Alliance, Inc., “MIPI Alliance Manufacturer ID Page”, <https://mid.mipi.org>, last  
450 accessed 9 June 2021.
- 451 [MIPI02] MIPI Alliance, Inc., “Current I3C Device Characteristic Register (DCR) Assignments”,  
452 [https://www.mipi.org/MIPI\\_I3C\\_device\\_characteristics\\_register](https://www.mipi.org/MIPI_I3C_device_characteristics_register), last accessed  
453 9 June 2021.
- 454 [MIPI04] *MIPI Alliance Specification for Debug for I3C*, version 1.0, MIPI Alliance, Inc.,  
455 21 April 2020.
- 456 [MIPI05] MIPI Alliance, Inc., “I3C Mandatory Data Byte (MDB) Assignments”,  
457 [https://www.mipi.org/MIPI\\_I3C\\_mandatory\\_data\\_byte\\_values\\_public](https://www.mipi.org/MIPI_I3C_mandatory_data_byte_values_public), last accessed  
458 9 June 2021.
- 459 [MIPI07] MIPI Alliance, Inc., “I3C SETBUSCON Table”,  
460 [https://www.mipi.org/MIPI\\_I3C\\_bus\\_context\\_byte\\_values\\_public](https://www.mipi.org/MIPI_I3C_bus_context_byte_values_public), last accessed  
461 9 June 2021.

### 3.2 Informative References

- 462 [MIPI03] *System Integrators Application Note for MIPI I3C v1.0 and I3C Basic v1.0*, App Note  
463 version 1.0, MIPI Alliance, Inc., 8 December 2018 (approved 8 December 2018).
- 464 [MIPI06] *MIPI Alliance Application Notes for MIPI I3C v1.1.1*, App Note version 1.0,  
465 MIPI Alliance, Inc., In Press.
- 466 [MIPI08] *MIPI Alliance Specification for I3C® (Improved Inter Integrated Circuit)*, version 1.1.1,  
467 MIPI Alliance, Inc., 11 June 2021.
- 468 [NXP01] UM10204, *I<sup>2</sup>C-bus specification and user manual*, Rev. 6, NXP Semiconductors N.V.,  
469 4 April 2014.
- 470 [USB01] *Universal Serial Bus 3.1 Specification*, Revision 1.0,  
471 [http://www.usb.org/developers/docs/usb\\_31\\_072715.zip](http://www.usb.org/developers/docs/usb_31_072715.zip), Hewlett-Packard Company  
et al., 26 July 2013.

This page intentionally left blank.

## 4 Technical Overview (Informative)

This Section generally describes the I3C Bus, the I3C interface, and I3C Controller and Target Devices.

I3C is a two-wire bidirectional serial Bus, optimized for multiple Target Devices (e.g., sensors) and controlled by only one I3C Controller Device at a time. I3C is backward compatible with many Legacy I<sup>2</sup>C Devices, but I3C Devices also support significantly higher speeds, new communication Modes, and new Device roles, including an ability to change Device Roles over time (i.e., the initial Controller can cooperatively pass the Controller role to another I3C Device (i.e., Secondary Controller) on the Bus, if the second I3C Device supports that feature).

I3C Basic is a subset of I3C, and is defined to be interoperable with I3C. In this I3C Basic Specification, the definition of I3C includes:

- Support for many Legacy I<sup>2</sup>C Target Devices and Messages
- **I3C Single Data Rate (SDR) Mode:** New I3C enhanced version of the I<sup>2</sup>C protocol supporting private Messages, and adding two kinds of standard built-in Messages:
  - **Broadcast Messages**, which are sent to all I3C Targets on the Bus
  - **Direct Messages**, which are addressed to specific Targets
- **I3C High Data Rate (HDR) Modes:** Additional optional Modes that add significant functionality:
  - **Dual Data Rate (HDR-DDR) Mode:** Uses same signaling as SDR Mode (i.e., is not significantly different from the I<sup>2</sup>C protocol), but runs at about 2x the speed of SDR
  - **Bulk Transport (HDR-BT) Mode:** Gives the highest possible throughput using a Clock-and-Data transmission model leveraging dual data rate over single-, dual-, or quad-Lane configurations

Readers interested in a detailed, low-level introduction to the operation of the I3C Bus for each of the defined I3C Modes are encouraged to study and compare the example waveforms shown in informative *Annex C*.

## 4.1 I3C Fundamental Principles

I3C supports several communication formats, all sharing a two-wire interface.

The two wires are designated SDA and SCL:

- **SDA** (Serial Data) is a bidirectional data pin
- **SCL** (Serial Clock) can be either a clock pin or a Bi-directional data pin while in certain HDR Modes

An I3C Bus supports the mixing of various Message types:

1. I<sup>2</sup>C-like SDR Messages, with SCL clock speeds up to 12.5 MHz
2. Broadcast and Direct Common Command Code (CCC) Messages that allow the Controller to communicate to all or one of the Targets on the I3C Bus, respectively
3. HDR Mode Messages, which achieve higher data rates per equivalent clock cycle
4. I<sup>2</sup>C Messages to Legacy I<sup>2</sup>C Targets
5. Target-initiated START Request to the Controller, for example to send an In-Band Interrupt or to request the Controller role

An example traffic pattern on the I3C Bus is shown in **Figure 6**.



**Figure 6 Example of Data Traffic on the I3C Bus**

09-Jun-2021

511 **Figure 7** illustrates how I<sup>2</sup>C communication is initiated:

- All I3C communication occurs within a Frame. The Frame begins with a START, followed by one or more transfers, and a STOP.
  - For the HDR Modes that are either supported in I3C Basic, or are tolerated by I3C Basic Devices:
    - First the dedicated Broadcast I3C Address (7'h7E) is issued to all Targets on the I3C Bus.
    - Then one of the Enter HDR CCCs is issued, indicating that the Controller is entering an HDR Mode. Each HDR Mode has its own EnterHDR CCC.
    - This is followed by one or more HDR transfers.
    - HDR Mode is ended by using the HDR Exit Pattern protocol.



**Figure 7 I3C Communication Flow**

522 I3C is based on a Frame encapsulation approach. A Frame includes a Data Payload. The transfer protocol for  
523 the Data Payload is either SDR or HDR. Frames are bordered by I<sup>2</sup>C-like Bus management.

524 The I3C Frame always includes at least the START, the Header, the Data, and the STOP.

525 The Header following a START allows for Bus Arbitration. The Controller uses the Header to address Target  
526 Device(s). I3C Target Devices(s) may use the Header Arbitration for multiple purposes: for In-Band Interrupt,  
527 for Hot-Join, and for Secondary Controller functionality.

528 Common Command Codes (CCCs) are used to enter the High Data Rate (HDR) Modes. It is important to  
529 understand that I3C Bus activity for the HDR Message does not follow the Legacy I<sup>2</sup>C format. Supported  
530 HDR protocols use the SDA line and the SCL line to transfer commands, data, and other control information,  
531 using alternate formats specified in *Section 5.2*.

532 I3C allows only one Controller to have control of the I3C Bus at a time. Mechanisms for handoff of the  
533 Controller role from one Device to another Device are provided.

## 4.2 I3C Controller and Target Devices

A given I3C Bus always has one Controller and one or more Targets. This Section generally describes I3C Controller Devices and I3C Target Devices.

A given I3C Device can be designed to function either solely as an I3C Controller, solely as an I3C Target, or with both I3C Controller and I3C Target capabilities.

An I3C Device with both I3C Controller and I3C Target capabilities cannot function as both Controller and Target at the same time, instead it must be configured either as an I3C Target Device or as an I3C Controller Device. Such an I3C Device can be initially configured (initialized) on an I3C Bus either as the Controller of that I3C Bus, or as a Target on that I3C Bus. However for that I3C Bus to function properly, only one of the multiple I3C Devices on the Bus can be initially configured (initialized) as an I3C Controller Device. That I3C Device will have the “Primary Controller” Device Role, and will be the first I3C Device on the Bus to serve as Active Controller; all other I3C Devices and Legacy I<sup>2</sup>C Devices on the I3C Bus will be initially configured (initialized) as Targets.

I3C introduces the concept of Active Controller, defined as the I3C Controller Device on the I3C Bus that is functioning as Controller (i.e., the one that is controlling the Bus) at the present time. Only one I3C Device on an I3C Bus can serve as Active Controller at a time. However after initial Bus configuration the Active Controller function can be cooperatively passed from the Active Controller to any other I3C Device on the Bus with I3C Controller Device capability, using provided I3C commands (CCCs).

I3C defines several Controller and Target Device Roles (see *Table 1* and *Table 2*) to reflect the functional capabilities of a given I3C Controller or Target Device. A given I3C Device must support at least one Device Role, and can be designed to support multiple Device Roles. Every I3C Device exposes the Device Roles it supports via its Bus Characteristics Register (BCR, see *Section 5.1.1.2.1*).

Table 1 Roles for I3C Compatible Devices

| Device Type                 | Device Role                   | Description                                                             |
|-----------------------------|-------------------------------|-------------------------------------------------------------------------|
| I3C Controller <sup>1</sup> | I3C Primary Controller        | Initially configures I3C Bus, has HDR support                           |
|                             | SDR-Only Primary Controller   | Initially configures I3C Bus, no HDR support                            |
|                             | I3C Secondary Controller      | Can control the Bus but currently functioning as Target                 |
|                             | SDR-Only Secondary Controller | Can control the Bus but currently functioning as Target, no HDR support |
| I3C Target <sup>2</sup>     | I3C Target                    | Ordinary I3C Target, no Controller capability                           |
|                             | SDR-Only Target               | Ordinary I3C Target, no Controller capability, no HDR support           |
|                             | I <sup>2</sup> C Target       | No I3C Controller or I3C Target capabilities                            |

**Note:**

- 1) Applies to Controller-only Devices. In a Multi-Controller context, a Controller Device may also implement functionality to join the Bus acting in a Target role.
- 2) Applies to Target-only Devices.

#### 4.2.1 I3C Controller Device

An I3C Bus requires there to be exactly one I3C Device at a time functioning as an I3C Controller Device. In I3C terms, this I3C Controller Device is the Active Controller at that time. In typical applications, the Active Controller is the I3C Device on the Bus that sends the majority of the I3C Commands (CCCs), addressing either all Targets (Broadcast CCCs) or specific individual Targets (Directed CCCs). The Active Controller is also the only Device on the I3C Bus allowed to send I<sup>2</sup>C Messages.

In addition to sending I3C Commands and I<sup>2</sup>C Messages, an I3C Controller Device also:

- Generates the Bus clock when in SDR Mode, HDR-DDR Mode, and HDR-BT Mode
    - I3C Targets may optionally generate the Bus clock in HDR-BT Mode, for Read transfers.
    - Note that there is no traditional clock in HDR-Ternary Modes.
  - Manages Pull-Up structures
  - Manages Dynamic Address Assignment while acting as the Active Controller.
- There are methods based on SETDASA, SETAASA, or ENTDA (including Hot-Join events).
- Manages START Requests from I3C Target Devices on the Bus along with Address Arbitration requests:
    - Generate In-Band Interrupts
    - For Hot-Join events
    - To become Active Controller
  - Supports I<sup>2</sup>C Legacy Target Devices
  - Supports I3C SDR Mode

In addition, an I3C Controller Device can optionally support any combination of I3C's defined HDR Modes.

**Figure 8** is a block diagram of a typical generic I3C Controller Device.



**Figure 8 I3C Controller Device Block Diagram**

#### 4.2.1.1 I3C Controller Device Roles

All I3C Controller Devices support one of the two Primary Controller Device Roles, and may also support one of the two Secondary Controller Device Roles.

**Primary Controller Device Roles:**

- **Primary Controller:** The I3C Controller Device on the I3C Bus that initially configures the I3C Bus and serves as the first Active Controller. Only one I3C Device on a given I3C Bus can take the Primary Controller role, i.e., the role cannot be passed on to any other I3C Device on the I3C Bus. Supports both SDR Mode and at least one HDR Mode.
- **SDR-Only Primary Controller:** A Primary Controller that only supports I3C's SDR Mode, i.e., does not support any of the HDR Modes.

**Secondary Controller Device Roles:**

- **I3C Secondary Controller:** Any I3C Device on the I3C Bus, other than the Active Controller, with I3C Controller Capability. There can be multiple Secondary Controllers on an I3C Bus at the same time. By definition, a Secondary Controller functions as an I3C Target Device until and unless it eventually becomes Active Controller. Supports both SDR Mode and at least one HDR Mode.
- **SDR-Only Secondary Controller:** A Secondary Controller that only supports I3C's SDR Mode, i.e., does not support any of the HDR Modes.

See also *Table 2* and *Table 3*.

**Note:**

*Active Controller is not formally defined as an I3C Device Role, and is not exposed in the I3C Device's Bus Characteristics Register (BCR, see **Section 5.1.1.2.1**).*

#### 4.2.2 I3C Target Device

The maximum number of Devices that an I3C Bus supports will depend on trace length, capacitive load per Device, and the types of Devices (I<sup>2</sup>C vs. I3C) present on the Bus, because these factors affect clock frequency requirements.

**Note:**

*Previous versions of the I3C Basic Specification (as well as some previous versions of the full I3C Specification) listed a maximum number of 11 I3C Target Devices. This limit was calculated based on typical electrical parameters (see **Section 6**).*

An I3C Target Device listens to the I3C Bus for relevant I3C Commands (CCCs) sent by the Active Controller and responds accordingly. This includes all Broadcast Commands (CCC), and any Directed Commands (CCC) addressed specifically to that I3C Target Device and supported by that I3C Target Device.

In addition to responding to I3C Commands, an I3C Target Device always supports I3C SDR Mode.

An I3C Target Device does not generate the Bus clock, and always follows the Bus clock generated by the Active Controller, except during:

- Read transfers in HDR-BT Mode (optional, at implementer discretion)

For addressing, an I3C Target Device supports at least one of the Dynamic Address Assignment methods: based on SETDASA, SETAASA, or ENTDAAA.

In addition, an I3C Target Device can optionally:

- Request In-Band Interrupts
- Generate Hot-Join events
- Request to become Active Controller, if the I3C Target Device also has I3C Controller Device capability (i.e., an I3C Secondary Controller Device)
- Support any combination of I3C's defined HDR Modes

While functioning as a Target, an I3C Target Device functions in one of the Target Device Roles detailed in **Section 4.2.2.1**.

**Figure 9** is a block diagram of a typical generic I3C Target Device.



624

625

**Figure 9 I3C Target Device Block Diagram**

#### 4.2.2.1 I3C Target Device Roles

626 All I3C Target Devices support one of the two I3C Target Device Roles:

- 627 • **I3C Target:** An ordinary I3C Target Device without Controller capability. Supports both SDR  
628 Mode and at least one HDR Mode.
- 629 • **SDR-Only I3C Target:** An I3C Target without Controller capability that only supports I3C's SDR  
630 Mode (i.e., does not support any of the HDR Modes).

631 **Note:**

632     *An additional Target Device Role is defined for I<sup>2</sup>C Target, however this is not relevant for an I3C*  
633     *Target Device.*

634 See also **Table 1** and **Table 2**.

This page intentionally left blank.

## 5 I3C Protocol

This Section specifies the communication protocols for all defined I3C Modes:

- **Single Data Rate (SDR) Mode:** See *Section 5.1*
- **High Data Rate (HDR) Modes:** See *Section 5.2*
  - NOT INCLUDED IN I3C BASIC: HDR Ternary Symbol Pure-bus (HDR-TSP) Mode: See *Section 5.2.3*
  - NOT INCLUDED IN I3C BASIC: HDR Ternary Symbol Legacy-inclusive-bus (HDR-TSL) Mode: See *Section 5.2.3*
  - HDR Double Data Rate (HDR-DDR) Mode: See *Section 5.2.2*
  - HDR Bulk Transport Mode: See *Section 5.2.4*

It is important to note that the I3C Bus is always initialized and configured in SDR Mode, never in any of the HDR Modes. (The procedure for entering an HDR Mode from SDR Mode is detailed in *Section 5.2.1*.)

As a result, most of the essential basic I3C protocol specifications are found in *Section 5.1*, including:

| Subject                                                | Section       |
|--------------------------------------------------------|---------------|
| Bus Configuration                                      | <b>5.1.1</b>  |
| Bus Communication                                      | <b>5.1.2</b>  |
| Bus Conditions                                         | <b>5.1.3</b>  |
| Bus Initialization and Dynamic Address Assignment Mode | <b>5.1.4</b>  |
| Hot-Join Mechanism                                     | <b>5.1.5</b>  |
| In-Band Interrupt                                      | <b>5.1.6</b>  |
| I3C Bus with Multiple Controllers                      | <b>5.1.7</b>  |
| Timing Control                                         | <b>5.1.8</b>  |
| Common Command Codes (CCC)                             | <b>5.1.9</b>  |
| Error Detection and Recovery Methods for SDR           | <b>5.1.10</b> |
| Target Reset                                           | <b>5.1.11</b> |

This page intentionally left blank.

## 5.1 Single Data Rate (SDR) Mode

This Section specifies the communication protocols for Single Data Rate (SDR) Mode.

SDR Mode is the default Mode of the I3C Bus. SDR Mode is also used to enter other Modes, sub-Modes, and states (as described in **Section 5.1** and **Section 5.2**); and for built-in features such as Common Commands (CCCs), In-Band Interrupts, and transition from I<sup>2</sup>C to I3C by assignment of a Dynamic Address.

I3C SDR Mode is significantly similar to the I<sup>2</sup>C protocol **[NXP01]** in terms of procedures and conditions, and as a result I3C Devices and many Legacy I<sup>2</sup>C Target Devices (but not Legacy I<sup>2</sup>C Controller Devices) can coexist on the same I3C Bus. However, SDR Mode also includes numerous new features not present in I<sup>2</sup>C. For the procedures and conditions that I3C shares with I<sup>2</sup>C, SDR Mode closely follows the definitions in the I<sup>2</sup>C Specification. I<sup>2</sup>C traffic from an I3C Controller to an I<sup>2</sup>C Target will be properly ignored by all I3C Targets, because the I3C protocol is designed to allow I<sup>2</sup>C traffic. I3C traffic from an I3C Controller to an I3C Target will not be seen by most Legacy I<sup>2</sup>C Target Devices, because the I<sup>2</sup>C Spike Filter is opaque to I3C's higher clock speed.

### 5.1.1 Bus Configuration

The I3C Bus can be configured as the link among several clients, in a flexible and efficient manner. At the system architecture level, seven roles are defined for I3C compatible Devices (see *Table 1*).

An example block diagram of I3C interconnections is shown in *Figure 10*. In this figure the color blue indicates Devices with a Controller role, the color pink indicates Devices with an I3C Target role, and the color purple indicates Devices with an I<sup>2</sup>C Target role.

**Note:**

I3C Secondary Controller Devices have the ability to function in either Controller or Target roles at different times, using the same Dynamic Address. In *Figure 10*, the I3C Primary Controller is the Active Controller of the Bus, so the I3C Secondary Controller acts as a Target (i.e., its Controller capability is not active).

I3C Devices may also present multiple simultaneous roles. In *Figure 10*, a typical I3C composite Device is shown that presents multiple Virtual Targets on the I3C Bus, where each Virtual Target has a separate Dynamic Address. Such a composite I3C Device uses shared Peripheral logic to handle transfers for its Virtual Targets, which are active simultaneously, per *Section 5.1.2.1.2*. Other types of composite I3C Devices are possible, and might include support for other roles (i.e., Secondary Controller).

I3C Devices may also enable connections to other buses, either as a Bridge Device (i.e., to a different bus such as I<sup>2</sup>C or SPI) or as a Routing Device (to another I3C Bus). Such Devices might present one or more Virtual Targets on this I3C Bus that may be used to communicate through the Bridge Device or Routing Device.



**Figure 10 I3C Bus with I<sup>2</sup>C Devices and I3C Devices**

681 **Figure 11** shows another example block diagram, with an I3C Minimal Bus use case for simple point-to-point  
 682 communications. In this use case a single Controller assigns the same Dynamic Address to one or more  
 683 I3C Target Devices, only one of which supports Read transactions and In-Band Interrupts.



**Figure 11 I3C Minimal Bus with I3C Target Devices**

684 I3C compatible Devices may have diverse features, as appropriate for their function within the I3C Bus.  
 685 Depending on the I3C Bus's system design, it may not be necessary for all features of a given Device to be  
 686 enabled for any particular Bus instantiation. However, the enabled features of every I3C compatible Device  
 687 shall be described in Characteristics Registers associated with the Device and its Roles, as described in  
 688 **Section 5.1.1.2**. The I3C Primary Controller shall obtain the Characteristics of any Legacy I<sup>2</sup>C Devices on  
 689 the I3C Bus before power-up (e.g., the fixed Address of each Legacy I<sup>2</sup>C Device present on the Bus).

690 At every start-up from a powered-down state, the Primary Controller shall assign a unique Dynamic Address  
 691 to every Device presenting an active Role on the Bus, including itself. The Dynamic Address assignment  
 692 procedure is described in **Section 5.1.4**. Dynamic Addresses create a priority ranking of In-Band Interrupts.  
 693 Any Secondary Controllers present on the I3C Bus shall be made aware of the Dynamic Address assignments  
 694 and Characteristic Registers associated with each I3C compatible Device on the Bus via Common Command  
 695 Codes as described in **Section 5.1.9**.

### 5.1.1.1 I3C Device Characteristics

696 The configuration of an I3C Bus will depend upon the Characteristics of the I3C Devices intended to be  
 697 active on that I3C Bus. Therefore, an active I3C Device playing a given Role in a given I3C Bus instantiation  
 698 shall fulfill all responsibilities for that Role, as detailed in **Table 2**.

**Table 2 I3C Devices Roles vs Responsibilities**

| Responsibilities / Features                              | Comments                                                                              | Roles              |                       |                             |                               |          |                 |
|----------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------|-----------------------|-----------------------------|-------------------------------|----------|-----------------|
|                                                          |                                                                                       | Primary Controller | Secondary Controller  | SDR-Only Primary Controller | SDR-Only Secondary Controller | Target   | SDR-Only Target |
| <b>Manages SDA Arbitration</b>                           | For Address Arbitration, In-Band Interrupt, Hot-Join, Dynamic Address, as appropriate | Y                  | Y                     | Y                           | Y                             | N        | N               |
| <b>Dynamic Address Assignment</b>                        | Controller assigns Dynamic Address                                                    | Y                  | Optional <sup>3</sup> | Y                           | Optional <sup>3</sup>         | N        | N               |
| <b>Hot-Join Dynamic Address Assignment</b>               | Controller capable of Dynamic Address assignment after Hot-Join                       | Y                  | Optional <sup>3</sup> | Y                           | Optional <sup>3</sup>         | N        | N               |
| <b>Self Dynamic Address Assignment</b>                   | Only Primary Controller can self-assign a Dynamic Address                             | Y                  | N                     | Y                           | N                             | N        | N               |
| <b>Static I<sup>2</sup>C Address<sup>1</sup></b>         | –                                                                                     | N/A                | Optional              | N/A                         | Optional                      | Optional | Optional        |
| <b>Memory for Targets' Addresses and Characteristics</b> | Retaining registers                                                                   | Y                  | Y                     | Y                           | Y                             | N        | N               |
| <b>HDR Target capable</b>                                | Supports being accessed in at least one HDR Mode                                      | Y                  | Y                     | N                           | N                             | Y        | N               |
| <b>HDR Controller capable</b>                            | Supports Bus control in at least one HDR Mode                                         | Y                  | Y                     | N                           | N                             | N/A      | N/A             |
| <b>HDR Exit Pattern Generation capable<sup>2</sup></b>   | Able to generate the HDR Exit Pattern on the Bus for error recovery                   | Y                  | Y                     | Y                           | Y                             | N        | N               |
| <b>HDR Tolerant</b>                                      | Recognizes HDR Exit Pattern                                                           | Y                  | Y                     | Y                           | Y                             | Y        | Y               |

**Note:**

- 1) A Static Address may be used to more quickly assign a Dynamic Address. See **Section 5.1.4**.
- 2) All Targets require an HDR Exit Pattern Detector, even Targets that are not HDR capable.
- 3) A Secondary Controller may assign a Dynamic Address using the ENTDAA CCC while it is the Active Controller (i.e., when it holds the Controller Role, per **Section 5.1.7.3.3**). Some Secondary Controllers might have limited capabilities or reduced functionality while acting as the Active Controller of the I3C Bus. See **Section 5.1.7.3.4** and **Section 5.1.7.3.6**. However, only the Primary Controller may assign Dynamic Addresses using the SETDASA and/or SETAASA CCCs (i.e., during Bus Initialization), per **Section 5.1.4.2**.

The I3C protocol supports a subset of I<sup>2</sup>C Target features. For example, an I3C Target can have a Static Address but also support Dynamic Addressing. A Device shall not have a 50 ns Spike Filter enabled when used in an I3C Bus operating at full clock speed. These differences are summarized in **Table 3**. When used in an I3C system, I3C Targets shall enable or disable appropriate I<sup>2</sup>C features as shown in **Table 3**.

**Table 3 I<sup>2</sup>C Features Allowed in I3C Targets**

| I <sup>2</sup> C Feature When Used on an I3C Bus | Required on I3C | Desirable on I3C | Not Used on I3C | Not Allowed on I3C   | Note    |
|--------------------------------------------------|-----------------|------------------|-----------------|----------------------|---------|
| Fm/Fm+ Speed                                     | X               | —                | —               | —                    | 2, 3, 4 |
| HS Speed                                         | —               | —                | X               | —                    | 3       |
| UFm Speed                                        | —               | —                | X               | —                    | 3       |
| Static I <sup>2</sup> C Address                  | —               | X                | —               | —                    | —       |
| 50 ns Spike Filter                               | —               | —                | X               | X<br>(Shall disable) | 3       |
| Clock Stretch                                    | —               | —                | —               | X                    | —       |
| 20 mA Open Drain Driver                          | —               | —                | X               | —                    | 1, 3    |
| Matches I <sup>2</sup> C AC Timing               | —               | —                | X               | —                    | 2, 3    |
| I <sup>2</sup> C Extended Address (10 bit)       | —               | —                | X               | —                    | 3       |
| I3C Reserved Addresses                           | —               | —                | —               | X                    | —       |

**Note:**

- 1) See **Table 82** and **Table 85**
- 2) I3C drive and timing requirements are different from I<sup>2</sup>C.
- 3) If an I3C Target has I<sup>2</sup>C features intended for use on an I<sup>2</sup>C Bus, then they will not be used on an I3C Bus. As stated in **Section 5.1.1.1**, once the Target sees a 7'h7E, it will disable I<sup>2</sup>C features that are not used by I3C.
- 4) For a Mixed Bus, timing requirements when communicating with I<sup>2</sup>C-only Devices may depend on the maximum SCL clock frequency supported by such I<sup>2</sup>C-only Devices. See **Table 84** and **Table 85**.

Performance of an I3C Bus is heavily dependent upon any I<sup>2</sup>C-only Devices that may be connected to that Bus. Consequently, all I<sup>2</sup>C-only Devices permitted on any instantiation of an I3C Bus must be compliant with one of the categories detailed in **Table 4**. Furthermore (and as referenced in **Table 84**), no I<sup>2</sup>C or I3C Device present on an I3C Bus shall have an I<sup>2</sup>C Static Address that matches any of the Addresses associated with Error Type TE0 (see **Table 59**).

**Table 4 Legacy I<sup>2</sup>C-Only Target Categories and Characteristics**

| Index Specific                                              | I <sup>2</sup> C-Only Devices Index 0 | I <sup>2</sup> C-Only Devices Index 1 | I <sup>2</sup> C-Only Devices Index 2 |
|-------------------------------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|
| 50 ns IO Spike Filter <sup>1</sup>                          | Y                                     | N                                     | N                                     |
| Max SCL clock frequency ( $f_{SCL}$ ) tolerant <sup>2</sup> | N/A                                   | Y                                     | N                                     |

**Note:**

- 1) Allows tolerance of HDR Modes and SDR at SCL High periods of  $t_{DIG\_H\_MIXED}$  or less
- 2) Allows compliance up to maximum SDR SCL clock frequency ( $f_{SCL}$ )

### 5.1.1.2 I3C Characteristics Registers

I3C Characteristics Registers describe and define an I3C compatible Device's capabilities and functions on the I3C Bus, as the Device services a given system. Devices without I3C Characteristics Registers shall not be connected to a common I3C Bus.

There are three Characteristics Register types:

- **Bus Characteristics Register** (BCR, see *Section 5.1.1.2.1*)
- **Device Characteristics Register** (DCR, see *Section 5.1.1.2.2*)
- **Legacy Virtual Register** (LVR, see *Section 5.1.1.2.3*)

Every I3C compatible Device shall have associated Characteristics Registers, depending on the Device type:

- Every I3C compliant Device (as defined in *Table 2*) that holds one active role shall have one Bus Characteristics Register, and one Device Characteristics Register; these are associated with the Dynamic Address.
- I3C compliant Devices that hold multiple active roles might use a single shared Bus Characteristics Register and Device Characteristics Register that applies to all such active roles; or one pair of such registers for each active role, associated with each role's Dynamic Address.
  - Composite I3C Devices that present multiple Virtual Targets should usually have separate Bus Characteristics Registers and Device Characteristics Registers, i.e., one set for each Virtual Target, associated with its Dynamic Address.
- Every Legacy I<sup>2</sup>C Device to be connected to an I3C Bus shall have one associated Legacy Virtual Register. Since these are Legacy Devices, it is understood that this register will exist virtually, for example as part of the Device's driver.

### 5.1.1.2.1 Bus Characteristics Register (BCR)

Each I3C Device that is connected to the I3C Bus shall have an associated read-only Bus Characteristics Register (BCR). This read-only register describes the I3C compliant Device's role and capabilities for use in Dynamic Address assignment and Common Command Codes. The bits within the BCR shall conform to the Descriptions presented in in **Table 5**.

**Table 5 Bus Characteristics Register (BCR)**

| Bit    | Name                      | Description                                                                                                                                                                                                                                                                                                                                                             | Notes |
|--------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| BCR[7] | Device Role[1]            | 2'b00: I3C Target<br>2'b01: I3C Controller capable<br>2'b10: Reserved for future definition by MIPI Alliance I3C WG<br>2'b11: Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                    | 1     |
| BCR[6] | Device Role[0]            | 2'b11: Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                           |       |
| BCR[5] | Advanced Capabilities     | 1: Supports optional advanced capabilities.<br>Use GETCAPS CCC ( <b>Section 5.1.9.3.19</b> ) to determine which ones.<br>0: Does not support optional advanced capabilities                                                                                                                                                                                             | 2     |
| BCR[4] | Virtual Target Support    | 0: Is not a Virtual Target and does not expose other downstream Device(s)<br>1: Is a Virtual Target, or exposes other downstream Device(s)                                                                                                                                                                                                                              | 3     |
| BCR[3] | Offline Capable           | 0: Device will always respond to I3C Bus commands<br>1: Device will not always respond to I3C Bus commands                                                                                                                                                                                                                                                              | 4     |
| BCR[2] | IBI Payload               | 0: No data bytes follow the accepted IBI<br>1: One data byte (MDB) shall follow the accepted IBI, and additional data bytes may follow; see also the Set/Get Maximum Read Length CCC ( <b>Section 5.1.9.3.6</b> ). Data byte continuation is indicated by T-Bit per <b>Section 5.1.2.3.4</b> . See also <b>Section 5.1.8</b> on use of IBI Payloads for Timing Control. | –     |
| BCR[1] | IBI Request Capable       | 0: Not Capable<br>1: Capable                                                                                                                                                                                                                                                                                                                                            | –     |
| BCR[0] | Max Data Speed Limitation | 0: No Limitation<br>1: Limitation                                                                                                                                                                                                                                                                                                                                       | 5     |

**Note:**

- 1) The BCR Device Role bits for any I3C Device capable of acting as I3C Controller (either Primary Controller or Secondary Controller) are 2'b01. The Primary Controller identifies itself to the Targets with the DEFTGTS CCC (**Section 5.1.9.3.7**); its Static Address is the value 7'h7E.
- 2) In I3C v1.0, bit BCR[5] only indicated HDR support, and that the Controller should use the GETHDRCAPS CCC to determine what HDR Modes were supported. In I3C v1.1 and above, bit BCR[5] now indicates that the Controller should use the same CCC (now renamed GETCAPS) to determine what advanced features the I3C Device supports, including (but no longer limited to) HDR. Note that the I3C v1.0 method is fully interoperable with the I3C v1.1 and above method.
- 3) In I3C v1.0, bit BCR[4] only indicated Bridge Devices required to comply with the I3C Specification. In I3C v1.1 and above, bit BCR[4] now indicates that the Device is a Virtual Target or exposes other downstream Devices, and that the Controller should use the GETCAPS CCC with Defining Byte VTCAPS (**Section 5.1.9.3.19**) to determine what features and capabilities the I3C Device supports, including (but no longer limited to) Bridge Devices.
- 4) Offline Capable Devices retain the Dynamic Address, and are specified in **Section 2.2**.
- 5) Controller shall use the GETMXDS CCC to interrogate the Target for specific limitation.

### 5.1.1.2.2 Device Characteristics Register (DCR)

Each I3C Device that is connected to the I3C Bus shall have an associated read-only Device Characteristics Register (DCR). This read-only register describes the I3C compliant Device type (e.g., accelerometer, gyroscope, etc.) for use in Dynamic Address Assignment and Common Command Codes. The bits within the DCR shall conform to the Descriptions presented in *Table 6*.

MIPI Alliance maintains a public registry of approved and pending DCR value assignments [*MIPI02*].

**Table 6 I3C Device Characteristics Register (DCR)**

| Bit           | Name                | Description                                                       |
|---------------|---------------------|-------------------------------------------------------------------|
| <b>DCR[7]</b> | <b>Device ID[7]</b> | 255 available codes for describing the type of sensor, or Device. |
| <b>DCR[6]</b> | <b>Device ID[6]</b> | Examples: Accelerometer, gyroscope, composite Devices.            |
| <b>DCR[5]</b> | <b>Device ID[5]</b> |                                                                   |
| <b>DCR[4]</b> | <b>Device ID[4]</b> | Default value is 8'b0: Generic Device                             |
| <b>DCR[3]</b> | <b>Device ID[3]</b> |                                                                   |
| <b>DCR[2]</b> | <b>Device ID[2]</b> |                                                                   |
| <b>DCR[1]</b> | <b>Device ID[1]</b> |                                                                   |
| <b>DCR[0]</b> | <b>Device ID[0]</b> |                                                                   |

### 5.1.1.2.3 Legacy Virtual Register (LVR)

Each Legacy I<sup>2</sup>C Device that can be connected to the I3C Bus shall have an associated read-only Legacy Virtual Register (LVR) describing the Device's significant features. Since these are Legacy I<sup>2</sup>C Devices, it is understood that this register will exist virtually, for example as part of the Device's driver. When Legacy I<sup>2</sup>C Devices are present on an I3C Bus, LVR data determines allowed Modes and maximum SCL clock frequency. The bits within the LVR shall conform to the descriptions in *Table 7*.

All LVRs shall be established by the higher-level entity controlling the I3C Bus, and shall be transferred to the I3C Bus Primary Controller prior to Bus configuration. The LVR content for all I<sup>2</sup>C Devices is always known by the Primary Controller. The Primary Controller shall transfer the LVR content for all I<sup>2</sup>C Devices to Secondary Controllers by using the DEFTGTS CCC (see *Section 5.1.9.3.7*).

**Table 7 Legacy I<sup>2</sup>C Virtual Register (LVR)**

| Bits            | Name                                                | Values                                                                                                                                                                                                                                                                     |
|-----------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>LVR[7:5]</b> | <b>Legacy I<sup>2</sup>C-Only [2:0] per Table 4</b> | <b>3'b000:</b> Index 0: Spike Filter, Max SCL clock freq tolerant N/A<br><b>3'b001:</b> Index 1: No Spike Filter, Max SCL clock freq tolerant<br><b>3'b010:</b> Index 2: No Spike Filter, Not Max SCL clock freq tolerant<br><b>3'b011 – 3'b111:</b> Index 3 – 7: Reserved |
| <b>LVR[4]</b>   | <b>I<sup>2</sup>C Mode Indicator</b>                | <b>0:</b> I <sup>2</sup> C Fm+<br><b>1:</b> I <sup>2</sup> C Fm                                                                                                                                                                                                            |
| <b>LVR[3:0]</b> | <b>MIPI Alliance I3C WG Reserved</b>                | <b>0:</b> Reserved<br><b>1 – 15:</b> 15 available codes for describing the Device capabilities and function on the sensors' system.                                                                                                                                        |

### 5.1.2 Bus Communication

The primary protocol and Mode of I3C is SDR (Single Data Rate) Mode. The SDR protocol is based on the I<sup>2</sup>C standard protocol [*NXP01*], with a few notable variations:

- The I3C START and STOP (as shown in *Figure 147* and *Figure 150*, respectively) are identical to the I<sup>2</sup>C START and STOP in their signaling, but they may vary from I<sup>2</sup>C in their timing. Compare *Table 86* vs. *Table 85*.

**Note:**

*In I3C SDR (but not HDR), a STOP or Repeated START is tolerated (i.e., may appear) any time that SCL is High while the Controller controls SDA or SDA is Open-Drain. This is unlike I<sup>2</sup>C, which wants STOP or Repeated START only after a NACK of an address, or after ACK/NACK of data. Although I3C SDR also prefers STOP and Repeated START to be used only in those situations, and after an I3C Broadcast Address is ACKed, it does not disallow them in any other location. However, appearance of a STOP or Repeated START in the middle of an Address or in the middle of data is interpreted to cancel that Address or data.*

- The I3C Address Header is identical to the I<sup>2</sup>C Address Header in bit form and in signaling, but it may vary from I<sup>2</sup>C in its timing. See *Section 5.1.2.2*, *Table 86*, and *Table 87*.
- The Data 9-bit Words use the same bit count as I<sup>2</sup>C, but differ in the ninth bit, as explained in *Section 5.1.2.3*.
- In I3C, the SCL line is only driven by the Controller. Normally this drive is Push-Pull, but it can also be Open Drain.

Because the bit count is the same for Address Header and Data Word, the I3C Target only needs to know whether a Message is an I3C Messages (vs. is an I<sup>2</sup>C Message) if the Message is addressed to that Target (either directly or by Broadcast).

An I3C Message is defined as everything from the initial START (or Repeated START) to the next Repeated START or STOP.

An I3C Message is an SDR Message if:

- The Address in the Address Header is 7'h7E (the I3C Broadcast Address). All I3C Targets shall match Address value 7'h7E. No I<sup>2</sup>C Target will match Address 7'h7E, because that value is reserved and unused in I<sup>2</sup>C.
- The Address in the Address Header matches the Target's Dynamic Address (as assigned by the I3C Controller per *Section 5.1.4*). All I3C Targets shall match their own Dynamic Address. (It is permitted to then NACK the Header if needed.)

All I3C Targets shall ignore all Messages with Addresses other than 7'h7E or the I3C Controller Assigned Address, and shall await either the Repeated START or the STOP. I3C Targets shall not transmit on the Bus in response to a non-matching Address.

**Note:**

*Legacy I<sup>2</sup>C Targets will ignore any Message not addressed to them, and will await the next START or STOP. Per Section 5.1.2.4, Legacy I<sup>2</sup>C Targets may also not see some or all of I3C Messages and Modes due to the speed of SCL signaling.*

**Figure 12 Address Header Comparison**

792

793

### 5.1.2.1 Role of I3C Target

An I3C Target is a functional role that is embodied or presented by an I3C Device. Such a Device may be a standalone physical Device that presents only one Target, or it may be a composite Device that presents multiple Virtual Targets using shared Peripheral logic. In either case, each Target (which may be a Virtual Target) presented on the I3C Bus may be assigned its own unique Dynamic Address, and the Controller can address it independently for transfers.

**Note:**

*Many such I3C Device implementations are possible that might embody or present one or more active I3C Target roles. For composite I3C Devices that present multiple Virtual Targets, the shared Peripheral logic might handle many of the underlying functions that would normally be handled by internal logic for a single, standalone I3C Device that only presented a single Target on the I3C Bus. For simplicity, the remainder of this section treats both options equally, referring to "Target" in a generic sense. See **Section 5.1.2.1.2** for special exceptions.*

The I3C Target does not have to know whether it is on a Legacy I<sup>2</sup>C Bus or an I3C Bus. If it has an I<sup>2</sup>C Static Address, then it may participate using that Address (per **Section 5.1.2.1.1**) up until it is assigned a Dynamic Address. Once assigned a Dynamic Address, unless asked to Reset, it shall only operate as an I3C Target.

An I3C Capable Target may act as an I<sup>2</sup>C Device before it gets its Dynamic Address (DA) assigned. However, the Target shall ACK the START with Address 7'h7E. (The only exception would be if the Target is choosing to remain an I<sup>2</sup>C-only Device on a given Bus or use, in which case it would leave its 50 ns Spike Filter enabled.)

#### Before Receiving a Dynamic Address

Targets that do recognize START and the 7'h7E Address may see any CCC, not just ENTDAA (see **Section 5.1.9.3.4**), and shall behave as follows:

- The Target shall appropriately process all required Broadcast CCCs, including ENTDAA, RSTDAA (see **Section 5.1.9.3.3**), ENEC (see **Section 5.1.9.3.1**), and DISEC (see **Section 5.1.9.3.1**).

Examples of appropriate processing:

- RSTDAA has no effect, since no Dynamic Address is assigned
- For a Target Device intended to be used on I3C Buses that only use SETAASA and/or SETDASA to assign a Dynamic Address to it, ENTDAA support is optional.
- If the Target would never issue a Controller Role Request, then the DISEC CCC for the Controller Role Request can be ignored.
- The Target shall recognize the CCCs ENTHDR0 through ENTHDR7 (see **Section 5.1.9.3.9**), and then wait for the HDR Exit Pattern.
- The Target may choose to understand and process the SETDASA CCC (see **Section 5.1.9.3.10**) when its Static Address matches.
- The Target may choose to understand and process the SETAASA CCC (see **Section 5.1.9.3.23**).
- The Target shall disregard all Directed CCC commands, but shall properly recognize the ends of Directed CCCs (i.e., either Repeated START followed by 7'h7E, or STOP).
- When no Dynamic Address has been assigned yet, the Target may either support or ignore non-Required and Conditionally Required Broadcast CCCs.

This is true even if the Target supports any of these CCCs after being assigned a Dynamic Address. For example, the Target may choose to only support Test Mode only when no Dynamic Address is assigned.

- The I3C Target shall ignore TE0 type errors related to incorrect Addresses only (see **Table 59**).

**838 Address Header Matching**

839 The role of an I3C Target shall be as follows:

- 840 1. Following a START or a Repeated START, at any speed conforming to **Section 6** of this  
841 Specification, the I3C Target shall attempt to match the Address to the I3C Broadcast Address  
842 (7'h7E) or to its own Dynamic Address, once assigned.

843 If the Target also supports Group Address capabilities (per **Section 5.1.4.4**), then it shall also  
844 attempt to match the Address to any of its assigned Group Addresses.

845 If any match is found, then the I3C Target shall treat that Message as I3C SDR.

- 846 2. If the Message is addressed to the Target's Dynamic Address, then the Target may ACK or  
847 passively NACK the Address Header:

- 848 a. If the Target ACKs the Address Header, then the Target shall process the Message as I3C  
849 SDR, following all rules as outlined in this Section.  
850 b. If the Target NACKs the Address Header (does not drive the ACK bit Low), then the Target  
851 should disregard any bits that follow, up until the next Repeated START or STOP.

- 852 3. If the Message is addressed to any of the Target's assigned Group Addresses, with a Write (RnW  
853 bit is 0), then the Target may ACK or passively NACK the Address Header:

- 854 a. If the Target ACKs the Address Header, then the Target shall process the Message as  
855 described above (i.e., in the same manner as an I3C SDR Write to its Dynamic Address).

- 856 4. If the Message is addressed to the I3C Broadcast Address (7'h7E), with a Write (RnW bit is 0),  
857 then the Target shall process that Message at least through the first byte of data (if any data is  
858 present in the Message):

- 859 a. If there is a byte of data in a 7'h7E Broadcast Message, then the Message is a CCC (Common  
860 Command Code) Command, per **Section 5.1.9**.  
861 b. The I3C Target shall process all applicable Required CCC commands, per **Section 5.1.9.3**. A  
862 command may be either Always Required, or only Conditionally Required, per **Table 16**.

863 **For Required CCCs:** The Target shall always remain ready to respond to certain Direct  
864 CCCs sent to its Dynamic Address, such as **Get Device Status** (GETSTATUS, see  
865 **Section 5.1.9.3.15**) even if the Target (or its inner system) is processing previously sent  
866 Messages, and might not be able to process or ACK other CCCs or Messages (see  
867 **Section 5.1.10.2.5**).

- 868 c. If the CCC command changes the Mode of the I3C Bus, then the I3C Target shall handle the  
869 new Mode in one of two ways.

870 **Either:**

- 871 i. If the new Mode is Dynamic Address Assignment Mode (see **Section 5.1.4**), and required  
872 for all I3C Targets, then the Target shall participate if it does not have a current Dynamic  
873 Address; otherwise, the Target shall await the STOP that indicates exit from Dynamic  
874 Address Assignment Mode.

875 **Or:**

- 876 ii. If the new Mode is HDR (High Data Rate) Mode, then the Target may either enter into  
877 HDR Mode if supported (per **Section 5.2.1.3.1**), or else enable its HDR Exit Pattern  
878 detector (per **Section 5.2.1** and **Section 5.2.1.1.3**) to await the exit from HDR Mode.

- 879 5. If the Message is not addressed to the I3C Broadcast Address (7'h7E) or to any of the Target's  
880 currently assigned Addresses (i.e., Dynamic Address or Group Address), then the I3C Target shall  
881 await either a Repeated START or a STOP. The Target may record/monitor the bits as they pass (if  
882 desired), but the only obligation is to wait for either a Repeated START or a STOP:

883 **Note:**

884 *Repeated START and STOP are specified in **Section 2.2** and **Section 6.2**, and are similar to I<sup>2</sup>C.  
885 In both cases, I3C timing may or may not be the same as with I<sup>2</sup>C.*

### 5.1.2.1.1 Role of I3C Target Acting as an I<sup>2</sup>C Target with Static Address

886 As noted in other Sections, I3C Targets are capable of acting as standard I<sup>2</sup>C Targets as long as they have an  
887 I<sup>2</sup>C Static Address.

888 There are two situations:

- 889 1. They are on a Legacy I<sup>2</sup>C Bus, and so all messaging is coming from a Legacy I<sup>2</sup>C Controller.  
890 2. They are on an I3C Bus, but the I3C Controller is not assigning them a Dynamic Address, so they  
891 continue to operate as an I<sup>2</sup>C Target; Messages to/from its I<sup>2</sup>C Static Address use the I<sup>2</sup>C protocol.

892 For operation on an I<sup>2</sup>C Bus, the Target may use an I<sup>2</sup>C Fm/Fm+ Spike Filter of 50 ns (or more) if it has one.

893 For operation on an I3C Bus, the Target may have an I<sup>2</sup>C Fm/Fm+ Spike Filter of 50 ns (or more), which it  
894 shall disable once it sees a Message from an I3C Controller, notably the first I3C Address Header after Bus  
895 initialization (i.e., a START followed by 7'h7E and a RnW bit of 0; see **Section 5.1.2.2**). To support the  
896 disabling of the Spike Filter, the I3C Controller shall emit at least the first such I3C Address Header with  
897 Open Drain timing parameters (per **Table 86**) such that the High and Low periods are long enough to be seen  
898 with the Spike Filter enabled (see **Section 5.1.2.2.2**).

899 **Note:**

900 *If the Target has such a Spike Filter enabled, and sees the Controller send such an I3C Address  
901 Header with Open Drain timing parameters, then it shall disable the Spike Filter after the ACK (i.e.,  
902 after acknowledging the I3C Broadcast Address).*

903 An I3C Target acting as an I<sup>2</sup>C Target will operate correctly on an I3C Bus with the Spike Filter disabled, or  
904 without ever having a Spike Filter, because of two strict requirements on all conforming I3C Targets:

- 905 1. An I3C Target shall recognize all required Broadcast CCCs and act appropriately for each one,  
906 even if the Target has not yet received a Dynamic Address. This notably includes the ENTHDRn  
907 CCCs (see **Section 5.1.9.2** and **Table 16**).  
908 2. An I3C Target shall recognize the HDR Exit Pattern (see **Section 5.2.1.1.1**).

909 As a result of these two requirements, it is safe for an I3C Target acting as an I<sup>2</sup>C Target to see the short SCL  
910 High periods (unlike a Legacy I<sup>2</sup>C Device). As a result, it can operate correctly as an I<sup>2</sup>C Target on an I3C  
911 Bus without a Spike Filter (unlike Legacy I<sup>2</sup>C Targets).

### 5.1.2.1.2 Composite Devices and Virtual Targets

As noted above, a Virtual Target is presented by an I3C Device that also presents other such Virtual Targets on the I3C Bus, and must manage the communications for all such Virtual Targets. In this manner, a Virtual Target can be considered a function of such a composite I3C Device that holds multiple active Target roles simultaneously. The I3C Device shall maintain separate configuration for each Virtual Target, including the assigned Dynamic Address.

During Dynamic Address Assignment (see **Section 5.1.4.2**) the shared Peripheral logic manages the interaction with the I3C Controller and other I3C Targets on the Bus, for the ENTDAA procedure. This includes managing Address Arbitration while providing the 48-bit Provisioned ID, and ensuring that all active Virtual Targets are able to receive Dynamic Addresses. The shared Peripheral logic also initiates the Hot-Join Request (per **Section 5.1.5**) during Bus Initialization or whenever necessary.

**Note:**

*A Device that presents multiple Virtual Targets might also support the SETDASA and/or SETAASA CCCs, instead of the ENTDAA CCC. If so, then each Virtual Target must have a unique Static Address.*

Once Dynamic Addresses are assigned, the shared Peripheral logic typically handles many of the underlying communications with the I3C Bus in SDR Mode, while each Virtual Target receives data for Private Write transfers addressed to its Dynamic Address, and also provides data to the shared Peripheral logic for responding to Private Read transfers and raising In-Band Interrupt requests.

The shared Peripheral logic also handles the signaling and framing for HDR Modes (if supported, per **Section 5.2.1**) as well as participation in Broadcast and Direct CCC flows, both in SDR Mode (per **Section 5.1.9.1**) as well as any HDR Modes in which CCCs might be supported (per **Section 5.2.1.2**).

The shared Peripheral logic also handles the reset flows involving the RSTACT CCC with the Target Reset Pattern (see **Section 5.1.11**), and generates appropriate internal reset messaging to Virtual Target functions based on the type of reset. In most cases, a Device that reports as Virtual Target capable should indicate this via Bit[4] of the BCR (per **Section 5.1.1.2.1**) and also report additional capabilities using the GETCAPS CCC with Defining Byte VTCAPS (see **Section 5.1.9.3.19**).

Depending on the implementation, certain actions or CCCs sent to one Virtual Target's Dynamic Address may cause side effects for other Virtual Targets presented by the same composite Device, or within the shared Peripheral logic itself. In some cases, certain features and capabilities that are reported by Virtual Target's Dynamic Address (e.g., by the GETCAPS CCC) shall actually apply equally to the entire Device (i.e., to all Virtual Targets and the shared Peripheral logic).

### 5.1.2.1.3 Targets Supporting Group Addresses

If a Target supports Group Addressing (per *Section 5.1.4.4*), then it will typically have a single set of capabilities or other configurable parameters that pertain to either the Target, or, in special cases, the Device or its Peripheral logic.

- If such capabilities are accessible via a Direct GET CCC (e.g., the GETCAPS CCC, *Section 5.1.9.3.19*), then these shall be assumed to apply to the Target and all its assigned Addresses, including any assigned Group Addresses, unless specified otherwise in the particular Direct CCC's definition.
- If such configuration can be set via a Direct SET CCC (per *Section 5.1.9.3*), then these shall also apply to the whole Target, with exceptions and limitations noted in *Section 5.1.9.4*.

For such capabilities or other configurable parameters, the Target should accept (i.e., should ACK) such Direct SET CCCs that might be sent to any assigned Dynamic Addresses or assigned Group Addresses, unless the Direct CCC format is not supported for a Group Address, or a particular Direct CCC defines a different use or format that applies when sent to an assigned Group Address (e.g., the MLANE CCC, see *Section 5.1.9.3.30*).

### 5.1.2.2 I3C Address Header

The I3C Address Header follows either a START, or a Repeated START. The format is the same as I<sup>2</sup>C: 7 bits of Address, 1 bit of RnW, and 1 bit of ACK/NACK.

The Address Header following a START is an Arbitrable Address Header, as explained in *Section 5.1.2.2.1*. This means the START and at least the first Address bit and ACK/NACK are issued on SDA using Open Drain Bus drive, similar to I<sup>2</sup>C. However, some of the Arbitrable Address Header may be driven on SDA using Push-Pull and higher speed (see *Section 5.1.2.2.2*).

The Address Header following a Repeated START is always driven on SDA using Push-Pull, with the exception of the ACK/NACK (see *Section 5.1.2.2.4*).

Using the I3C Arbitrable Address Header, I3C Targets may transmit any of three requests to the I3C Controller:

1. **An In-Band Interrupt**, per *Section 5.1.6*. This is equivalent to toggling a wire to get the Controller's attention. The In-Band Interrupt request shall be made using the Target's Dynamic Address with a RnW bit of 1.
2. **A Controller Role Request**, per *Section 5.1.7*. An I3C Device shall not make such a request unless it is marked as a Controller-capable Device in its BCR register, per *Section 5.1.1.2.1*. The Controller Role Request may be made by a Secondary Controller wishing to gain the Controller Role from the Active Controller, or by the Primary Controller after it has relinquished the Controller Role and now wishes to regain it from the Active Controller. The Controller Role Request shall include the Device's Dynamic Address with a RnW bit of 0.
3. **A Hot-Join Request**, per *Section 5.1.5*. An I3C Target shall only make such a request when becoming available after the I3C Bus is operational. The Hot-Join Request shall be made using the reserved Hot-Join Address (i.e., 7'h02).

The I3C Targets shall make these requests to the I3C Controller in only two Bus conditions:

1. A START (but not a Repeated START) is issued on the Bus following a Bus Free Condition, per *Section 5.1.3*. The Target may transmit its Dynamic Address or the Hot-Join Address (7'h02) following the START, by adhering to the I3C Address Arbitration rules per *Section 5.1.2.1*.
2. The Bus is in a Bus Available Condition, per *Section 5.1.3*, so the Target may issue a START by pulling the SDA Low.
  - a. If the Target pulls SDA Low, then the Controller shall pull SCL Low within **tcas** (see *Table 86*).
  - b. The Controller shall also pull SDA Low (overlapping the Target pulling it Low).
  - c. Once the Controller has pulled SCL Low, the Target shall control the SDA line in Open Drain mode (i.e., either pull Low, or release High).
  - d. The Target may then issue its Address in the normal way (condition 1 above).

### 5.1.2.2.1 I3C Address Arbitration

An Address Header following a START (but not a Repeated START) is subject to Arbitration, meaning both the Controller and one or more Targets may attempt to drive an Address onto the Bus, using SDA. Such Address Headers are defined as Arbitrable Address Headers.

The Arbitration model follows the common Open Drain approach. All Devices (whether Controller or Target) that are transmitting an Address shall then follow the same rule:

1. If the current bit to transmit is a 0, then the Device shall drive SDA Low after the falling edge of SCL and hold Low until the next falling edge of SCL.

**Note:**

*Other Devices may also be driving SDA Low, but that is acceptable.*

2. If the current bit to transmit is a 1, then the Device shall not drive SDA, but rather shall High-Z SDA on the falling edge of SCL.
  - a. Additionally, the Device shall monitor the SDA on the rising edge of SCL to determine whether another Device has driven SDA Low.
  - b. If another Device has driven the SDA Low, then the Device has ‘lost’ the Arbitration and shall not further participate in this Address Header. That is, the Device shall not transmit any more bits, but may wait for a future START (but not a Repeated START).

### 5.1.2.2.2 I3C Address Arbitration Optimization

I3C Address Arbitration may optionally be optimized, as detailed in this Section.

The Controller shall not apply the optimizations described in this Section for the first I3C Address Header (i.e., START followed by 7'h7E and an RnW bit of 0) after Bus initialization. This permits any I3C Target with an I<sup>2</sup>C Spike Filter to detect that it is on an I3C Bus, and as a result disable the Spike Filter. The Controller may skip this requirement only if it knows that no I3C Target on the Bus has such a Spike Filter.

As previously described in **Section 5.1.2.2**, an I3C Controller Device assigns 7-bit Dynamic Addresses with values in the range 7'h03 to 7'h7B. However, because the I3C Controller treats the entire 9-bit Arbitrable Address Header as Open Drain, it has no way to detect whether an I3C Target Device might be transmitting its own Address during some (or all) of the Address Header.

For I3C Secondary Controllers and I3C Targets that can request In-Band Interrupts, the I3C Controller is typically free to restrict assigned Dynamic Addresses to the lower half of the available range (7'h03 to 7'h3F), thus leaving the value of Address bit A6 (the first Address bit after the START) as 0 in all such assigned Dynamic Addresses. For other I3C Targets that cannot request In-Band Interrupts, the I3C Controller restricts assigned Dynamic Addresses to the upper half of the available range (7'h40 to 7'h7B), thus leaving the value of Address bit A6 as 1 in all such assigned Dynamic Addresses.

**Note:**

*This Dynamic Address Assignment strategy is not always possible, since some I3C Targets might not support arbitrary Dynamic Address values in the available range (i.e., when an I3C Target has an I<sup>2</sup>C Static Address and also does not support the SETNEWDA CCC; see **Section 5.1.9.3.11**).*

Having restricted Dynamic Addresses in this manner, the I3C Controller may then optionally optimize the Arbitrable Address Header as follows:

- If the I3C Controller is transmitting a 1 value (i.e., High-Z on SDA), as it would when transmitting 7'h7E, then it can monitor SDA on the rising edge of SCL. If SDA has the value 1 (i.e., if SDA is not being driven by any Target), then the I3C Controller may optionally transmit the remainder of the Address Header (up until the ACK/NACK) in Push-Pull mode. See **Figure 13**, upper waveform.
- If the I3C Controller is transmitting a 0 value (i.e., is driving SDA Low), or if SDA was driven Low by a Target, then the I3C Controller shall transmit the remainder of the Address Header using Open Drain.
- If the I3C Controller intends to transmit solely to other I3C Devices (i.e., not to any I<sup>2</sup>C Devices), then it may optionally maintain the SCL pulse width below 50 ns, with the result that any I<sup>2</sup>C Devices present on the Bus will see only a 0 value. This shorter pulse width produces a higher data rate, because for Open Drain Arbitration only the Low time is extended. See **Figure 13**, middle waveform.
- If the I3C Controller intends to transmit to any I<sup>2</sup>C Devices, then it must use the slower I<sup>2</sup>C timing. See **Figure 13**, lower waveform.

The upper waveform of **Figure 13** illustrates this optimization. When the I3C Controller sees a value of 1 for Address bit A6, but previously made sure that all Dynamic Addresses assigned to such Targets have a 0 in bit A6, then the I3C Controller knows that the line was not being driven by any such Target (i.e., for an In-Band Interrupt request or a Controller Role Request).



**Figure 13 Address Arbitration During Header**

1047  
1048

### 5.1.2.2.3 Consequence of Controller Starting a Frame with I3C Target Address

The I3C Controller normally should start a Frame with 7'h7E (for all I3C Messages) or an I<sup>2</sup>C Static Address (when sending only to a Legacy I<sup>2</sup>C Target).

In both cases the Address may be arbitrated, and so the Controller shall monitor to see whether an In-Band Interrupt request, a Controller Role Request (i.e., Secondary Controller requests to become the Active Controller), or a Hot-Join Request has been made.

- If not, then the Controller may proceed normally.
- If so, then the Controller may ACK or NACK that request and then proceed accordingly.

If the Controller chooses to start an I3C Message with an I3C Dynamic Address, then special provisions shall be made because that same I3C Target may be initiating an IBI or a Controller Role Request. So, one of three things may happen:

1. The Addresses match, but the difference is caught on the RnW bit, and the Controller was initiating a Private Write (i.e., RnW = 0) while the Target was attempting to send an IBI request (i.e., RnW = 1).

In this case, the Controller wins (i.e., an IBI with RnW = 1 loses), and the Target shall ACK or NACK the Private Write. The Target shall defer its IBI, and may retry at a later opportunity.

2. The Addresses match, but the difference is caught on the RnW bit, and the Controller was initiating a Private Read (i.e., RnW = 1) while the Target was attempting to send a Controller Role Request (i.e., RnW = 0).

In this case, the Target wins (i.e., a Private Read with RnW = 1 loses), and the Controller must ACK or NACK the Controller Role Request. The Controller shall defer its Private Read, and may retry at a later opportunity.

3. The Addresses match and the RnW bits also match, and so neither Controller nor Target will ACK since both are expecting the other side to provide ACK. As a result, each side might think it had “won” arbitration, but neither side would continue, as each would subsequently see that the other did not provide ACK.

a. If RnW = 0 (i.e., if the Controller was initiating a Private Write while the Target was attempting to send a Controller Role Request), then the Target shall defer its Controller Role Request, and may retry at a later opportunity.

b. If RnW = 1 (i.e., if the Controller was initiating a Private Read while the Target was attempting to send an IBI request), then the Target shall defer its IBI request, and may retry at a later opportunity.

For either value of RnW: Due to the NACK, the Controller shall defer the Private Write or Private Read, and should typically transmit the Target Address again after a Repeated START (i.e., the next one or any one prior to a STOP in the Frame). Since the Address Header following a Repeated START is not arbitrated, the Controller will always win (see **Section 5.1.2.2.4**).

This allows the Controller to determine whether the Target intended to provide the same RnW bit (i.e., which may have led to this NACK situation), or whether it may have simply chosen not to support this transaction. In this manner, the Controller can avoid a ‘live-lock’ situation.

### 5.1.2.2.4 Address Header Following a Repeated START is Push-Pull

The Address transmitted by the I3C Controller following a Repeated START shall not be arbitrated. That is, no I3C Target shall attempt to transmit its own Dynamic Address nor the reserved Hot-Join Address (i.e., 7'h02) following a Repeated START.

As a result, the Address Header (i.e., the 7 bits of Address plus the RnW bit) shall be transmitted on SDA using Push-Pull mode when the Message is not to a Legacy I<sup>2</sup>C Target. The ACK/NACK bit that follows the RnW bit is always Open Drain to allow the Target to ACK or passively NACK its Address.

### 5.1.2.2.5 I3C Target Address Restrictions

The I3C Target Address space is dependent on decisions by the Controller. That is, the Controller may choose the Dynamic Addresses from a set of values, observing optional and non-optional restrictions as follows. These restrictions are also illustrated in *Table 8*.

- The I3C Controller shall not use any of 7'h00, 7'h01, 7'h02, 7'h7E, 7'h7F. All are reserved for I3C.
- The I3C Controller shall not use any of 7'h3E, 7'h5E, 7'h6E, 7'h76, 7'h7A, 7'h7C, 7'h7F. All are prohibited since I3C Targets will interpret an I3C Address Header with any of these Addresses as a Broadcast Address (7'h7E) with a single-bit error. See Error Type TE0, *Section 5.1.10.1.1*.
- The I3C Controller may choose to not use 7'h03, marked in I<sup>2</sup>C as reserved.
- The I3C Controller shall not use 7'h04, 7'h05, 7'h06, 7'h07 if any Legacy I<sup>2</sup>C Devices are present on the Bus that support I<sup>2</sup>C “High-Speed Mode”.
- The I3C Controller shall not use 7'h7C or 7'h7D if any Legacy I<sup>2</sup>C Devices are present on the Bus that support I<sup>2</sup>C Device ID Mode.
- The I3C Controller shall not use 7'h78, 7'h79, 7'h7A, 7'h7B if any Legacy I<sup>2</sup>C Devices are present on the Bus that support I<sup>2</sup>C Extended Address Mode and have an Extended Address or would be impacted by the Extended Address mechanism.

1109

**Table 8 I3C Target Address Restrictions**

| Target Dynamic Address |               | Restriction       | Description                                                                                                                                                                                                                                       |
|------------------------|---------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Binary                 | Hex           |                   |                                                                                                                                                                                                                                                   |
| 000 0000               | 7'h00         | Shall not use     | I3C Reserved                                                                                                                                                                                                                                      |
| 000 0001               | 7'h01         | Shall not use     | I3C Reserved: For use with SETDASA CCC in special Point-to-Point Communication. See <b>Section 5.1.9.3.10.</b>                                                                                                                                    |
| 000 0010               | 7'h02         | Shall not use     | I3C Reserved: Hot-Join Address                                                                                                                                                                                                                    |
| 000 0011               | 7'h03         | Optional          | Marked 'Reserved' by I <sup>2</sup> C                                                                                                                                                                                                             |
| 000 0100               | 7'h04         | Conditional       | Available for use only if no Legacy I <sup>2</sup> C Devices supporting I <sup>2</sup> C "High-Speed Mode" are present on the Bus                                                                                                                 |
| 000 0101               | 7'h05         |                   |                                                                                                                                                                                                                                                   |
| 000 0011               | 7'h06         |                   |                                                                                                                                                                                                                                                   |
| 000 0011               | 7'h07         |                   |                                                                                                                                                                                                                                                   |
| 000 1000<br>011 1101   | 7'h08 – 7'h3D | Available for use | 54 Addresses                                                                                                                                                                                                                                      |
| 011 1110               | 7'h3E         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect                                                                                                                                                                                           |
| 011 1111<br>101 1101   | 7'h3F – 7'h5D | Available for use | 31 Addresses                                                                                                                                                                                                                                      |
| 101 1110               | 7'h5E         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect                                                                                                                                                                                           |
| 101 1111<br>110 1101   | 7'h5F – 7'h6D | Available for use | 15 Addresses                                                                                                                                                                                                                                      |
| 110 1110               | 7'h6E         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect                                                                                                                                                                                           |
| 110 1111<br>111 0101   | 7'h6F – 7'h75 | Available for use | 7 Addresses                                                                                                                                                                                                                                       |
| 111 0110               | 7'h76         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect                                                                                                                                                                                           |
| 111 0111               | 7'h77         | Available for use | 1 Address                                                                                                                                                                                                                                         |
| 111 1000               | 7'h78         | Conditional       | Available for use only if no Legacy I <sup>2</sup> C Devices are present on the Bus that both a) support I <sup>2</sup> C "Extended Address Mode", and b) either have an Extended Address, or would be impacted by the Extended Address mechanism |
| 111 1001               | 7'h79         |                   |                                                                                                                                                                                                                                                   |
| 111 1010               | 7'h7A         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect                                                                                                                                                                                           |
| 111 1011               | 7'h7B         | Conditional       | Available for use only if no Legacy I <sup>2</sup> C Devices are present on the Bus that both a) support I <sup>2</sup> C "Extended Address Mode", and b) either have an Extended Address, or would be impacted by the Extended Address mechanism |
| 111 1100               | 7'h7C         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect<br>(Also not available for use if any Legacy I <sup>2</sup> C Devices supporting I <sup>2</sup> C "Device ID Mode" are present on the Bus.)                                               |
| 111 1101               | 7'h7D         | Conditional       | Available for use only if no Legacy I <sup>2</sup> C Devices supporting I <sup>2</sup> C "Device ID Mode" are on the Bus                                                                                                                          |
| 111 1110               | 7'h7E         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect<br>(See Error Type TE0, <b>Section 5.1.10.1.1.</b> )                                                                                                                                      |
| 111 1111               | 7'h7F         | Shall not use     | I3C Reserved: Broadcast Address single bit error detect                                                                                                                                                                                           |

### 5.1.2.3 I3C SDR Data Words

In I3C SDR, the Data Words match I<sup>2</sup>C only in the sense that they are both 9 bits long. I3C SDR Data Words differ from I<sup>2</sup>C in three ways, as detailed in *Sub-Sections 5.1.2.3.1, 5.1.2.3.2, and 5.1.2.3.4*.

In summary:

1. **Handoff from Address ACK to SDR Controller Write Data:** When performing an SDR Write, the handoff from the Target's Address Header ACK to the Controller's first Data bit is different in I3C. I<sup>2</sup>C is Open Drain, so overlap from the ACK Low into the first bit is harmless. By contrast, I3C is Push-Pull and so this handoff is specified (see *Section 5.1.2.3.1*).
2. **Ninth Bit of SDR Controller Written Data as Parity:** In I<sup>2</sup>C, the ninth Data bit written by the Controller is an ACK by the Target. By contrast, in I3C the ninth Data bit written by the Controller is the Parity of the preceding eight Data bits. Therefore, in I3C the Target shall not drive the SDA line for Data written by the Controller in SDR. In SDR terms, the ninth bit of Write data is referred to as the T-Bit (for 'Transition') (see *Section 5.1.2.3.2*).
3. **Ninth Bit of SDR Target Returned (Read) Data as End-of-Data:** In I<sup>2</sup>C, the ninth Data bit from Target to Controller is an ACK by the Controller. By contrast, in I3C this bit allows the Target to end a Read, and allows the Controller to Abort a Read. In SDR terms, the ninth bit of Read data is referred to as the T-Bit (for 'Transition') (see *Section 5.1.2.3.4*).

**Note:**

*A Target should have an SDA Read detector that determines if the SCL clock has not changed for 100 µs or more, so that it can abandon the read by switching SDA to High-Z and waiting for Repeated START or STOP.*

#### 5.1.2.3.1 Transition from Address ACK to SDR Controller Write Data

The end of any Address Header (whether Arbitrated or not) is an ACK or NACK by the one or more addressed Targets, using Open Drain on SDA:

- If 7'h7E, then it is the ACK of all I3C Targets on the Bus.
- If a single Target Address, then it is the ACK (or NACK) of the addressed Target, or a NACK if no such Target is on the Bus.

When the Address Header results in an ACK, and the Message is SDR Write from Controller, the SDA line has to be turned from Open Drain to Push-Pull for the first data bit. To do that safely, I3C SDR specifies how the handoff is to occur. This is summarized below and shown in *Figure 142*.

1. The I3C Target shall hold the SDA line Low during the ACK (while SCL is Low).
  - This shall be an Open Drain SCL Low period.
2. After the I3C Target sees the rising edge of SCL, it releases the SDA line to High-Z.
  - The I3C Target shall release the SDA line using normal (Push-Pull) timing (release the SDA line as soon as it sees SCL rising).
3. After the rising edge of SCL, the I3C Controller shall drive the SDA line Low.
  - As a result, both Controller and Target will be driving the SDA line Low for a short overlap (which is safe).
  - The SCL High period may be as short as the minimal t<sub>DIG\_H</sub>, per *Section 6.2*.
4. On the falling edge of SCL the I3C Controller shall begin driving data on the SDA line, using Push-Pull drive as shown in *Figure 142*.

When the Address Header results in a NACK, the Controller may choose to:

**either:**

1. Continue the transaction, by generating a Repeated START

**or:**

2. Relinquish the Bus, by generating a STOP as shown in *Figure 143*.

### 5.1.2.3.2 Transition from Address ACK to Mandatory Byte during IBI

The end of any IBI Address Header during an IBI request (whether the Address Header is Arbitrated or not) is either an ACK or a NACK by the Controller, using Open Drain on SDA.

If the Controller detects one of the Target Addresses, and if the Controller chooses to receive the request, then the Controller will ACK the request per *Section 5.1.6.2*.

- **ACK:** When the IBI Target Address Header results in an ACK, and the Target Device is capable of sending a Mandatory Byte, then the SDA line has to be turned from Open Drain to Push-Pull for the first data bit. To do that safely, I3C SDR specifies how the handoff is to occur. This is summarized below and shown in *Figure 14*.

1. The I3C Controller shall hold the SDA line Low during the ACK (i.e., while the SCL line is Low). This shall be an Open Drain SCL Low period.
2. After the rising edge of the SCL line, the I3C Target shall drive the SDA line Low as soon as possible. As a result, both Controller and Target will be driving the SDA line Low for a short overlap (which is safe).
3. After (A) a minimum of the  $t_{SCO}$  time reported by the Target Device, (B) a predetermined safe time that could guarantee the takeover by all Targets, or (C) the Controller may optionally keep the SDA line Low until the next falling edge of the SCL line in order to be in full control of the SDA line and make sure it accommodates all  $t_{SCO}$  values from different Targets, the I3C Controller may release the SDA line. The SCL High period may be as short as the minimal  $t_{DIG\_H}$ , per *Section 6.2*.
4. On the falling edge of SCL, the I3C Target shall begin driving data on the SDA line, using Push-Pull drive as shown in *Figure 14*.

- **NACK:** When the Address Header results in a NACK, as shown in *Figure 15*, the Controller may choose to:

**either:**

- Continue the transaction, by generating a Repeated START,

**or:**

- Relinquish the Bus by generating a STOP.



**Figure 14 Transition from Address ACK to Mandatory Byte During IBI**

1181

1182



1183

1184

**Figure 15 Transition from IBI Address NACK to Repeated START or STOP**

### 5.1.2.3.3 Ninth Bit of SDR Controller Written Data as Parity

The ninth data bit of each SDR Data Word written by the I3C Controller (also referred to as the T-Bit) is a Parity bit, calculated using odd parity. Parity can help in detecting noise-caused errors on the line. The value of this Parity bit shall be the XOR of the 8 Data bits with 1, i.e.:  $\text{XOR}(\text{Data}[7:0], 1)$ .

#### Examples

- If all eight data bits are 1's (0xFF), then the Parity bit value will be 1.
- If all eight data bits are 0's (0x00), then the Parity bit value will be 1.
- If an odd number of bits in the Data Word are 1's (e.g., 0xFE or 0x01), then the Parity bit value will be 0.

T (Parity) bit writes shall always be kept valid through the SCL High period. In the case of a T-Bit representing the last data byte, the write is therefore kept valid through the SCL High period, and the next SCL Low can then be used to either change the SDA, or not change the SDA, in preparation for the Repeated START or STOP that follows.

### 5.1.2.3.4 Ninth Bit of SDR Target Returned (Read) Data as End-of-Data

In I<sup>2</sup>C, Read from Target has the issue that only the Controller ends the Read, so the Target has no ability to control the amount of data it returns. In I3C SDR, by contrast, the Target controls the number of data Words it returns; but it also allows the I3C Controller to abort the Read prematurely when necessary.

This mechanism is controlled purely by the ninth (T) Data bit of each SDR Data Word returned by the I3C Target. The ninth bit is returned by the Target in one of three ways, as explained below.

- The I3C Target returns the ninth bit as 0 (SDA Low) to end the Message:
  - The Target shall set SDA Low on the falling edge of SCL.
  - On the following rising edge of SCL, the Target shall set SDA to High-Z.
  - The I3C Controller shall drive SDA Low on the rising edge of SCL, thereby overlapping with the Target.
  - The I3C Controller then shall issue either a STOP as shown in *Figure 150*, or a Repeated START as shown in *Figure 151* (on the next clock, or one after, per the normal I<sup>2</sup>C procedure for setting up SDA to issue a Repeated START).
- The I3C Target returns the ninth bit as 1 (SDA High) to continue the Message (and permit the Controller to abort the Message):
  - The Target shall set SDA High on the falling edge of SCL.
  - On the following rising edge of SCL, the Target shall set SDA to High-Z, thereby Parking the Bus for the SCL High period:
    - If the I3C Controller is able to continue the reply from the Target, then it shall do nothing. The weak Pull-Up resistor on SDA will keep SDA High during the SCL High period, as shown in *Figure 152*.
    - If the I3C Controller wants to abort the Message, then it shall drive SDA Low after the rising edge of SCL, thereby terminating the Message with a Repeated START. The I3C Controller then takes control starting with the falling edge of SCL. The Controller shall ensure enough delay after SCL rising before driving SDA Low to ensure no contention. In order to achieve this delay, the Controller might have to extend the SCL High period. Since the transition of SDA Low when SCL is High is a Repeated START, the Controller may begin a new Address (see *Figure 154*), or it may issue a STOP in the next cycle (see *Figure 153*). However in a Mixed Bus the Controller should extend the SCL Low period, in order to ensure that any Spike Filters for Legacy I<sup>2</sup>C Devices properly reset.
  - The Target shall monitor the SDA on the falling edge of SCL:
    - If SDA is High, then the Target shall continue with the next data value.
    - If SDA is Low (i.e., if there has been a Repeated START), then the Message has been aborted, and the Target shall not drive SDA after that.

### 5.1.2.4 Use of Clock Speed to Prevent Legacy I<sup>2</sup>C Devices from Seeing I3C Traffic

In a system, there are three possible I3C Bus Configurations:

1. **Pure Bus:** Only I3C Devices are present on the Bus.
2. **Mixed Fast Bus:** Both I3C Devices and Legacy I<sup>2</sup>C Devices are present on the Bus, such that the Legacy I<sup>2</sup>C Devices are restricted to ones that are generally permissible (i.e., Target-only, and no Target clock stretching), and that have a true I<sup>2</sup>C 50 ns Spike Filter on SCL. (I.e., I<sup>2</sup>C Devices that do not ‘see’ the SCL line as High when the High duration is less than 50 ns, across all temperatures and processes.)
3. **Mixed Slow/Limited Bus:** Both I3C Devices and Legacy I<sup>2</sup>C Devices are present on the Bus, such that the Legacy I<sup>2</sup>C Devices are restricted to ones that are generally permissible (i.e., Target-only, and no Target clock stretching), but that do not have a true I<sup>2</sup>C 50 ns Spike Filter on SCL.

The Bus designer’s choice of Bus Configuration affects what speed options are available for I3C SDR, as well as what HDR Modes are possible at various clock speeds. **Table 9** shows the possible options for each Bus Configuration.

**Table 9 Available Options for Bus Operating Parameters, Per I3C Bus Configuration**

| Bus Operating Parameter                                                                 | Available Options Per Bus Configuration          |                                                                                                                                                                          |                             |
|-----------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
|                                                                                         | Pure Bus                                         | Mixed Fast Bus                                                                                                                                                           | Mixed Slow / Limited Bus    |
| <b>SDR Mode Speed</b>                                                                   | f <sub>SCL</sub> (Min) to f <sub>SCL</sub> (Max) | I <sup>2</sup> C Messages: Fm or Fm+,<br>I3C Messages: SCL High from t <sub>DIG_H_MIXED</sub> (Min) to t <sub>DIG_H_MIXED</sub> (Max)<br>(see <b>Section 5.1.2.4.1</b> ) | Fm or Fm+ only <sup>1</sup> |
| <b>HDR-DDR Mode</b>                                                                     | f <sub>SCL</sub> (Min) to f <sub>SCL</sub> (Max) | SCL High from t <sub>DIG_H_MIXED</sub> (Min) to t <sub>DIG_H_MIXED</sub> (Max)<br>(see <b>Section 5.1.2.4.1</b> )                                                        | No                          |
| <b>HDR-TSP Mode</b>                                                                     | HDR-TSP Mode is not included in I3C Basic        |                                                                                                                                                                          |                             |
| <b>HDR-TSL Mode</b>                                                                     | HDR-TSL Mode is not included in I3C Basic        |                                                                                                                                                                          |                             |
| <b>HDR-BT Mode</b>                                                                      | f <sub>SCL</sub> (Min) to f <sub>SCL</sub> (Max) | SCL High from t <sub>DIG_H_MIXED</sub> (Min) to t <sub>DIG_H_MIXED</sub> (Max)<br>(see <b>Section 5.1.2.4.1</b> )                                                        | No                          |
| <b>Note:</b>                                                                            |                                                  |                                                                                                                                                                          |                             |
| 1) May be faster if all Legacy I <sup>2</sup> C Devices are index 1, per <b>Table 4</b> |                                                  |                                                                                                                                                                          |                             |

#### 5.1.2.4.1 Use of Duty Cycle to Achieve Lower Effective Speed in a Mixed Fast Bus

An I3C Pure Bus may simply change the clock speed to any frequency in the allowed speed range, as outlined in *Section 6*. By contrast, a Mixed Fast Bus wanting to clock faster than the slowest Legacy I<sup>2</sup>C Device needs to take advantage of the Spike Filter, i.e., shall ensure that the SCL High period is shorter than the Spike Filter, in order to prevent the Legacy I<sup>2</sup>C Devices from seeing the SCL High period (see  $t_{DIG\_H\_MIXED}$  in *Table 87*). As a result, the Legacy I<sup>2</sup>C Device ‘sees’ the SCL as staying Low the whole period.

However, a Mixed Fast Bus I3C Controller can change the effective Bus frequency by varying the duty-cycle of SCL. This allows running the data rate slower, for example to accommodate Targets that need a lower rate as defined by GETMXDS CCC (see *Section 5.1.9.3.18*). It may also be necessary to accommodate Legacy I<sup>2</sup>C Devices with Spike Filters that need a longer Low period in order to function properly.

In this model the SCL High period shall never exceed  $t_{DIG\_H\_MIXED}$ , thus staying below the 50 ns required by the I<sup>2</sup>C Spike Filter; however, the Low period is free to be any length permitted by I3C’s allowed clock frequency range. For example, depending on the clock generation capability of the I3C Controller, the SCL Low period may be a multiple of the High period, or it may be any multiple of some higher frequency clock capable of providing a High period less than or equal to  $t_{DIG\_H\_MIXED}$ , but greater than the minimum SCL High period as defined in *Table 85*.

**Example 1:** An SCL High period of 40 ns, plus a Low period of 280 ns, yields a total clock period of 320 ns which corresponds to a frequency of 3.125 MHz.

**Example 2:** In order to ensure that the Legacy I<sup>2</sup>C Device Spike Filters continue tracking SCL as Low, an SCL High period of 40 ns could be used with a Low period of 80 ns, yielding a total clock period of 120 ns which corresponds to a frequency of 8.3 MHz.

Such adjustment of the clock Duty Cycle brings three benefits:

- It remains hidden from Legacy I<sup>2</sup>C Devices, while still significantly increasing the SDR, HDR-DDR, and HDR-BT data rate.
- It ensures a longer Low period, so that Legacy I<sup>2</sup>C Device Spike Filters continue to track SCL as Low.
- It is easy for a Controller to generate, and has no impact on I3C Targets (which just react to clock edges).

This model works because all I3C Targets must be able to accommodate 12.5 MHz as a clock rate, so the shorter High period will not impact them.

Note that this Duty Cycle technique does not resolve issues of long Buses with high line capacitance. This is because the short High period may be insufficient for SDA propagation, even if the Low period is long enough.

### 5.1.2.5 Controller Clock Stalling

In SDR Mode the I3C Controller may Stall the I3C Bus during the SCL Low period, but only under the specific, transitory conditions described in this Section.

Stalling may be necessary for either of two reasons:

1. The absolute or relative timing of a Message to a specific Target, or to all Targets, needs to be carefully controlled. Clock Stalling provides the Controller with fine-grained data timing control.
2. The I3C Controller needs to internally synchronize data. This may be due to parts of the Controller's system waking up in response to data, to changing state, or to otherwise needing time during a transaction.

Note that Stalling impacts Bus performance. For example, it will reduce the Bus capacity and increase the latency of any Devices issuing In-Band Interrupts.

To Stall the Bus, the I3C Controller shall hold SCL Low while the Bus is in one of the four following conditions, each of which is detailed below:

1. I3C/I<sup>2</sup>C Transfer, ACK/NACK Phase
2. Write Data Transfer, Parity Bit
3. I3C Read Transfer, Transition Bit
4. Dynamic Address Assignment, First Bit of Assigned Address

The maximum Stall time (SCL Low period) shall be 15 ms; note, this is an absolute maximum. The Controller should use the shortest Stall duration possible given current circumstances, per **Table 10**.

**Table 10 Controller Clock Stall Times**

| Condition                                                 | Section          | Maximum Stall Time |
|-----------------------------------------------------------|------------------|--------------------|
| I3C/I <sup>2</sup> C Transfer, ACK/NACK Phase             | <b>5.1.2.5.1</b> | 100 µs             |
| Write Data Transfer, Parity Bit                           | <b>5.1.2.5.2</b> | 100 µs             |
| I3C Read Transfer, Transition Bit                         | <b>5.1.2.5.3</b> | 100 µs             |
| Dynamic Address Assignment, First Bit of Assigned Address | <b>5.1.2.5.4</b> | 15 ms              |

In all cases, after Stalling the SCL Low period, the continuation of the clock (i.e., the first SCL rising edge after the extended Low period) shall follow the normal rules for I3C SDR (for I3C SDR Messages), or for I<sup>2</sup>C (for I<sup>2</sup>C Messages) including rise time, change in SDA (if any) before SCL rise, next bit, etc. For example, the I3C Controller might choose to terminate the Frame after this Stalled bit with a STOP; but in this case the Controller is required to observe the requirements for STOP timing, as appropriate.

It is recommended to use Controller Clock Stalling only when necessary and unavoidable. In all other circumstances the Controller should avoid Controller Clock Stalling because of its negative impacts on Bus performance. In order to help guide system designers, Data Sheets for I3C Controller Devices should include appropriately detailed SCL Stalling parameters.

### 5.1.2.5.1 I3C/I<sup>2</sup>C Transfer, ACK/NACK Phase

Controller Clock Stalling during the ACK/NACK phase of the I3C/I<sup>2</sup>C transfer (see *Figure 16*) indicates one of the following:

- The Controller can allow the I3C/I<sup>2</sup>C Target to prepare to receive data (for write transfers) or transmit data (for read transfers)
- The Controller can Stall SCL during write or read transfers to Legacy I<sup>2</sup>C Targets in case of underrun and overflow situations
- The Controller can Stall the clock during the ACK/NACK phase of the incoming In-Band Interrupt (Target Interrupt Request or Controller Role Request), to decide whether to ACK or NACK depending upon the incoming In-Band Interrupt
- The Controller can allow the Target to respond with data for the directed GET CCC commands if the Target is not ready with the CCC data to be returned



**Figure 16 Controller Clock Stalling in ACK Phase**

### 5.1.2.5.2 Write Data Transfer, Parity Bit

The Controller can Stall SCL between data bytes of an I3C Write Data transfer, by Stalling the clock during the Low period of the Parity Bit, in case of underrun situations. See *Figure 17*.



**Figure 17 Controller Clock Stalling in Write Parity Bit**

### 5.1.2.5.3 I3C Read Transfer, Transition Bit

The Controller can Stall SCL between data bytes of an I3C Read Data transfer, or before terminating, by Stalling the clock during the Low period of the Transition Bit, in case of overflow situations. See *Figure 18* through *Figure 22*.



**Figure 18 Controller Clock Stalling in T-Bit Before Next Read Data**



**Figure 19 Controller Clock Stalling in T-Bit Before STOP**

**Figure 20 Controller Clock Stalling in Low T-Bit Before Repeated START****Figure 21 Controller Clock Stalling in High T-Bit Before Repeated START**

1333  
1334 **Figure 22 Controller Clock Stalling in High T-Bit Before Repeated START and STOP****5.1.2.5.4 Dynamic Address Assignment, First Bit of Assigned Address**

1335 The Controller can Stall SCL during the Low period of the first bit of the Assigned Address phase of the  
 1336 Enter Dynamic Address Assignment CCC command (ENTDAA, see *Section 5.1.9.3.4*), for example to gain  
 1337 time to assign the Dynamic Address to the Device based on the Target's Bus Characteristics Register BCR  
 1338 (see *Section 5.1.1.2.1*) and Device Characteristics Register DCR (see *Section 5.1.1.2.2*) bytes. See *Figure*  
 1339 **23.**

1340  
1341 **Figure 23 Controller Clock Stalling in Dynamic Address First Bit**

### 5.1.3 Bus Conditions

This Specification defines Open Drain Pull-Up and High-Keeper, as well as three distinct conditions in which the I3C Bus shall be considered inactive: Bus Free, Bus Available, and Bus Idle.

#### 5.1.3.1 Open Drain Pull-Up and High-Keeper

I3C Controller Devices shall provide an active Open Drain class Pull-Up, to be engaged whenever the Bus is in Open Drain mode (with exceptions, detailed below, where a weak Pull-Up may be used).

This active Pull-Up shall be implemented either:

1. As a passive resistance from V<sub>DD</sub>, or
2. As a passive resistance from a current source, or
3. In any other method that both:
  - a. Balances its current sourcing in order to ensure that SDA rises within t<sub>rDA</sub> (see **Table 85**), and
  - b. Is not so strong as to prevent a Target with the minimum I<sub>OL</sub> driver (see **Table 82**) from driving SDA Low within t<sub>rDA</sub> (see **Table 85**).

In addition to the active Open Drain class Pull-Up, a High-Keeper is also required on the Bus. A High-Keeper is generally used for a Controller-to-Target or Target-to-Controller handoff, and for optional termination uses where the Controller can signal a termination by driving SDA Low while Parked High.

The High-Keeper on the Bus shall be strong enough to prevent system leakage (i.e., the sum of the leakage of all Devices on the Bus) from pulling SDA, and sometimes SCL, Low. The High-Keeper on the Bus shall also be weak enough that a Target with the minimum I<sub>OL</sub> driver (see **Table 82**) is able to pull SDA, SCL, or both Low within the Minimum t<sub>DIG\_L</sub> period.

The Controller may provide the High-Keeper on the Bus. If the Controller does so, then the Controller shall also provide a way to disable its High-Keeper. Reasons to disable a Controller-provided High-Keeper might include that the High-Keeper is not strong enough for the present system leakage, or other reasons.

A Controller-provided High-Keeper may optionally be implemented using a single, common Pull-Up Device capable of supporting both the active Open Drain class Pull-Up function and the weak High-Keeper class Pull-Up function.

Whether implemented as a single combined Pull-Up, or as two separate Pull-Ups, the Controller should switch SCL and SDA, each independently, between three Pull-Up states as needed, based on Bus state:

1. No Pull-Up (High-Z)
2. High-Keeper Pull-Up
3. Open Drain Pull-Up

The Bus shall have High-Keepers on SDA and SCL. When adequate High-Keepers cannot be provided by the Controller, then the system designer is required to handle this externally. Reasons why the Controller would be unable to provide adequate High-Keepers might include that the Controller does not support High-Keepers, that the Controller-provided High-Keepers are not strong enough for present needs, or that the Bus is too long to use the Controller-provided High-Keepers.

The system High-Keepers on SCL and SDA may be implemented as one or more passive resistors tied to V<sub>DD</sub>, or they may be active Bus-Keeper Devices that turn off when the respective line is pulled below some threshold. The system High-Keepers on SCL and SDA shall be sized so as to balance between system leakage and the requirement that I3C Devices be able to pull the corresponding line Low within the t<sub>DIG\_L</sub> period.

**Note:**

*The Controller may choose to not use the Open Drain class Pull-Up in cases of Open Drain mode where the SDA happens to be already High (i.e., is coming into the SCL Falling edge). In that case, the Controller may choose to rely solely upon the High-Keeper, in order to use less power if and when a Target drives SDA Low.*

### 5.1.3.2 Bus Condition Timing

After a STOP, three defined timing conditions are used to create permission for a Controller or a Target to take defined actions leading to a START: the Bus Free Condition, the Bus Available Condition, and the Bus Idle Condition. **Figure 24** illustrates timing for each condition, and each condition is detailed in a sub-section below.



**Figure 24 Bus Condition Timing**

#### 5.1.3.2.1 Bus Free Condition

The Bus Free Condition is defined as a period occurring after a STOP and before a START, and with the following duration:

- **For Pure Bus:** A duration of at least  $t_{CAS}$  (see **Table 86**).
- **For Mixed Bus** (i.e., at least one Legacy I<sup>2</sup>C Device is present on the I3C Bus): A duration of at least  $t_{BUF}$  (see **Table 85**). Note that the value of  $t_{BUF}$  depends upon whether any I<sup>2</sup>C FM Devices vs. I<sup>2</sup>C FM+ Devices are present on the Mixed Bus.

#### 5.1.3.2.2 Bus Available Condition

The Bus Available Condition is defined as a period during which the Bus Free Condition is sustained continuously for a duration of at least  $t_{AVAL}$  (see **Table 86**). A Target may only issue a START Request (e.g., for an In-Band Interrupt, or for a Controller Role Request) after a Bus Available Condition.

#### 5.1.3.2.3 Bus Idle Condition

The I3C Bus Idle Condition is defined in order to help ensure Bus stability during Hot-Join events, and is defined as a period during which the SDA and SCL lines both sustain High level for a duration of at least  $t_{IDLE}$  (see **Table 86**).

### 5.1.3.3 Activity States

I3C provides a mechanism for the Controller to inform Targets about expected upcoming levels of activity on the I3C Bus, in order to help the Targets better manage their internal states. Four Activity State levels from 0 through 3 are defined (see *Table 11*).

**Table 11 Activity States**

| Activity State | Activity Interval | CCC    |
|----------------|-------------------|--------|
| 0              | 1 $\mu$ s         | ENTAS0 |
| 1              | 100 $\mu$ s       | ENTAS1 |
| 2              | 2 ms              | ENTAS2 |
| 3              | 50 ms             | ENTAS3 |

The Activity State number serves as a hint to the Target, indicating how long it will be before the Controller directs Bus activity to that Target, and the likely latencies to expect in response to the Target pulling SDA Low (i.e., for the START Request to then generate an In-Band Interrupt Request or a Controller Role Request).

The Controller uses CCC commands ENTAS0, ENTAS1, ENTAS2, and ENTAS3 (see *Section 5.1.9.3.2*) to communicate the four expected Bus Activity states to Targets. Each ENTASx CCC has both a Broadcast version and a Directed (per-Target) version. The Controller may switch to a different Activity State in any way, and at any time, by issuing the appropriate ENTASx CCC command.

The Target may use the received Activity State hint to adjust internal settings such as power savings, FIFO trigger levels, timestamp counters and clock rates, and other suitable operating parameters. However Targets are not required to support the Activity States CCCs (ENTASx), and as a result could even ignore them completely.

The Activity States mechanism is a basis for a general agreement between Controller and Target, i.e., that the Target may NACK any access occurring sooner than the general time factor. For example: If the Controller sends the ENTAS2 CCC, meaning the Controller is unlikely to initiate a request sooner than 2 ms from the time the CCC is sent, then a request arriving only 1 ms later could result in a NACK (although it will be ACKed if the request is repeated after the Target re-awakens). As a result, the Target shall wake up either upon any Bus activity, or upon matching 7'h7E and its own Dynamic Address.

The Activity State CCCs also adjust the maximum value for I3C Bus timing parameter **tcas** (Clock after START; see *Table 86*), the maximum amount of time that the Controller may take to generate the SCL clock (drive SCL Low) in response to the Target pulling SDA Low. Note that **tcas** is only a worst-case number; it does not indicate whether or not the Controller will ACK the In-Band Interrupt Request or Controller Role Request. Further, the selected Activity State does not necessarily indicate the time at which the Controller will read additional data from a Target in response to an In-Band Interrupt; that is a private contract between Controller and Target. A Target that does not support the ENTASx CCCs shall have a **tcas** maximum value of 50 ms (the ENTAS3 value).

Activity States are not intended as a substitute for a more precise power mode, nor for any other mechanism that might be supported by private contract between Controller and Target. For example, if a Target has a Device power mode setting, then the Controller should use that mechanism to put the Target into the desired state. Likewise, a Target could provide a FIFO trigger level setting, relating to the amount of time that the Controller will have to read the FIFO contents in response to an In-Band Interrupt Request; if so, then the Controller should use that setting to match its internal latencies.

### 5.1.4 Bus Initialization and Dynamic Address Assignment Mode

The Controller-capable Device with the job of initializing the I3C Bus holds the special role of “Primary Controller”. The Primary Controller acts as the authority for the initial configuration of the Bus and all Devices, including any Legacy I<sup>2</sup>C Devices. Since it acts as the Bus’s first Active Controller, during Bus initialization it also performs the Dynamic Address Assignment procedure as part of configuring all I3C Devices that require a Dynamic Address.

Additionally, either the Primary Controller or any Secondary Controller that supports Hot-Join may also subsequently perform the Dynamic Address Assignment procedure while acting as Active Controller, i.e., when a Device needs to be reset or when a new Device is connected to an already-configured I3C Bus and performs a Hot-Join Request.

As detailed in this Section, a Controller must be responsible for performing a Dynamic Address Assignment procedure, in order to provide a unique Dynamic Address to each I3C Device (i.e., with Target or Secondary Controller role) that is connected to the Bus.

**Note:**

*For the remainder of this Section, the term ‘Controller’ applies to any capable Controller, including the Primary Controller, performing the Dynamic Address Assignment procedure for any reason.*

Once a Target or Secondary Controller receives a Dynamic Address, that Dynamic Address shall be used in all subsequent transactions on the I3C Bus, until and unless the Controller changes the Dynamic Address (if applicable). The only way for the Controller to change the Dynamic Address is by using either the RSTDAA CCC command (see **Section 5.1.9.3.3**) or the SETNEWDA CCC command (if applicable; see **Section 5.1.9.3.11**). The Controller might choose to change the Dynamic Address due to re-prioritization, unless the Target does not support the SETNEWDA CCC.

The Controller controls the Dynamic Address Assignment process. This process includes an Address Arbitration procedure similar to I<sup>2</sup>C’s (see [*NXP01*] at **Sections 3.1** and **3.1.8**). The I3C Arbitration procedure differs from I<sup>2</sup>C by using the values of the 48-bit Provisioned ID and the Device’s I3C Characteristic Registers (that is, BCR and DCR), concatenated. The Device on the I3C Bus with the lowest concatenated value wins each Arbitration round in turn, and the Controller assigns a unique Dynamic Address to each winning Device.

### 5.1.4.1 Device Requirements for Dynamic Address Assignment

This Section describes the requirements for Target Devices to be identified by the Controller for assignment of a Dynamic Address.

#### 5.1.4.1.1 Target Device 48-bit Provisioned ID

A Device that supports the Broadcast Command Code **Enter Dynamic Address Assignment** (ENTDAA) (see *Section 5.1.4.2*) shall have a 48-bit Provisioned ID. The Controller shall use this 48-bit Provisioned ID, unless the Device has a Static Address and the Controller uses the Static Address.

The 48-bit Provisioned ID is composed of three parts:

1. **Bits[47:33]: MIPI Manufacturer ID [MIPI01]** (15 bits)

*Note:* The Most Significant Bit of the MIPI Manufacturer ID is discarded, i.e. only the 15 Least Significant Bits are used.

2. **Bit[32]: Provisioned ID Type Selector** (One bit, 1'b1: Random Value, 1'b0: Vendor Fixed Value)

3. **Bits[31:0]:** 32 bits containing either a **Vendor Fixed Value** or a **Random Value**, depending on the value of Bit[32]:

**If the value of Bit[32] is 1'b0: Vendor Fixed Value, then:**

- **Bits[31:16]: Part ID:** The meaning of this 16-bit field is left to the Device vendor to define.
- **Bits[15:12]: Instance ID:** The value in this 4-bit field should identify the individual Device, using a method selected by the system designer. For example: straps, fuses, non-volatile memory, or another appropriate method.
- **Bits[11:0]:** The meaning of this 12-bit field is left for definition with additional meaning. For example: deeper Device Characteristics, which could optionally include Device Characteristic Register values.

**If the value of Bit[32] is 1'b1: Random Value, then:**

- **Bits[31:0]:** 32-bit value randomly generated by the Device. This value can be queried via General Test Mode, using the Command Code **Enter Test Mode** (ENTTM) (see *Section 5.1.9.3.8*).

**Note:**

*Under Vendor Test Mode, the Device may provide a fully random or pseudo-random 32-bit value in Bits[31:0] of its Provisioned ID (see *Section 5.1.9.3.8*). Bits[47:33] shall not be randomized.*

#### 5.1.4.1.2 Unique Identifiability Methods

In order to support the Dynamic Address Assignment procedure, each I3C Device to be connected to an I3C Bus shall be uniquely identifiable before starting the procedure. Two mechanisms are defined:

1. The Device shall have a 48-bit Provisioned ID (see *Section 5.1.4.1.1*)
2. In addition, the Device may also optionally have a Static Address, in which case the Controller may use that Static Address (presuming it is known to the Controller). For example, an Address similar to what I<sup>2</sup>C specifies **[NXP01]**.

### 5.1.4.2 Bus Initialization Sequence with Dynamic Address Assignment

Bus Initialization and Dynamic Address Assignment shall be executed according to the following sequence. See also **Figure 170**, Dynamic Address Assignment FSM.

The Dynamic Address Assignment process shall be performed in Open Drain mode, except that the Repeated START and 7'h7E/R may be either Open Drain or Push-Pull. For Open Drain the Controller shall drive the SCL line with clocks at the appropriate Open Drain speed for the Devices present on the I3C Bus. For Repeated START, the Primary Controller may optionally choose to actively drive the SDA line High, but only after the Target has safely released the SDA line.

In the procedure below, steps 1 and 2 shall be performed only by the Primary Controller, and only during Bus initialization. Subsequent steps may be performed by any capable Controller holding the Active Controller role, for subsequent Dynamic Address Assignment as needed.

1. The Primary Controller shall begin in an appropriately configured state, and shall have, either in its own non-volatile memory or as a result of having received it from the Host, the following data:
  - a. The number of I3C compliant Devices that need to receive a Dynamic Address,
  - b. The data for any I3C Devices resident on the I3C Bus that already have I<sup>2</sup>C Static Addresses, and
  - c. The data for any Legacy I<sup>2</sup>C Devices resident on the I3C Bus.
2. The Primary Controller should assign Dynamic Addresses to any I3C Devices with a known Static Address, using the Command Code **Set Dynamic Address from Static Address** (SETDASA, see **Section 5.1.9.3.10**), or by assigning all I3C Devices their known I<sup>2</sup>C Static Address using the Command Code **Set All Addresses to Static Address** (SETAASA) (see **Section 5.1.9.3.23**).

Under these pre-conditions, Targets supporting the SETAASA CCC and Targets only supporting the SETDASA CCC (see **Section 5.1.9.3.10**) can be mixed on the I3C Bus. Via SETDASA, the Controller will individually assign a Dynamic Address to each Target not supporting SETAASA.

In a system that mixes I<sup>2</sup>C-capable Devices and non-I<sup>2</sup>C-capable Devices, the Controller should send the SETAASA CCC before sending the ENTDAAC CCC (see **Section 5.1.9.3.4**), in order to assign Dynamic Addresses to the I3C-only Targets. In addition, any Target having a restricted Address (see **Table 8**) shall not support SETAASA.

- All I3C Target Devices shall support at least one of the aforementioned Dynamic Address assignment methods.
3. If the Active Controller knows it has already assigned all Targets their Dynamic Address(es) in the preceding Bus initialization steps, then it may skip the remaining steps in this procedure (i.e., is permitted to not use the ENTDAAC CCC). Otherwise, the Active Controller shall send the Broadcast Command Code **Enter Dynamic Address Assignment** (ENTDAAC, see **Section 5.1.9.3.4**).

**Note:**

*A Target Device that does not implement the ENTDAAC Broadcast Command Code CANNOT BE RELIED ON TO BE ASSIGNED A DYNAMIC ADDRESS on a generic I3C Bus. DAA is an essential basic function of the generic I3C Bus, and ENTDAAC should not be omitted without careful consideration.*

- 1538 4. The Active Controller shall send a Repeated START, and the I3C Broadcast Address 7'h7E with  
1539 RnW bit High (i.e., Read). Every I3C Device on the I3C Bus that supports Dynamic Address  
1540 Assignment with ENTDAA and does not yet have an assigned Dynamic Address shall  
1541 acknowledge the I3C Broadcast Address, except for Hot-Joining Devices that are not eligible to  
1542 participate (per **Section 5.1.5**).

1543 At least one I3C Device on the I3C Bus should acknowledge the I3C Broadcast Address in this  
1544 step, if a Hot-Join Device had previously initiated a Hot-Join Request to signal that it needed a  
1545 Dynamic Address and was eligible to participate in Dynamic Address Assignment with ENTDAA.

1546 **Note:**

1547 *Per Section 5.1.5, a Hot-Joining Device must first emit the Hot-Join Request at least once,*  
1548 *before it may ACK the I3C Broadcast Address 7'h7E with RnW bit High and participate in a*  
1549 *Dynamic Address Assignment procedure with ENTDAA. For example, a Hot-Joining Device*  
1550 *that uses the standard Hot-Join method must wait to determine that the Bus is Idle (see*  
1551 *Section 5.1.3.2.3) before it may request a START as part of a Hot-Join Request. If such a*  
1552 *Device has not waited for the minimum time (i.e., Bus Idle Condition) to determine whether*  
1553 *the Bus is Idle, then it shall not emit the Hot-Join Request, and hence it cannot participate in*  
1554 *Dynamic Address Assignment with ENTDAA.*

1555 *This use of the I3C Broadcast Address (7'h7E) with RnW bit High (i.e., Read) is specific to*  
1556 *Dynamic Address Assignment Mode. It is also acceptable per the I<sup>2</sup>C Specification [NXP01].*

- 1557 5. The Active Controller shall drive only the SCL line. The Active Controller shall release the SDA  
1558 line to a High-Z state, allowing SDA to go to High level via the Bus Pull-Up resistor.  
1559 6. Every I3C Device that is eligible to participate and responds to the I3C Broadcast Address sent in  
1560 Step 4 shall drive the SDA line with its own 48-bit Provisioned ID (using Big Endian bit order),  
1561 until it loses Dynamic Address Arbitration.

1562 The 48-bit Provisioned ID shall be transferred continuously, starting with the most significant bit  
1563 (bit[47]), with no delimitation or ACK/NACK pulse.

1564 **Note:**

1565 *As mentioned above, a Hot-Joining Device shall only participate in the Dynamic Address*  
1566 *Assignment procedure after emitting the Hot-Join Request (per Section 5.1.5).*

- 1567 7. The Active Controller shall continue to drive the SCL line with the same clock, while still  
1568 releasing the SDA line. The I3C Device that did not yet lose the Arbitration shall then transfer its  
1569 Bus Characteristics Register (BCR) and Device Characteristic Register(s) (DCR) per  
1570 **Section 5.1.1.2.2**, until it eventually loses Dynamic Address Arbitration. See also **Section 5.1.4.3**.  
1571 8. The Device whose concatenated Provisioned ID, BCR, and DCR has the lowest value will win the  
1572 Arbitration round, due to the nature of Arbitration.

1573 **Note:**

1574 *It is possible for multiple Devices to have the same concatenated value, although this is*  
1575 *highly improbable. See Section 5.1.4.3.*

1576 *Per Section 5.1.2.5.4, the Controller can stall SCL after receiving the last bit of the DCR, if it*  
1577 *needs time to determine the correct Dynamic Address for the specific Device that has won*  
1578 *this Arbitration round.*

- 1579 9. The Active Controller shall transfer a 7-bit wide Dynamic Address for the winning Device, in  
 1580 Open Drain Mode. This Dynamic Address shall incorporate the priority level that the Active  
 1581 Controller assigns to the Device, per **Section 5.1.6.2**. The Arbitration-winning Device shall  
 1582 acknowledge the assigned Dynamic Address. This Dynamic Address transfer procedure shall have  
 1583 the following steps:
- 1584 • The Active Controller shall drive the 7-bit Dynamic Address, followed by a parity bit (PAR),  
 1585 which is calculated as odd parity. Odd parity is the inverse of the XOR of the 7 bits. Therefore  
 1586  $\sim\text{XOR}(\text{dynamic\_address}[7:1])$  is placed in position 0.
- 1587 • If the parity is valid, then the Target shall acknowledge receipt of the Dynamic Address on the  
 1588 next SCL clock. If the parity is invalid, then the Target shall passively NACK on the next  
 1589 SCL.
- 1590 10. The Active Controller shall repeat this procedure, jumping back to step 4 until there is no ACK  
 1591 from any Device present on the I3C Bus.
- 1592 11. This Dynamic Address Assignment procedure shall be ended by the Active Controller issuing a  
 1593 STOP.

1594 **Figure 25** shows a typical Dynamic Address Assignment transaction using the flow that is entered with the  
 1595 ENTDAACCC, including two iterations of steps 4–9 above. This Figure shows how the Controller may send  
 1596 the ENTDAACCC after either a START or a Repeated START.



1597 1598 **Figure 25 Dynamic Address Assignment Transaction**

1599 Regarding this Dynamic Address Assignment procedure, note that:

- 1600 • The Active Controller may end the Dynamic Address Assignment procedure at any time, even if  
1601 some of the pre-established I3C Devices have not yet received their Dynamic Addresses.
- 1602 • The Dynamic Address Assignment procedure can be started again any time the I3C Bus is in Bus  
1603 Free Condition, using the Command Code **Enter Dynamic Address Assignment (ENTDAA)** (see  
1604 *Section 5.1.9.3.4*).
- 1605 • If a given Target does not acknowledge its assigned Dynamic Address, then the procedure requires  
1606 the Active Controller to continue from step 4. The Target will then participate in the Address  
1607 Arbitration using the same 48-bit Provisioned ID, and as a result the Target will win the  
1608 Arbitration round. If the Target does not ACK the Dynamic Address a second time, then the Active  
1609 Controller shall exit the Dynamic Address Assignment procedure and execute an error  
1610 management procedure provided by the I3C Bus designer.
- 1611 • Any Secondary Controllers wishing to receive the Dynamic Addresses assigned to all I3C Devices  
1612 present on the I3C Bus can do one, or both, of the following:
  - 1613 • Follow the Dynamic Address Allocation procedure. If a Secondary Controller has been  
1614 connected to the Bus since the Bus was initialized by the Primary Controller, then it will have  
1615 received all the same data for all other I3C Devices that received a Dynamic Address.
  - 1616 • Monitor the Bus and wait for the Active Controller to send the Command Code **Define List of**  
1617 **Targets** (DEFTGTS, see *Section 5.1.9.3.7*), then acquire the Addresses and Characteristics of  
1618 all Devices on the I3C Bus from the Broadcasted data.

1619 After the Dynamic Address Assignment process is complete, the Active Controller knows which Devices on  
1620 the I3C Bus are Secondary Controllers. The Active Controller then addresses the Secondary Controllers with  
1621 the Command Code **Define List of Targets** (DEFTGTS, see *Section 5.1.9.3.7*) and transfers the data for all  
1622 Devices on the I3C Bus.

### 5.1.4.3 Provisioned ID Collision Detection and Correction

In the Dynamic Address Assignment procedure described in *Section 5.1.4.2*, multiple I3C compliant Devices will receive the same Dynamic Address if they provide the Active Controller with both identical 48-bit Provisioned IDs, and identical Device Characteristic Register values. Although the probability of such a coincidence is quite small the potential does exist, and the I3C Bus will not operate properly under such conditions (at least the Instance IDs must be different, see *Section 5.1.4.1.1*). As a result the Primary Controller must test for this collision condition for any Devices present during Bus initialization, and resolve it if necessary, before the I3C Devices present on the I3C Bus can all be safely used together.

During Bus initialization the Primary Controller knows the number of Devices resident on the I3C Bus requiring Dynamic Address Assignment (per procedure step 1.a. in *Section 5.1.4.2*), which enables detection of collision errors. At completion of the Dynamic Address Assignment procedure the Primary Controller shall compare this expected number to the final count of Static Addresses and Dynamic Addresses that were actually assigned. If fewer Dynamic Addresses were assigned than expected, then multiple Devices must have received the same Dynamic Address, i.e., a collision has occurred.

If this collision condition is detected, then the Primary Controller shall resolve it using the following method:

- The Primary Controller resets the Dynamic Address Assignment process by using the Broadcast Command Code **Reset Dynamic Address Assignment (RSTDAA)** (per *Section 5.1.9.3.3*), and then proceeding from step 3 of the procedure in *Section 5.1.4.2* from step 8, until the sooner of either:
  - a. The expected number of I3C Devices is discovered, **or**
  - b. A set maximum number of attempts fail. If this limit is reached, then a system error message shall be sent to the Host. To avoid freezing the entire system, a limit of three (3) attempts is recommended.

A Secondary Controller might not be able to test for this collision without also knowing how many Devices are expected to require Dynamic Address Assignment. Additionally, for Devices that are connected to the Bus after it is configured, a Controller might not be able to detect a collision if the Devices both join at the same time and have identical Provisioned IDs.

#### 5.1.4.4 Group Address Assignment Procedure

As an optional feature, multiple I3C Target Devices can share a single Group Address, allowing a Controller Device to send a given I3C Message to all Target Devices in the Group at once rather than one at a time. In a Target that supports the Group Address capability, a Group Address is stored and exists alongside the Target's unique Dynamic Address; i.e., both Addresses are in effect simultaneously. A Target can optionally be designed to support multiple Groups; such Targets store one Group Address for each Group in which the Target is included, up to the maximum number of supported Groups; all of the Group Addresses are in effect simultaneously.

The Active Controller can write to a Group Address just as it would any I3C Dynamic Address. However, the Active Controller shall not attempt to read data from I3C Devices using a Group Address. Both rules apply for private SDR and HDR Messages, and for Broadcast and Direct Set CCC commands.

An I3C Device with active Target role that has been assigned a Group Address shall not issue an In-Band Interrupt (IBI) using that Group Address.

The Active Controller can configure the Group Address function using the following CCC commands:

- **SETGRPA** (see *Section 5.1.9.3.27*): Assigns a Group Address to one or more I3C Targets, each selected via its Dynamic Address. (As a result, each such I3C Device must be assigned a Dynamic Address first, before the Group Address is assigned via SETGRPA.)
- **GETCAPS** (see *Section 5.1.9.3.19*): Gets the various capabilities of the I3C Targets on the I3C Bus, in particular whether the Group Address function is supported.
- **DEFTGTS** (see *Section 5.1.9.3.7*): Informs any Secondary Controllers about what Addresses, including any Group Addresses, have been assigned to the I3C Targets on the I3C Bus.
- **DEFGRPA** (see *Section 5.1.9.3.29*): Informs any Secondary Controllers that support the Group Address feature about what I3C Targets on the I3C Bus are included in each Group Address.
- **RSTGRPA** (see *Section 5.1.9.3.28*): Removes one or more I3C Targets from a Group by resetting their assigned Group Address, disbands a single Group, or removes all Groups and Group Addresses.

To use the Group Address feature, the Active Controller must support the assignment of Group Addresses. The Active Controller shall use the following procedure to assign one or more Group Addresses to each desired I3C Device on the I3C Bus:

1. After the Active Controller assigns Dynamic Addresses to the I3C Devices on the I3C Bus (via the ENTDA and/or SETDASA CCC), the Active Controller shall determine the capabilities of the I3C Devices on the I3C Bus via the GETCAPS CCC.

GETCAPS allows the Active Controller to determine, among other things, which I3C Targets support the Group Address function.

If an I3C Device joins the I3C Bus via Hot-Join, then the Active Controller shall determine that Device's capabilities via the GETCAPS CCC following completion of the Hot-Join (i.e., only after assignment of a Dynamic Address via the ENTDA CCC).

2. If any of the I3C Targets on the I3C Bus support the Group Address feature, then the Active Controller shall assign the desired Group Address(es) to the desired I3C Targets via the SETGRPA CCC.

The act of assigning a Group Address to a Target includes that Target in the indicated Group (i.e., as a member).

If the Active Controller wishes to have multiple Groups, then it would continue to issue the SETGRPA CCC for as many additional times as needed to complete configuration of the desired Groups. An I3C Target capable of belonging to multiple Groups can be included in as many Groups as the Target is capable of supporting, if the Active Controller so desires.

- 1695     3. After the Active Controller assigns Group Addresses, the Active Controller shall use the  
1696        DEFTGTS CCC to inform any Secondary Controllers about the Dynamic Addresses and Group  
1697        Address(es) that were assigned.  
1698     4. If any Secondary Controllers support Group Addressing, then the Active Controller shall use the  
1699        DEFGRPA CCC to inform them about the Group memberships that were assigned.
- 1700     If the Active Controller detects the disconnection of any I3C Devices from the I3C Bus, then the Active  
1701        Controller shall execute step 4 of the above procedure.
- 1702     The Active Controller could use the RSTGRPA CCC to manage Group membership of Targets, and to modify  
1703        the existing Groups, or reset all Groups and Group Addresses.
- 1704     In addition to resetting the Target's Dynamic Address, the RSTDAA CCC shall also reset all of the Target's  
1705        Group Addresses if the Target supports the Group Address function.
- 1706     Group Addresses may also be used for write transactions that use Multi-Lane formatting, if supported by all  
1707        Targets assigned to a Group Address (see **Section 5.3.1.1.1**).
- 1708     If an I3C Target supports the Group Address feature, and is presented by a composite Device that presents  
1709        multiple Virtual Targets on the I3C Bus using shared Peripheral logic (per **Section 5.1.2.1.2**) then each Virtual  
1710        Target shall report its Group Address capabilities using the GETCAPS CCC. Each such Virtual Target may  
1711        optionally support multiple Groups, and the Device shall store all assigned Group Addresses for each Virtual  
1712        Target. The Controller may assign any or all such Virtual Targets to as many Groups as each Virtual Target is  
1713        capable of supporting, if the Active Controller so desires. The Device's shared Peripheral logic shall match  
1714        incoming Private Write transfers addressed to any such Group Addresses, and deliver them internally to  
1715        appropriate logic for each Virtual Target function that has been assigned to that Group Address.

### 5.1.5 Hot-Join Mechanism

The I3C protocol supports a Hot-Join mechanism, to allow Targets to join the I3C Bus after it is already configured.

**Note:**

*Hot-Join does not allow Targets to join the I3C Bus before the I3C Bus has been configured.*

Hot-Join may be used for:

- I3C Devices mounted on the same board, but de-powered until needed. Such Devices shall not violate electrical limits for Targets when de-powered (or while transitioning) as defined in **Section 6**, including capacitive load.
- I3C Devices mounted on a module/board that is physically inserted after the I3C Bus has already been configured. This specification does not attempt to address how that physical insertion is handled, however such insertion shall not disrupt the SCL and SDA lines, including respecting all electrical limits defined in **Section 6**.

Hot-Joining Devices (i.e., Hot-Joining Targets) may include any valid Device type that supports the I3C Target role, such as a Secondary Controller. After a Hot-Join, the Active Controller shall use the **DEFTGTS** CCC as described in **Section 5.1.9.3.7**. To ensure that any Secondary Controllers are aware of all of the available Targets, the Controller shall immediately notify the I3C Bus if it discovers that any previously joined Targets are no longer present on the Bus (e.g., due either to non-response, or to mechanisms outside of the Bus).

#### Flow and Procedure

Since the Controller is not inherently aware when new Targets join the I3C Bus, the Hot-Join mechanism provides the following procedure for informing the Controller about new Targets. Each Target shall determine its eligibility to emit the special Hot-Join Request on the I3C Bus, per the method that it supports.

1. As each Target connects to the I3C Bus, and when the Target determines that it is eligible to do so (per the Target Hot-Join Requirements below), the Target shall issue an In-Band Interrupt using the reserved Target Address (i.e., 7'h02) as an IBI, using W (write) after the START.

This is a Hot-Join Request, and the Target shall issue this request at the appropriate time, based on whether it is using the standard Hot-Join method (i.e., based on the Bus Idle Condition) or a passive Hot-Join method (i.e., waiting for an SDR Frame ending with a STOP, per **Section 5.1.5.3**).

**Note:**

*Unlike a typical In-Band Interrupt request, a Hot-Join Request does not have a data payload or a Mandatory Data Byte.*

This requests a Dynamic Address Assignment process using the ENTDAAC CCC (see **Section 5.1.4.2**).

- 1750 2. The Active Controller shall either ACK the request, to indicate that it has seen the Hot-Join and  
1751 will assign a Dynamic Address at some point in the future; or NACK the request to reject the Hot-  
1752 Join and defer processing.
- 1753 a. If the Active Controller NACKs the request, then the Target attempting to Hot-Join shall try  
1754 again, following the I3C Target Interrupt Request procedure (see **Section 5.1.6.2**).  
1755 b. If the Active Controller ACKs the request, then the Target knows that the Hot-Join was  
1756 accepted, and it shall wait for the Active Controller to initiate the Dynamic Address  
1757 Assignment procedure with ENTDAA (see **Section 5.1.4.2**). Once the Target has seen the  
1758 ACK of the Hot-Join Request, it shall **not** send another Hot-Join Request.  
1759 c. The Active Controller may choose to issue a Broadcast CCC to disable Hot-Join by setting the  
1760 DISHJ bit in the Command Code **Disable Target Events Command** (DISEC, see  
1761 **Section 5.1.9.3.1**). The Active Controller may do so after either a NACK or an ACK of the  
1762 Hot-Join Request, although this typically happens after a NACK. If another Target attempts to  
1763 Hot-Join before the Controller is ready to assign Dynamic Addresses to the Targets, then the  
1764 Controller might need to repeat this procedure.  
1765 d. Likewise, the Active Controller may choose to re-enable Hot-Join at a later time (i.e., after  
1766 using the DISEC CCC with DISHJ bit set, to disable Hot-Join). To do this, the Active  
1767 Controller may issue a Broadcast CCC to enable Hot-Join by setting the ENHJ bit in the  
1768 Command Code **Enable Target Events Command** (ENEC, see **Section 5.1.9.3.1**).  
1769 If any Hot-Joining Targets had previously received the DISEC CCC with DISHJ bit set,  
1770 then such Targets may choose to re-send the Hot-Join Request after receiving the ENEC  
1771 CCC with ENHJ bit set.
- 1772 3. The Active Controller should eventually issue a Broadcast Command Code **Enter Dynamic**  
1773 **Address Assignment** (ENTDAA, see **Section 5.1.9.3.4**) to start the Dynamic Address Assignment  
1774 process. Since only eligible Targets with no Dynamic Address shall participate, this allows the  
1775 newly joined Target to receive its Dynamic Address.
- 1776 a. If the Active Controller has limited capabilities (e.g., is a reduced functionality Secondary  
1777 Controller Device, per **Section 5.1.7.3.4**), then it may choose to not process the Hot-Join  
1778 Request, by using the NACK followed by the DISEC CCC (as listed above), and then it may  
1779 pass the Controller Role to a more capable Controller (per **Section 5.1.7.3.6**) at a later time.  
1780 b. A Target that supports Hot-Join (either via the standard method, or the passive method per  
1781 **Section 5.1.5.3**) is eligible to participate in Dynamic Address Assignment if and only if it has  
1782 issued the Hot-Join Request (i.e., using the reserved Target Address, 7'h02).

1783 **Note:**

1784 *Controller ACK in a Hot-Join Request does not imply that the Dynamic Address Assignment*  
1785 *will necessarily start immediately. The Controller may wait for a potentially prolonged period*  
1786 *before issuing the ENTDAA CCC.*

1787 **Note:**

1788 *Hot-Join is only compatible with ENTDAA. Targets that do not support ENTDAA shall not*  
1789 *use Hot-Join.*

1790 If an **Enter Dynamic Address Assignment (ENTDAA)** Command Code is issued as  
1791 described in **Section 5.1.9.3.4**, then the Target shall transmit its 48-bit Provisioned ID per  
1792 the normal mechanism. Hot-Join Targets required to receive the same assigned Dynamic  
1793 Address every time they join can use a fixed-value ID, per **Section 5.1.4.1.1**.

1794 **Figure 171** in **Annex C** illustrates the Hot-Join flow, for both standard and passive Hot-Joining Targets. This  
1795 flow diagram is strictly informative and does not provide every possible combination of paths.

If a Target drops off the I3C Bus due to being detached or depowered, then the Controller might not be aware of this. The Controller may determine this condition by repeated attempts to contact the Target using a safe Command Code (i.e., a CCC that the Target is required to always respond to), such as **Get Device Status** (GETSTATUS, see *Section 5.1.9.3.15*). If the Controller determines that the Target is no longer part of the I3C Bus, then it shall either recycle that Target's Dynamic Address, or else reserve that Target's Dynamic Address in case that Target later re-joins the Bus.

**Note:**

*If the Controller's first attempt to emit the first I3C Address Header (i.e., emitted slowly to allow for I3C Targets to disable Spike Filters) is converted into a Hot-Join, then the Controller needs to ACK it, then emit STOP and attempt to emit the I3C Address Header again, per **Section 5.1.2.1.1**.*

*A Hot-Joining Target may power-up at the same time as the Primary Controller (e.g., may be connected to the I3C Bus when power is applied to the system). In that case, the Hot-Joining Target might pull SDA Low even before the I3C Bus has been started, assuming that SCL and SDA are being pulled up. If a Primary Controller needs 1 ms or more in order to start acting on the I3C Bus, then that Primary Controller shall tolerate the situation of SDA being held Low when it is ready to initialize the I3C Bus, or it may hold SDA and/or SCL Low until ready, keeping the Hot-Joining Target from seeing the Bus Idle Condition.*

*Hot-Joining Targets should implement some method that allows the system designer to prevent the Device from attempting to Hot-Join when the Device is not being used as a Hot-Joining Target. For example: either NVMEM or a pin strap could be used when such a Device is soldered onto the board and powered with the rest of the I3C Bus.*

**Target Hot-Join Requirements**

A Hot-Joining Target (i.e., a Hot-Joining Device attempting to join with active Target role) should be 'single-minded' in nature, focusing exclusively on emitting the Hot-Join Request, until the Active Controller either ACKs the request (thereby indicating that it will eventually start the process of Dynamic Address Assignment) or NACKs the request (thereby indicating that the Target should continue providing Hot-Join Requests until the Active Controller either ACKs such a request, or sends the Broadcast DISEC CCC to disable Hot-Join, as mentioned above).

1. The first time the Hot-Joining Target connects to the I3C Bus, the Target shall wait for the appropriate opportunity to send the Hot-Join Request, based on its eligibility:
  - a. A Hot-Joining Target using the standard method shall become eligible after waiting for a period of at least Bus Idle Condition ( $t_{IDLE}$ , see *Table 86*) and ensuring that the Bus remains Idle (i.e., that SDA and SCL are both High per *Section 5.1.3.2.3*).
  - b. A Hot-Joining Target using a passive method shall follow the conditions of eligibility defined in *Section 5.1.5.3*.

If multiple Hot-Joining Targets become eligible at the same time, then they could all attempt to emit the Hot-Join Request together (i.e., at the same time). This could apply to Hot-Joining Targets using any combination of standard or passive Hot-Join methods.

2. The Hot-Joining Target shall, when eligible, send the Hot-Join Request on the I3C Bus, following a START.
  - a. The Hot-Join Request is an IBI from the reserved Target Address (i.e., 7'h02), with the RnW bit Low (i.e., Write).
  - b. The Target shall send the Hot-Join Request, by either waiting for a START, or requesting a START by pulling SDA Low (for the standard method only). After the START, the Target shall drive the Address of 7'h02 / W into the Arbitrable Address Header.

**Note:**

*To issue a START, a Hot-Joining Target using the standard method must pull SDA Low; the Target shall then wait for the Controller to drive SCL Low. This applies to the standard Hot-Joining method only; a passive Hot-Joining Target that does not have a timer must wait for another Device to drive a START Request, per *Section 5.1.5.3*.*

1846           *In the case where multiple Hot-Joining Targets successfully emit the Hot-Join Request at the*  
1847           *same time, it would not be necessary for each of these eligible Targets to emit separate Hot-*  
1848           *Join Requests in succession with delays between each request. If a Hot-Join Request was*  
1849           *successfully emitted, and if the Active Controller responds to that Hot-Join Request, then*  
1850           *each such Target shall participate in a subsequent Dynamic Address Assignment procedure*  
1851           *with ENTDAA that would be initiated by the Active Controller.*

- 1852       c. The Target shall watch for the Active Controller to either ACK or NACK the Hot-Join  
1853           Request.
- 1854       3. The Hot-Joining Target shall conditionally continue sending the Hot-Join Request on each  
1855           subsequent START (i.e., at the next appropriate opportunity) until and unless the Active Controller  
1856           provides an ACK for the Hot-Join Request.
- 1857           Once such an eligible Target sees the Active Controller ACK the Hot-Join Request (i.e., one that it  
1858           initiates or that it is eligible to initiate, per step 1), then it shall stop sending further Hot-Join  
1859           Requests.
- 1860       4. Once the Hot-Joining Target sees the Active Controller ACK or NACK the Hot-Join Request, it  
1861           shall follow all normative requirements for the Role of an I3C Target per **Section 5.1.2.1** (i.e., one  
1862           that has not yet received its Dynamic Address).

1863       **Note:**

1864           *A Hot-Joining Target that uses the standard Hot-Join method (i.e., based on the Bus Idle*  
1865           *Condition) shall not follow these normative requirements (i.e., as a Target that has not yet*  
1866           *received its Dynamic Address) until and unless it emits the first Hot-Join Request, and then*  
1867           *receives an ACK or NACK from the Active Controller. This is because the Bus Idle Condition is*  
1868           *related to the minimum time necessary to determine that the Bus is free and not in any HDR Mode*  
1869           *(i.e., no transfer is in progress).*

- 1870       a. This shall include receiving and appropriately processing all required Broadcast CCCs.
- 1871       b. This may also include the Broadcast ENEC CCC with the ENHJ bit set, if the Target chooses  
1872           to support re-sending Hot-Join Requests as a response to this Broadcast CCC, and if it  
1873           previously received the Broadcast DISEC CCC with the DISHJ bit set. Note that this shall not  
1874           affect whether the Target supports (or remains ready to respond to) the Broadcast ENTDAA  
1875           CCC.
- 1876       c. The Target shall also remember that it has seen an ACK/NACK response to at least one  
1877           Hot-Join Request, and it shall remain ready to respond to the Broadcast ENTDAA CCC for  
1878           subsequent Dynamic Address Assignment. Note that this may follow immediately after any of  
1879           the following:
- 1880           i. An ACK or a NACK, followed by a Repeated START;
- 1881           ii. A STOP, followed by a delay (i.e., Bus Free Condition, or longer); or
- 1882           iii. A Repeated START that is followed by other valid Bus traffic, such as Private Reads,  
1883           Private Writes, and/or other CCCs.

1884       **Note:**

1885           *Once the Target has emitted the Hot-Join Request, the Target shall remain ready to respond to the*  
1886           *Broadcast ENTDAA CCC, even if it sees a NACK to a Hot-Join Request, or a NACK followed by the*  
1887           *Broadcast DISEC CCC with the DISHJ bit set.*

1888           *If a Hot-Joining Target has not yet emitted the Hot-Join request, then it shall not be eligible to*  
1889           *participate in Dynamic Address Assignment with the ENTDAA CCC.*

1890           *A Hot-Join Request shall always follow a START, which means that this uses an Arbitrable Address*  
1891           *Header. Hot-Joining Targets should attempt to arbitrate the reserved Target Address (i.e., 7'h02), per*  
1892           *the conditions of eligibility to emit the Hot-Join Request (i.e., standard vs. passive Hot-Join method).*

1893           *Since this reserved Target Address has a very low value, it will almost always have higher priority*  
1894           *over other I3C Target Addresses, which means it is very likely to win Arbitration.*

### 5.1.5.1 Failsafe Device Pads

Hot-Joining Devices shall be Failsafe, unless there is a protection method outside of the pad. Failsafe means that when the SCL and SDA pads are unpowered but wire-connected to the I3C Bus, they must not draw extra leakage current from the Bus.

The Device SCL and SDA pads shall be designed so as to avoid drawing current from the system SCL and SDA lines, both when they are being held High and when they are being held Low. Such leakage may be avoided by using special connectors, or other isolation methods (e.g., physical connection order in a plug). This excess current should be avoided whether due to diode effect, rail tie for ESD, or clamps. The leakage current variation between unpowered and powered shall not exceed the normal variation range of an active pad,  $I_i$ , as specified in *Section 6, Table 82*.

### 5.1.5.2 Legacy I<sup>2</sup>C Buses and Hot-Join

Hot-Join is not compatible with Legacy I<sup>2</sup>C. A Target shall not attempt a Hot-Join when on a Legacy I<sup>2</sup>C Bus. This may be accomplished, with a Hot-Join capable Target, in one of two ways:

1. The Target may use a pin or NVMEM to allow the system designer to turn the feature off when it is not appropriate for the system, as noted in *Section 5.1.5*.
2. The Target may use a passive Hot-Join method per *Section 5.1.5.3*. This prevents it trying to Hot-Join until it is sure it is on an I3C Bus.

### 5.1.5.3 Passive Hot-Join

The passive Hot-Join method works the same basic way as outlined in **Section 5.1.5**, except with a modification to the conditions of eligibility for a Hot-Joining Target.

A standard Hot-Joining Target must first wait for at least the Bus Idle Condition, and then it may pull SDA Low, or it may wait for a START. A passive Hot-Joining Target will first wait for an SDR Frame ending in STOP, and then wait for the next START, which must be issued by either the Active Controller or any other Target that can request a START. This ensures that the Target is on an I3C Bus.

Since a passive Hot-Joining Target does not necessarily have an internal timer that would otherwise be used to wait for the Bus Idle Condition, it must clearly recognize a START that another Device might issue (i.e., as opposed to a Repeated START).

In practice, this means that a passive Hot-Joining Target will:

**Either:**

- Wait for at least Bus Free Condition, if the Active Controller issues the next START (i.e., for the next I3C transaction in SDR Mode);

**Or:**

- Wait for at least Bus Available Condition, if another Target issues the next START (i.e., for an In-Band Interrupt Request or a Controller Role Request).

Once a passive Hot-Joining Target recognizes the next START, it shall then issue the Hot-Join Address (i.e., the reserved Target Address, 7'h02) into the Arbitrable Address Header to emit its Hot-Join Request, in the same manner as a standard Hot-Joining Target.

**Note:**

*Because a passive Hot-Join Target waits for a recognizable I3C Address Header, on some Buses this could lead to a long delay before the Target is in fact Hot-Joined to the Bus.*

*A Hot-Joining Target that uses such a passive Hot-Join method should still follow all normative requirements for the Role of an I3C Target in **Section 5.1.2.1** (i.e., one that has not yet received its Dynamic Address), since it would have already seen an SDR Frame ending in STOP. In this case, such a Target should also process any Broadcast CCCs that it might receive before it emits the Hot-Join Request (such as ENEC/DISEC), except for the ENTDAA CCC since it would not be eligible to participate in Dynamic Address Assignment before it emits the Hot-Join Request.*

*If a Hot-Joining Target supports both the passive and standard Hot-Join methods, then it may use either method or both methods to emit the Hot-Join Request. For example, such a Target may opportunistically attempt to use a passive Hot-Join method if it clearly recognizes a START that another Device has issued; or it may wait for at least the Bus Idle Condition and then issue its own START, if the Bus remains Idle and no other Devices have issued a START during that period.*

### 5.1.6 In-Band Interrupt

1943 This Section specifies I3C's priority-based In-Band Interrupt mechanism.

#### 5.1.6.1 Priority Level

1944 In I3C, Priority Level controls the order in which In-Band Interrupt requests and Controller Role Requests  
1945 from I3C Targets are processed. The Priority Level of each Target (or Secondary Controller) in an I3C Bus  
1946 instantiation is encoded in its Address, with lower Addresses having higher Priority. That is, Targets with  
1947 lower value Addresses and higher Priority Levels have their In-Band Interrupts and Controller Role Requests  
1948 processed sooner than Targets with higher value Addresses and lower Priority Levels. This Priority Level  
1949 ordering is a natural outcome of the I3C Address Arbitration behavior specified at **Section 5.1.2.2.1**, where  
1950 Address bits with value 0 prevail over bits with value 1.

1951 As a result, during each Dynamic Address Assignment operation (see **Section 5.1.4**) the Active Controller  
1952 should assign lower Addresses to Targets for higher Priority In-Band Interrupt requests.

#### 5.1.6.2 I3C Target Interrupt Request

1953 In order to request an interrupt, an I3C Target shall emit its Address into the arbitrated Address header  
1954 following a START (but not following a Repeated START). If no START is forthcoming within the Bus  
1955 Available Condition, then the I3C Target may issue a START by pulling the SDA line Low, and then wait for  
1956 the Active Controller to pull the SCL Low.

1957 If the Active Controller sets the SCL line Low, thus completing the START, and then provides clocks on the  
1958 SCL line, then the Target shall drive the SDA line with its own Address, followed by an RnW bit with value  
1959 1'b1. If more than one Target has issued an IBI request after the same START, then the Active Controller  
1960 shall process those IBIs in Priority Level order, per **Section 5.1.6.1**. The Target(s) that lost the Arbitration  
1961 may issue another IBI request, but shall not do so until after the Bus Available Condition.

1962 At that point, the Active Controller shall perform one of the following three actions:

1963 **Either:**

- 1964 1. Accept the IBI by providing the ACK bit. The actions available to the Active Controller depend  
1965 upon the value of the Target's BCR[2] bit (in the Target's BCR register):
  - 1966 a. If the I3C Target's BCR[2] bit is set to 1, then per **Section 5.1.1.2.1** the Active Controller shall  
1967 read the Mandatory Data Byte that follows the accepted IBI request at any 'read' clock speed  
1968 allowable by the Target. This operation is similar to a 'read' from the Target and all the related  
1969 rules apply. Note that the Active Controller cannot avoid receiving the Mandatory Data Byte,  
1970 since it is transmitted in Push-Pull mode.

1971 After sending the Mandatory Data Byte, the Target may optionally send (i.e., or not send)  
1972 additional IBI data bytes, up to the IBI payload size limit per **Section 5.1.9.3.6** (the  
1973 **Set/Get Max Read Length** CCC). If the Target sends any such additional IBI data bytes,  
1974 then the Active Controller may either accept or terminate them, depending upon (a) any  
1975 private contract between Controller and Target regarding the meaning of these bytes, and  
1976 (b) the Controller's current willingness and/or ability to take them. After the Target sends  
1977 any such additional IBI data bytes, the Active Controller may issue either a STOP, or a  
1978 Repeated START, per the normal I3C protocol.

1979 If the Active Controller completes this transfer before all additional Data Bytes are read,  
1980 then the Target shall not repeat the as-yet unserviced IBI request; the Active Controller  
1981 has assessed the request, and will service it at a later time. Depending upon the character  
1982 of the data, the Controller can either:

- 1983 i. Attempt to read either the full data (e.g., for short data packets), or
- 1984 ii. Continue from the position at which the transfer was interrupted (e.g., for FIFO  
1985 transfers), or

1986                   iii. Abort the IBI service (e.g., for Timing Control information).

1987                   In all cases the specific follow-up actions shall be established by private contract between  
 1988                   the Devices, bearing in mind the possibility for data to be corrupted in the meantime.

1989                   One conceptual time diagram of this sequence is shown in ***Figure 26***.

| Open Drain | Open Drain           | Open Drain     | Hand Off | Push-Pull   | Drive High or Low, and then High-Z | Push-Pull |
|------------|----------------------|----------------|----------|-------------|------------------------------------|-----------|
| S          | Target_addr_as_IBI/R | Controller_ACK | SCL High | Target_byte | T                                  | Sr        |

1990                   **Figure 26 IBI Sequence with Mandatory Data Byte**

- 1991                   b. If the I3C Target's BCR[2] bit is set to 0, then the Active Controller may take any other valid  
 1992                   I3C action to terminate the frame after providing the ACK bit; i.e., issue either a STOP or a  
 1993                   Repeated START.

1994                   **Or:**

- 1995                   2. Refuse the IBI without disabling interrupts. To do this the Active Controller simply passively  
 1996                   NACKs, thus denying the IBI. The Target will normally try again after the next Bus Available  
 1997                   Condition, or on the next START.

1998                   **Or:**

- 1999                   3. Refuse the IBI and disable interrupts. To do this, the Active Controller NACKs to deny the IBI,  
 2000                   then sends a Repeated START, and finally sets the DISINT bit in the Command Code **Disable**  
 2001                   **Target Events Command (DISEC)** to the interrupting Target as described in ***Section 5.1.9.3.1***.  
 2002                   (The Active Controller can set the ENINT bit in the Command Code **Enable Target Events**  
 2003                   **Command (DISEC)** at a later time.)

2004                   In cases where the Active Controller anticipates that the I3C Bus might be needed for a higher Priority Level  
 2005                   transaction before the newly requested transaction would complete, the Active Controller could either deny  
 2006                   the access (by not acknowledging the request), or else drive the higher-priority Device Address instead of the  
 2007                   Address of the Device sending the IBI request. The Active Controller would then hold the SCL line Low until  
 2008                   the expected higher-priority transaction begins.

2009                   Bus contention occurs during Address evaluation. As a result, if multiple I3C Devices simultaneously attempt  
 2010                   to win the Bus, then all but one will lose the Arbitration. These Devices will have the opportunity, but are not  
 2011                   required, to repeat the attempt upon the next Bus Available Condition. Note that Target Devices have the  
 2012                   option to choose to not try again.

### 5.1.6.2.1 Mandatory Data Byte

The Mandatory Data Byte of the IBI payload is the data that follows the Dynamic Address when a Device sends an IBI request. The availability of a Mandatory Data Byte, together with the payload information that follows it, is indicated by bit BCR[2] in the Bus Characteristics Register (see [Section 5.1.1.2.1](#)).

It is called a Mandatory Data Byte because the Target Device takes over the line when the Controller ACKs the IBI request and the Target continues to send data; the Controller cannot decline the reception of the first byte, and must wait for the T-Bit to terminate any subsequent data.

The Mandatory Data Byte provides the Controller additional information about the event that has happened, and is divided in two fields as shown in [Table 12](#):

- **Interrupt Group Identifier:** The three most significant bits: MDB[7:5]

Values for the Interrupt Group Identifier are defined by MIPI Alliance I3C WG for different use cases.

- **Specific Interrupt Identifier:** The five least significant bits: MDB[4:0]

MIPI Alliance maintains a web-based registry of defined MDB values ([MIPI05](#)).

**Table 12 Mandatory Data Byte Field Format**

| Interrupt Group Identifier Field |        |        | Specific Interrupt Identifier Field |        |        |        |        |
|----------------------------------|--------|--------|-------------------------------------|--------|--------|--------|--------|
| MDB[7]                           | MDB[6] | MDB[5] | MDB[4]                              | MDB[3] | MDB[2] | MDB[1] | MDB[0] |

2027

**Table 13 Mandatory Data Byte Value Ranges**

| MDB Category                     | Interrupt Group Identifier | Specific Interrupt Identifier Value |                                                               | Description                                                                                                                                                                                                                                               |
|----------------------------------|----------------------------|-------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | MDB[7:5]                   | MDB[4:0]                            |                                                               |                                                                                                                                                                                                                                                           |
| <b>User Defined</b>              | 3'b000                     | 5'h00 – 5'h1F                       | <b>Vendor Reserved</b>                                        | Defined by the vendor and reserved for vendor definition                                                                                                                                                                                                  |
| <b>I3C WG</b>                    | 3'b001                     | 5'h00 – 5'h0C                       | MIPI Alliance I3C WG Reserved                                 | Defined and interpreted based on some reserved values allocated by MIPI Alliance I3C WG.<br>Indicates that the interrupt is related to a specific functionality.                                                                                          |
|                                  |                            | 5'h0D                               | <b>Error with additional data bytes in IBI payload</b>        |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h0E                               | <b>Generic error, no additional data bytes in IBI payload</b> |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h0F – 5'h11                       | MIPI Alliance I3C WG Reserved                                 |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h12                               | <b>Monitoring Devices Interrupt Enabling</b>                  |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h13 – 5'h16                       | MIPI Alliance I3C WG Reserved                                 |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h17                               | <b>D2DT Identifier</b>                                        |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h18 – 5'h1F                       | MIPI Alliance I3C WG Reserved                                 |                                                                                                                                                                                                                                                           |
| <b>MIPI Groups</b>               | 3'b010                     | 5'h00 – 5'h01                       | MIPI Alliance Camera WG Reserved                              | Allocated and reserved by MIPI Alliance Working Groups, and approved by MIPI Alliance I3C WG.<br>Indicates that the interrupt is generated by a Device that wants to send a specific MIPI Alliance WG-related interrupt (e.g., Camera WG or Debug WG)     |
|                                  |                            | 5'h02 – 5'h1B                       | MIPI Alliance Reserved                                        |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h1C – 5'h1D                       | <b>MIPI Alliance Debug WG Reserved</b>                        |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h1E – 5'h1F                       | MIPI Alliance Reserved                                        |                                                                                                                                                                                                                                                           |
| <b>Non MIPI Reserved</b>         | 3'b011                     | 5'h00 – 5'h1F                       | <b>Non MIPI Reserved</b>                                      | Allocated for uses outside of MIPI Alliance                                                                                                                                                                                                               |
| <b>Timing Information</b>        | 3'b100                     | 5'h00 – 5'h1F                       | <b>Vendor Reserved</b>                                        | May have any value defined by the vendor                                                                                                                                                                                                                  |
| <b>Pending Read Notification</b> | 3'b101                     | 5'h00 – 5'h0C                       | MIPI Alliance I3C WG Reserved                                 | Indicates that the interrupt is generated by a Device that wants to send a specific MIPI Alliance WG-related or vendor-specific interrupt, and has a data message that will be returned on the next Private Read if ACKed (see <b>Section 5.1.6.2.2</b> ) |
|                                  |                            | 5'h0D                               | <b>MIPI Alliance Debug WG Reserved</b>                        |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h0E                               | <b>MCTP Packet (for DMTF [MCTP01])</b>                        |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h0F                               | MIPI Alliance I3C WG Reserved                                 |                                                                                                                                                                                                                                                           |
|                                  |                            | 5'h10 – 5'h1F                       | <b>Vendor Reserved</b>                                        |                                                                                                                                                                                                                                                           |
| Reserved                         | 3'b110                     | —                                   | —                                                             | Reserved                                                                                                                                                                                                                                                  |
| Reserved                         | 3'b111                     | —                                   | —                                                             | Reserved                                                                                                                                                                                                                                                  |

### 5.1.6.2.2 Pending Read Notification

Target Devices that support In-Band Interrupt requests may also implement support for a particular Pending Read Notification contract, by which they may inform the Controller that there is data to be read for a specific purpose. Such a Target that expects that the Controller should also support this contract shall indicate its support by returning a value of 1'b1 in bit 6 of GETCAP3 byte (the third returned data byte, when the GETCAPS Format 1 CCC is sent (see [Section 5.1.9.3.19](#))).

To signal a Pending Read Notification, the Target shall send an IBI with a Mandatory Data Byte value (see [Section 5.1.6.2.1](#)) for which the first three bits (i.e., Interrupt Group Identifier) matches 3'b101. The remaining five bits in the Mandatory Data Byte value (i.e., the Specific Interrupt Identifier) may be specific for a particular type of Target, as assigned by MIPI Alliance I3C WG, or it may be any other value in the region reserved for a Vendor device.

If the Controller accepts the IBI and reads the Mandatory Data Byte from the Target, then it shall signal acceptance of the Controller's obligation to read the data, per this contract. The Target shall note that the MDB has been read, and treat the Pending Read Notification as active: i.e., it shall make the data available on the next Private Read request received from the Controller. However, if the Controller terminates the IBI before reading the MDB, or if the Controller NACKs the IBI, then it shall not signal acceptance, and the Target may try again at a later time.

The Controller should also read any additional data bytes as part of the IBI payload (see [Section 5.1.6.2](#)), as the Target may add additional bytes specific to the type of Target or its function (per the Specific Interrupt Identifier) to provide context or further describe or classify the data that the Target will return on the next Private Read request. If present, the format and length of any additional bytes in the IBI payload shall depend on the Specific Interrupt Identifier.

Once the IBI and its MDB has been serviced and accepted, the Controller is obligated to initiate a subsequent Private Read request to the Target, to read the data that has been made available and ready for this Private Read request. The Controller may do this immediately after the IBI has been serviced, or it may do this at a later time. However, the Controller should initiate this Private Read request before taking any actions that would either reset the Target Device (thereby causing the data to be lost), or before any other queued commands or actions initiated by its Host can initiate a Private Read for another purpose (thereby reading the data and associating it with another transaction). The Controller may queue up several Private Read Notifications from multiple Targets and process them in any order.

The Private Read request may be done in SDR Mode, or in any supported HDR Mode using any HDR Read command value specific to that HDR Mode. The choice of whether to use an HDR Mode may be a private contract between the Controller and the Target, or it may be indicated in the Specific Interrupt Identifier or any additional data bytes in the IBI payload.

**Note:**

*If the Target also supports any HDR Modes, then the Target may choose to support certain HDR Read command values for the active Pending Read Notification, by private contract or by assignment. The Target may also continue to support HDR Reads for other purposes, using other HDR Read command values, while it waits for the Controller to initiate the HDR Read for the active Pending Read Notification.*

Once the Controller has initiated the Private Read request, it should read the data from the Target, queue it for processing or transfer to its Host, and retain the association of the data with the IBI notification, including the specific MDB value as well as any additional bytes in the IBI payload.

2070 A Target may hold only one active Pending Read Notification at any time, while it is waiting for the Controller  
2071 to read the data:

- 2072 • While the Target is waiting for the Controller to initiate a Private Read request for its active  
2073 Pending Read Notification, it shall not send an IBI with a Mandatory Data Byte value to indicate  
2074 another Pending Read Notification until after the Controller has initiated the expected Private  
2075 Read request to consume the data for the active Pending Read Notification.
- 2076 • However, the Target may send an IBI with another Mandatory Data Byte value (i.e., one that does  
2077 not signal a Pending Read Notification) for other reasons, such as reporting error conditions or  
2078 other types of interrupt events.
- 2079 • If the Controller has serviced and accepted the IBI and its MDB, but has not initiated the expected  
2080 Private Read request in a timely manner, then the Target may re-transmit the IBI with the same  
2081 MDB (with additional data bytes, as described above) as a reminder.
  - 2082 • The Controller need not initiate multiple Private Read requests (i.e., one for each additional  
2083 IBI with MDB for a Pending Read Notification); the most recent IBI shall be the notification  
2084 to consume the data for the active Pending Read Notification.
  - 2085 • However, if the Controller does initiate additional Private Read requests due to additional IBIs  
2086 as reminders, then the Target shall not accept such requests.
- 2087 • The Target shall keep the data available for the Controller, to satisfy the expected Private Read  
2088 request, unless it encounters an error (e.g., due to delayed read or other conditions).
  - 2089 • If the Target encounters an error or is unable to return the data, then it shall not accept the  
2090 Private Read request (i.e., the Target shall NACK the read), and should also report this as an  
2091 error (i.e., an IBI with another MDB value).

2092 By default, a Target should not attempt to send an IBI with a Mandatory Data Byte value to indicate a Pending  
2093 Read Notification until it has been enabled to do so by the Controller.

2094 **Note:**

2095 *The method for configuring a Target to enable or disable IBIs with Pending Read Notifications is not*  
2096 *defined by the I3C Basic Specification. This method might be a private contract between the*  
2097 *Controller and the Target, or it might be defined for specific assigned MDB values in **Table 13** (i.e.,*  
2098 *with Interrupt Group Identifier value of 3'b101).*

### 5.1.6.3 I3C Secondary Controller Requests to be Active Controller

When the I3C Secondary Controller requests to be an Active Controller:

1. To perform the request, the I3C Secondary Controller shall wait for either a START (not a Repeated START), or a Bus Available Condition and issue its own START.
2. After a START, the I3C Secondary Controller shall issue its own Dynamic Address on the I3C Bus, followed by the RnW bit of 0 to request to become Active Controller.
3. If the I3C Secondary Controller wins the Arbitration by having the lower Dynamic Address, and if the Active Controller is currently willing to relinquish the Controller Role to the requester, then the Active Controller shall respond with ACK.

**Figure 172** shows the Controller Role Request flow if the Secondary Controller wins the Arbitration. Any Controller-capable Device shall use this flow to request the Controller Role, including when a former Active Controller needs to regain the Controller Role after acting as a Target.

After acknowledging the Controller Role Request, the Active Controller should prepare for Handoff in a timely manner (*see Section 5.1.7.1*). The Secondary Controller should also remain ready to accept the Controller Role (i.e., not transition into a lower-power mode or a “deep sleep” state) and respond to all relevant CCCs that the Active Controller may use, as part of the process of preparing for Handoff. **Section 5.1.7.2** specifies the process for passing the Controller Role.

### 5.1.6.4 I3C Active Controller Initiating a Transaction

In order to ensure that any other I3C Device can initiate a Target Interrupt Request or a Controller Role Request, the I3C Active Controller may choose to initiate new Frames with a START (not a Repeated START) followed by the I3C Broadcast Address (7'h7E). This allows another Device to emit its Address into the arbitrated Address header, when the Bus would otherwise be busy and a Device might not be able to wait for the minimum Bus Available period to initiate its own START by pulling SDA Low.

If the other Device wins the Arbitration, then it may drive its IBI Request, and the Active Controller may either ACK or NACK the request. However if no other Device attempts to emit its Address into the arbitrated Address header, then the Active Controller may follow with a Repeated START, or any other valid Bus activity.

If the Active Controller instead drives the same Dynamic Address and RnW bit as a Target issuing an IBI or a Controller Role Request with its own Dynamic Address, then the Arbitration might not have a clear winner, and as a result a retry might be necessary in order to give the Target a chance to request an IBI or the Controller Role (*see Section 5.1.2.2.3*).

### 5.1.7 I3C Bus with Multiple Controllers

An I3C Bus may have multiple Controller-capable Devices, with varying capabilities and purposes. All Controller-capable Devices shall support the required Bus Management procedures while acting as Active Controller. Although only one I3C Controller-capable Device can act as Active Controller of the I3C Bus at any given time, the role of Active Controller may be passed between Controller-capable Devices, using the Controller to Controller Handoff Procedure (see *Section 5.1.7.2*). The state of a Controller-capable Device currently holding the role of Active Controller on the I3C Bus is referred to as the Controller Role.

At least one Controller-capable Device shall support the required Bus Configuration procedures for a Bus. A Secondary Controller may perform some of these Bus Configuration procedures, as documented in *Section 5.1.7.3* depending on the specific application for the I3C Bus and the intended use cases of the Secondary Controller. A Secondary Controller that cannot, or might not, perform all required Bus Configuration procedures should defer or pass the Controller Role to another suitable Controller-capable Device if it encounters a condition that it cannot or might not handle while acting as Active Controller.

Additionally, the Controller-capable Device that has the job of initializing the I3C Bus holds the special role of Primary Controller. A Primary Controller Device is, by definition, the first Controller-capable Device to hold the Active Controller role. The Primary Controller acts as the authority for the initial configuration of the Bus and all Devices, including any Legacy I<sup>2</sup>C Devices. Therefore, the Primary Controller must be capable of all required Bus Configuration procedures. However, once the Bus has been initialized and configured, the Primary Controller can also pass the Controller Role to any other Controller-capable Device currently acting as Secondary Controller.

Using the Handoff procedure, either multiple Controller-capable Devices can cooperatively pass the Controller Role back and forth, or else one Controller-capable Device can direct the flow of passing the Controller Role among other Controller-capable Devices according to the capabilities of any I3C Secondary Controllers on the Bus and the I3C Bus's particular application.

A Secondary Controller may request the Controller Role from the Active Controller using the Controller Role Request flow detailed in *Section 5.1.6.3*. Alternately, the Active Controller may choose a particular Secondary Controller to receive the Controller Role, even if that Secondary Controller did not request the Controller Role. In either case, the names Active Controller and Secondary Controller largely reflect the Controller-capable Device's current role at any given point in time.

After acknowledging a Controller Role Request or choosing a Secondary Controller to receive the Controller Role, the Active Controller should:

1. Prepare the Bus and the indicated Secondary Controller for Handoff (see *Section 5.1.7.1*);
2. Pass the Controller Role to the indicated Secondary Controller using the Controller to Controller Handoff Procedure (see *Section 5.1.7.2*); and
3. Monitor the Bus to ensure that the indicated Secondary Controller asserts its Controller Role (see *Section 5.1.10.2.4* on Error Type CE3).

The process for passing the Controller Role is the same in either direction: it is always initiated by the Active Controller (i.e., the Controller-capable Device holding the Controller Role at that point in time). In most cases the immediately previous Active Controller can request to receive the Controller Role back again, or the indicated Secondary Controller can automatically pass the Controller Role back once it has finished its tasks. However, in some Bus implementations it might be advisable to designate one Controller-capable Device to direct and manage the flow of passing the Controller Role to/from any Secondary Controllers.

While acting as Active Controller, a Secondary Controller may choose not to handle any Bus Configuration procedures. In some circumstances, a Secondary Controller might be intended for a limited purpose or scope on a particular I3C Bus, and as a result might limit its activities while serving as Active Controller to some subset of what it is capable of performing; for example, by not supporting Bus Configuration procedures.

### 5.1.7.1 Preparing for Handoff

It may be necessary for the Active Controller to issue one or more commands on the I3C Bus to prepare other I3C Target Devices for the Handoff and ensure an optimal transition of the Controller Role, irrespective of whether the handoff is due to a Secondary Controller requesting the Controller Role via a Controller Role Request, or is due to the Active Controller having simply chosen to pass the Controller Role to a particular Secondary Controller.

There are many possible variations of the steps that the Active Controller should take to prepare for a Handoff. **Figure 27** presents a generalized flow, and this Section provides a recommended procedure.



**Figure 27 Pre-Handoff Steps Flow**

2182 Recommended procedure:

- 2183 1. If the Active Controller intends to pass the Controller Role to a selected Secondary Controller that  
2184 did not send a Controller Role Request, then the Active Controller should verify that the selected  
2185 Secondary Controller is active and ready to respond to additional commands (see  
2186 **Section 5.1.9.3.15**, the GETSTATUS CCC).

2187 **Note:**

2188 *If the Secondary Controller responds to the GETSTATUS CCC and returns a value of 2'b11 in bits  
2189 7:6 (i.e., LSB) of the GETSTATUS Format 1 CCC (see **Table 27**), then this indicates that it is not  
2190 able to participate in any subsequent steps to prepare for Handoff. The Active Controller should  
2191 stop the procedure at this point, and may initiate an error recovery procedure.*

- 2192 2. If the Active Controller needs to disable Hot-Joins, Target Interrupt Requests, or other Bus events  
2193 that could interfere with the Handoff, then it should send the appropriate Broadcast or Direct  
2194 CCCs to disable those events before the Handoff (see **Section 5.1.9.3.1**, the ENEC/DISEC CCCs).

2195 **Note:**

2196 *Once the Handoff is complete, the new Active Controller should re-enable any events that are  
2197 disabled in this step.*

- 2198 3. If the Active Controller is Multi-Lane capable, and does not have knowledge that the selected  
2199 Secondary Controller supports and is configured to use the same Multi-Lane Modes and codings  
2200 that any Multi-Lane capable Target Devices have been configured to use, then the Active  
2201 Controller should re-configure the I3C Bus such that all Target Devices are configured to use an  
2202 ML Frame format that is known to be supported by the selected Secondary Controller (see  
2203 **Section 5.1.9.3.30**, the MLANE CCC).

2204 **Note:**

2205 *In some situations, ensuring maximum compatibility and preventing communication errors after  
2206 Handoff might require resetting these Multi-Lane capable Target Devices to basic 2-Wire I3C  
2207 Mode (i.e., 1-Lane).*

- 2208 4. If the Active Controller knows that the selected Secondary Controller must be put into a different  
2209 Activity State before Handoff, then the Active Controller shall send the appropriate Broadcast or  
2210 Direct CCCs to put the Bus (or selected Devices) into a different Activity State (see  
2211 **Section 5.1.9.3.18** regarding the GETMXDS CCC with optional Defining Byte, and  
2212 **Section 5.1.9.3.2**, the ENTASx CCCs).
- 2213 5. If the Active Controller determines that the indicated Secondary Controller has been in a “deep  
2214 sleep” state and may need to be re-synchronized with the most current list of I3C Targets and  
2215 Group Addresses, then the Active Controller should send the appropriate Broadcast CCCs (see  
2216 **Section 5.1.9.3.7**, the DEFTGTS CCC, and **Section 5.1.9.3.29**, the DEFGRPA CCC). Afterwards,  
2217 the Active Controller should poll the Secondary Controller to ensure that it has successfully  
2218 processed this data and indicates that it is ready to accept the Controller Role (see  
2219 **Section 5.1.9.3.15** regarding the GETSTATUS CCC with optional Defining Byte).

2220 While steps 2–4 can generally be performed in any order, step 5 (or any other steps requiring  
2221 re-synchronization of data) should be done after steps 1–4, and immediately before checking for the  
2222 Secondary Controller’s status in processing the Broadcast data (if this is supported and indicated).

2223 **Figure 27** presents a generalized flow of the steps the Active Controller should take to prepare for a Handoff.

2224 Some of these steps require the Active Controller to determine some of the optional Secondary Controller  
2225 features and capabilities advertised by the Secondary Controller. In most cases, these can be determined by  
2226 reading the data returned by the Secondary Controller in response to various CCCs with a Defining Byte (see  
2227 **Section 5.1.9.3.18** regarding the GETMXDS CCC with optional Defining Byte, and **Section 5.1.9.3.19**  
2228 regarding the GETCAPS CCC with optional Defining Byte):

- 2229 • If the Active Controller has not already gathered this information and needs to determine whether  
2230 the Secondary Controller requires special handling based on these features and capabilities, then it  
2231 shall do so before taking any related steps that would require this information.
- 2232 • However, if the Active Controller has already gathered this information in advance, then it may  
2233 rely on cached data, and does not need to gather it again.
- 2234 • Once all the data has been gathered, the Active Controller must make its decisions relating to the  
2235 pre-Handoff flow steps, based on the data returned from the Secondary Controller.

2236 When the Active Controller has verified that the Bus is configured correctly, and the selected Secondary  
2237 Controller indicates that it is ready to accept the Controller Role, the Active Controller shall initiate the  
2238 Controller to Controller Handoff Procedure per **Section 5.1.7.2** (next).

### 5.1.7.2 Controller to Controller Handoff Procedure

After the Active Controller has prepared for Handoff, the Active Controller shall then issue a GETACCCR CCC (**Section 5.1.9.3.16**) followed by a STOP if the Handoff was successful, whereupon it shall release control of the SCL line, and therefore also releasing control of the I3C Bus (i.e., passing the Controller Role) to the selected Secondary Controller.

Following the STOP and Bus Available Condition, the selected Secondary Controller assumes the role of the Active Controller and takes control of the I3C Bus. The former Active Controller should monitor the I3C Bus to ensure that the new Active Controller asserts its Controller Role, according to the flow described in **Section 5.1.10.2.4** regarding Error Type CE3.

**Figure 155** presents a simplified and generalized picture of the Controller to Controller Handoff procedure. While there are many possible variations to this procedure, the most significant states are:

1. At the end of data transfer from a successful GETACCCR CCC, the current Active Controller (indicated by ‘**CCR**’ in the Figure) controls SCL and SDA, and the new Controller-capable Device that will become the new Active Controller (indicated by ‘**NCR**’ in the Figure, initially acting as a Secondary Controller) has SCL and SDA in High-Z state.
2. The **CCR** provides the rising edge of SCL, while keeping SDA Low
3. After  $t_{SU\_STO}$  elapses, the **CCR** drives SDA High, using either an active drive or the Open Drain class Pull-Up. However, once SDA is High the Open Drain class Pull-Up shall be used.
4. After the **CCR** determines that SDA is High, and after both its Clock to Data Turnaround Time ( $t_{SCO}$ ) and the time of flight elapse, it then takes two actions:
  - a. The **NCR** actively drives SCL High, overlapping with the **CCR**’s active drive; and
  - b. The **NCR** enables its Open Drain class Pull-Up, in parallel with the **CCR**’s Open Drain class Pull-Up

Neither of these actions conflicts with the **CCR**.

**Note:**

*Although  $t_{SCO}$  generally applies to any Target Device, in this step it applies to the **NCR** because prior to the Bus transfer the **NCR** performs in the Target role (i.e., as a Secondary Controller until it receives the Controller Role).*

*In the Figure,  $t_{SCO}$  is shown starting as if the **CCR** has used the Open Drain drive of SDA High. This illustrates the worst condition for this stage of the Handoff, showing the latest possible moment when the **NCR** starts overlapping the line controls with the **CCR**.*

5. After a time delay of  $t_{CRHPOverlap}$ , the Active Controller (i.e., the **CCR**):
  - a. Releases SCL to High-Z; and
  - b. Disables its Open Drain class Pull-Up on SDA and sets SDA to High-Z

**Note:**

*In the Figure,  $t_{CRHPOverlap}$  is shown in the worst case: on the Open Drain drive of SDA, and where the **CCR** starts counting it from the lower side of the SDA rising edge. The **CCR** must control the lines until the **NCR** could safely take over, and that is certain after  $t_{DIG\_OD\_L}$  Min. As a result,  $t_{CRHPOverlap}$  is greater than or equal to  $t_{DIG\_OD\_L}$  Min.*

6. After  $t_{NEWCRLock}$  (i.e., the time interval during which the **NCR** shall not drive SDA Low), the **NCR** may actively drive SDA Low, producing a START.

The Targets may also drive SDA Low at this point, since SDA is held by an Open Drain class Pull-Up. The  $t_{NEWCRLock}$  period timing parameter is similar to I3C’s  $t_{AVAL}$  parameter and I<sup>2</sup>C’s  $t_{BUF}$  parameter, and as such, requires different values for Pure Bus vs. Mixed Bus.

In the Figure,  $t_{NEWCRLock}$  is shown as starting at the SDA rising edge in Open Drain driving mode, similar to I3C’s  $t_{AVAL}$  parameter and I<sup>2</sup>C’s  $t_{BUF}$  parameter.

7. After  $t_{CAS}$  expires, the **NCR** may drive SCL Low, producing the first SCL falling edge.

2285 Following this SCL falling edge, the new Active Controller shall actively drive SCL, while also  
2286 driving SDA in Open Drain mode with the Arbitrable Address.

2287 After the Handoff procedure, the new active Controller (i.e., **NCR** in the steps above) should issue a START  
2288 to assert its Controller Role within 100  $\mu$ s, or the time interval indicated by its Activity State (as reported by  
2289 the GETMXDS CCC with optional Defining Byte, per *Section 5.1.9.3.18*), whichever is greater. If the new  
2290 Active Controller has not issued a START, then it shall respond to SDA being pulled Low by pulling SCL  
2291 Low; this is a START, and the new Active Controller may follow it with any valid Bus activity that is  
2292 sufficient to assert the Controller Role.

2293 However, if the new Active Controller does not pull SCL Low within 100  $\mu$ s of SDA being pulled Low, then  
2294 it might lose the Controller Role to the former Active Controller (i.e., ‘**CCR**’ in the steps above). To avoid a  
2295 hung Bus, the former Active Controller should detect whether the new Active Controller has taken over the  
2296 Bus per the Error Type CE3 flow described in *Section 5.1.10.2.4*.

### 5.1.7.3 Secondary Controller Functions

A Secondary Controller Device initially acts as a Target when it joins the Bus (either at Bus Initialization, or via Hot-Join) and, like any other Target, shall respond to the standard (i.e., Required) CCCs.

A Secondary Controller shall indicate that it is a Controller-capable Device, by returning a value of 2'b01 in its BCR Device Role bits (see *Table 5*) when queried by the Active Controller. The Active Controller shall use this value to determine whether any Secondary Controllers are on the Bus, so it knows whether it is obligated to send out other CCCs (such as DEFTGTS or DEFGRPA) that contain Broadcast data that the Secondary Controller needs to use when it becomes Active Controller.

Some Secondary Controllers may require special handling before becoming Active Controller, as listed in the steps to prepare for Handoff (see *Section 5.1.7.1*). Therefore, such Devices must advertise certain capabilities or status to the Active Controller, by supporting one or more optional Defining Bytes for the following CCCs:

- GETSTATUS Format 2 CCC with the PRECR Defining Byte (see *Section 5.1.9.3.15*)
- GETMXDS Format 3 CCC with the CRHDLY Defining Byte (see *Section 5.1.9.3.18*)
- GETCAPS Format 2 CCC with the CRCAPS Defining Byte (see *Section 5.1.9.3.19*)

A Secondary Controller may automatically enter lower-power modes or a “deep sleep” state based on inactivity, or via commands from other connected logic. Such a Secondary Controller should be capable of returning to an active state when it detects and responds to certain CCCs sent by the Active Controller, since the Active Controller may check to ensure that the Secondary Controller is online and ready to receive the Controller Role (see *Section 5.1.10.2.5*) before starting the process of preparing for Handoff (see *Section 5.1.7.1*). This is especially important for situations where the Active Controller is preparing to pass the Controller Role, but the Secondary Controller did not send a Controller Role Request.

For such situations, the Secondary Controller must return from its lower-power mode or “deep sleep” state, respond to CCCs sent by the Active Controller to prepare for Handoff, and remain ready to receive the Controller Role, unless it is constrained from doing so. If the Secondary Controller is constrained or unable to participate, then it may indicate this status by responding to the GETSTATUS Format 1 CCC (see *Section 5.1.9.3.15*) and returning a value of 2'b11 in bits 7:6 (see *Table 27*). However, if the Secondary Controller is able to participate and it supports the GETSTATUS Format 2 CCC with the PRECR Defining Byte, then it shall treat this CCC and Defining Byte as a definitive indication that the Active Controller intends to pass the Controller Role in the near future.

A Secondary Controller may initiate a Controller Role Request (see *Section 5.1.6.3*) to the Active Controller. A Secondary Controller may also accept the Controller Role from any Active Controller (including the Primary Controller), at which point it becomes the new Active Controller.

Once granted control of the Bus by the previous Active Controller via the Controller to Controller Handoff procedure, the Secondary Controller maintains control until another Controller-capable Device is granted Bus control. After the Secondary Controller transitions to the Active Controller role, it could encounter Bus management activities besides the data transfers that it initiates itself, including: In-Band Interrupts, Hot-Join Requests, and Controller Role Requests from other Controller-capable Devices such as another Secondary Controller or the previous Active Controller.

A Secondary Controller shall support the scenarios described in the following subsections *5.1.7.3.1* through *5.1.7.3.9*, according to its capabilities.

Per *Section 5.1.7.3.3*, the Secondary Controller may choose to perform some or all Bus Configuration procedures while acting as Active Controller. And per *Section 5.1.7.3.4*, the Secondary Controller may also choose *not* to perform any Bus Configuration procedures while acting as Active Controller. In either case, if the Secondary Controller receives a request (e.g., a Hot-Join Request) that it elects not to handle, then it may choose to defer the request by sending a DISEC CCC (*Section 5.1.9.3.1*), and may also immediately pass the Controller Role along to a more capable Controller that can handle that request. Any Secondary Controller acting as Active Controller may still freely use Bus Management procedures, in addition to the ENEC/DISEC CCCs (*Section 5.1.9.3.1*), to enable or disable requests on the Bus.

### 5.1.7.3.1 Hardware and Software Requirements

A Secondary Controller capable of acting as Active Controller shall have the following minimum hardware and software capabilities:

1. Memory for:
  - a. All Bus Devices' capabilities and functions at system level
  - b. Retaining the Dynamic Addresses of all I3C Bus Devices
  - c. Retaining the data transfer protocol that the I3C Bus Devices are capable of
  - d. Retaining the active Group Addresses, as well as the lists of all I3C Bus Devices assigned to these Group Addresses, if applicable and supported
  - e. Retaining the currently-configured Multi-Lane Modes and codings of all I3C Bus Devices that support Multi-Lane, if applicable and supported
2. Link requirements for Targets that are intended to transmit In-Band Interrupt requests (IBI), e.g., the clock speed and the maximum length of data transfer
3. Data transfer protocol capability needed for communicating to all I3C Bus Devices

### 5.1.7.3.2 Minimum Bus Management Procedures

A Secondary Controller capable of acting as Active Controller shall perform the following minimum Bus Management procedures:

1. During Bus initialization, if a Secondary Controller is connected to the I3C Bus, then it shall monitor the Bus for the Primary Controller to send a DEFTGTS CCC. A Secondary Controller shall also monitor the Bus for any Active Controller to send a subsequent DEFTGTS CCC containing any updates as a result of Dynamic Address changes, or of subsequent Hot-Join Requests. Using the most recent Broadcast, the Secondary Controller shall acquire the Addresses and Characteristics of all Devices on the I3C Bus from the data in that DEFTGTS CCC (see [Section 5.1.9.3.7](#)).  
A Secondary Controller may also monitor the Bus during Dynamic Address assignment (see [Section 5.1.4.2](#)).
2. Manage the In-Band Interrupt procedure. The Secondary Controller needs to know the meaning of the interrupt from the Target. If the Secondary Controller accepts the IBI, then the Secondary Controller shall service the IBI appropriately (see [Section 5.1.7.3.5](#)).
3. Procedure for requesting transfer of Bus control to another Controller-capable Device, including the Primary Controller or any previous Active Controller. The Secondary Controller uses the GETACCCR CCC (Get Accept Controller Role, [Section 5.1.9.3.16](#)). The Secondary Controller should also handle Controller Role Requests from another Controller-capable Device.

In addition, while acting as Active Controller a Secondary Controller may also utilize other CCCs to change the state of the Bus, or the state of any Devices, such as entering an Activity State, or disabling Target Events such as Interrupts or Controller Role Requests. If a Secondary Controller does so, then before passing the Controller Role to another Controller-capable Device the Secondary Controller should restore the state of the Bus, or the state of any Devices, to a prior state, or to a state known to be compatible with the prior state.

### 5.1.7.3.3 Bus Configuration Procedures

A Secondary Controller capable of changing the Bus Configuration while acting as Active Controller may perform any of the following Bus Configuration procedures:

1. Perform the Dynamic Address Assignment procedure for Hot-Join Devices:
  - a. In order to be able to assign the correct priority level to the Hot-Join Device, the Secondary Controller needs to know all Bus Devices' functionality at the system level.
  - b. The Secondary Controller may also perform the Dynamic Address Assignment procedure while acting as Active Controller, without a Hot-Join event. It may also reset a Device's Dynamic Address, or directly assign a Dynamic Address to a Device for any other reason.
  - c. If the Secondary Controller changes the Bus Configuration for the above reasons while acting as Active Controller, then it shall issue the DEFTGTS CCC (Define List of Targets, *Section 5.1.9.3.7*) to ensure that other Controller-capable Devices have the same knowledge.
2. Manage Group Address assignments for other I3C Devices that support Group Addressing, if applicable and supported.

To support Group Addressing, a Secondary Controller uses the following CCCs:

- SETGRPA (Set Group Address), *Section 5.1.9.3.27*
- RSTGRPA (Reset Group Address), *Section 5.1.9.3.28*
- DEFGRPA (Define List of Group Addresses), *Section 5.1.9.3.29*

The Secondary Controller shall also monitor the Bus for an Active Controller to send DEFGRPA CCCs containing Group Address data, comprising lists of the I3C Target Devices assigned to each known Group Address, if any Group Addresses are known and reported in a DEFTGTS CCC.

If the Secondary Controller changes any Group Address assignments while acting as Active Controller, then it shall send the appropriate Group Address data using the DEFTGTS (*Section 5.1.9.3.7*) and DEFGRPA (*Section 5.1.9.3.29*) CCCs to ensure that other Controller-capable Devices have the same knowledge.

3. Configure other Multi-Lane capable I3C Devices to use any supported Multi-Lane Modes and codings while acting as Active Controller, if applicable and supported. The Secondary Controller uses the MLANE CCC for this (Multi-Lane Data Transfer Control, *Section 5.1.9.3.30*).

A Secondary Controller that can perform any of these Bus Configuration procedures shall advertise its support for these features and capabilities by providing the appropriate bit values in the CRCAP1 byte that is returned when an Active Controller sends the Direct GETCAPS Format 2 CCC with the optional CRCAPS Defining Byte (Secondary Controller Capabilities, see *Section 5.1.9.3.19*).

In some cases, a Secondary Controller might not need to assign or change any Dynamic Addresses for any Devices, nor assign nor change Group Addresses for any Devices, nor change the Multi-Lane configurations of any Devices, while acting as Active Controller. The decision on whether to use these Bus Configuration procedures could depend upon the Secondary Controller's available features and capabilities, upon instructions or settings received from another Controller (including the Primary Controller), or upon the specific use cases required for that Secondary Controller within the Bus.

### 5.1.7.3.4 Reduced Functionality Secondary Controllers

Secondary Controllers are not required to implement or perform any Bus Configuration procedures. The Secondary Controller may defer or transfer the Bus control to another Controller-capable Device when needed; see *Section 5.1.7.3.1* and *Section 5.1.7.3.2*.

A Secondary Controller with reduced functionality shall have the following minimum capabilities:

1. Memory sufficient for retaining Device Addresses and Characteristics of any Targets it supports
2. Memory sufficient for retaining the Device Address and Characteristics of the Controller to which it will return Bus control

### 5.1.7.3.5 In-Band Interrupt Handling

A Secondary Controller may either accept an In-Band-Interrupt request from a Target, or refuse it.

Since the Target emits its Address in the Arbitrated Address header, the Secondary Controller may base the decision to accept or reject the IBI based on the Address (per *Section 5.1.6*) and/or the Secondary Controller's intended use case. If a Secondary Controller elects to accept an IBI from a particular Target, then it shall service that IBI request normally per *Section 5.1.6.2*.

Some Secondary Controllers may elect to simply refuse IBIs from all Addresses, whereas other Secondary Controllers may base the decision on the Address in each IBI request. If a Secondary Controller elects to refuse an IBI from a particular Target for any reason, then it should issue the DISEC CCC to the interrupting Target, with the DISINT bit set (Disable Target Events Command, *Section 5.1.9.3.1*), and then defer IBI handling to another capable Controller.

A Secondary Controller that refuses IBIs from all Target Addresses should also issue a Broadcast DISEC CCC with the DISINT bit set, to disable interrupts from all Targets. To avoid Target issues that might arise from an IBI not being accepted and serviced in a timely manner, a Secondary Controller that refuses an IBI should also plan to pass the Controller Role to another capable Controller within a reasonably short time after refusing that IBI.

### 5.1.7.3.6 Hot-Join Management

A Secondary Controller may either support Hot-Join Requests, or not support them.

If a Secondary Controller supports Hot-Join Requests, then it may either manage the Hot-Join Request while acting as Active Controller per *Section 5.1.5*, or else defer management to a capable Controller by issuing a Broadcast DISEC CCC to disable Hot-Join Requests by setting the DISHJ bit (Disable Target Events Command, *Section 5.1.9.3.1*).

If a Secondary Controller does not support Hot-Join Requests, then it shall deny any Hot-Join Requests and defer management to another capable Controller.

### 5.1.7.3.7 Group Address Management

A Secondary Controller may either support Group Address commands, or not support them.

If a Secondary Controller supports Group Address commands, then it can participate in the transfer of Group Address data and manage the Group Addresses of I3C Target Devices as described in *Section 5.1.4.4*. If the Secondary Controller determines that it needs to perform this function while acting as Active Controller, then it may use the Group Address commands to set or reset Group Addresses for any I3C Targets that support Group Addressing. The Secondary Controller may also participate in the transfer of Group Address data to another Controller-capable Device using the DEFGRPA CCC (Define List of Group Addresses, *Section 5.1.9.3.29*).

If a Secondary Controller does not support Group Addressing, then it shall not send these CCCs and cannot participate in the transfer of Group Address data, either before or after Handoff.

If the Controller Role passes through a Secondary Controller that does not support Group Address management, and that does not use the DEFGRPA CCC to pass on any Group Address data received from the previous Active Controller to a future Controller, then it shall be the responsibility of either the previous Active Controller, or of a future Controller, to resolve any issues relating to this Secondary Controller's lack of support for Group Addressing.

### 5.1.7.3.8 Multi-Lane Management

A Secondary Controller may either support Multi-Lane Data Transfer, or not support it.

If while acting as Active Controller a Secondary Controller that supports Multi-Lane Data Transfer determines that it is necessary to configure other Multi-Lane capable I3C Devices as described in **Section 5.3.1**, then it may do so. In this situation, the Secondary Controller shall rely upon the Active Controller to have configured the I3C Bus, and all Multi-Lane capable I3C Devices, to use a compatible Multi-Lane Frame format before the Secondary Controller accepts the Controller Role.

However if a Secondary Controller does not support Multi-Lane Data Transfer, then the Active Controller shall configure the I3C Bus and all Multi-Lane capable I3C Devices to use basic 2-Wire I3C mode (i.e., 1-Lane) before passing the Controller Role to that Secondary Controller.

**Note:**

*The following configuration advisory is provided in order to enable smooth transitions of the Controller Role from other I3C Controller-capable Devices that might support Multi-Lane for HDR-DDR Mode (as defined in version 1.1 or higher of the full I3C Specification):*

*Not all of the HDR Modes included in I3C Basic support Multi-Lane in I3C Basic. For example, Multi-Lane support for HDR-DDR Mode is defined in the full I3C Specification, but is not included in I3C Basic. As a result, HDR-DDR Mode may only be used in 2-Wire I3C Mode (i.e., 1-Lane) by any I3C Controller Devices and any I3C Target Devices that comply with the I3C Basic Specification.*

*Passing the Controller Role to a Multi-Lane capable I3C Controller-capable Device that supports I3C Basic could cause compatibility issues, if that I3C Controller-capable Device expects to use HDR-DDR Mode while it is Active Controller, and some I3C Target Devices that were previously configured to use Multi-Lane for HDR-DDR Mode (as defined in the full I3C Specification) have not been re-configured to use basic 2-Wire I3C mode (i.e., 1-Lane).*

### 5.1.7.3.9 Interoperability Among Controllers Based on Different I3C Versions

If multiple Controller-capable Devices on a given I3C Bus support different versions of the MIPI I3C Specification, then certain features or capabilities added in later I3C versions will not be supported (nor even known to exist) by Devices based on earlier I3C versions, raising potential interoperability issues.

In particular, some features and capabilities added in I3C version 1.1 or I3C Basic v1.1.1 may require special handling during Controller Role Handoff and the recommended Handoff preparation flow. These potential issues could impact the new Active Controller after Handoff, or any subsequent communications between a Controller and a Target.

To avoid leaving the Bus in a non-functioning state, the system designer must give the following situations careful consideration:

- **Use cases that depend upon features or capabilities introduced in I3C v1.1 or I3C Basic v1.1.1,** such as Multi-Lane Data Transfer, Group Addressing, or flow control in HDR Modes.

A Controller based on an earlier version of I3C might not support these features or capabilities, and could potentially be negatively impacted if such features or capabilities were to be enabled.

Additionally, a Controller that supports I3C Basic would not support all features and capabilities that are only included in the full I3C Specification, and the transition of the Controller Role could potentially be impacted if such features and capabilities were to be enabled.

- **Use cases that depend upon Target-initiated requests specified in a more recent I3C Specification version,** such as Device to Device Tunneling.

A Controller based on an earlier version of I3C might not be able to understand and/or handle such requests.

- **Use cases that pass the Controller Role between Controllers based on different I3C Specification versions.**

If a given Bus implementation calls for Controller Role Handoffs between multiple Controllers, and not all of those Controllers are based on the same version of the I3C Specification, then the system designer is responsible for ensuring smooth Controller Role Handoff between these Devices, without interoperability issues or loss of communications. In particular, some Controllers might require or expect special handling to prepare for a successful Handoff (see *Section 5.1.7.1*).

### 5.1.8 Timing Control

I3C Basic includes optional Timing Control and Timestamping of events generated by I3C Devices resident on the I3C Bus. This Timing Control framework allows uncertainties affecting the transmission or reception of timing information (for example: Bus activity, busy Controller or Target, operation latency, system jitter, etc.) to be nullified.

**Note:**

*I3C Basic only includes some of the Timing Control modes and capabilities that the full I3C Specification includes. To gain access to these additional Timing Control modes and capabilities, please contact MIPI Alliance.*

The I3C Timing Control framework provides:

- Flexible implementation with significant capability enhancements
- Means for synchronizing the timing references/clocks, and subsequently the events, of Target Devices on the I3C Bus to the timing reference/clock of the Controller
  - This can result in reduced energy consumption at the system level.
- Transmission of timing information, with minimal complexity for the Target Devices
- Controllable timing accuracy, suitable for the intended use cases

I3C defines two forms of main systems and events for Timing Control: Synchronous mode and Asynchronous mode. These modes and their versions can be used independently and concurrently on a given I3C Bus, per the application-specific requirements, with only one restriction: a Target can enable only one Asynchronous mode variant at a time.

- **Synchronous Time Control** (see *Section 5.1.8.2*): NOT INCLUDED IN I3C BASIC.
- **Asynchronous Time Control** (see *Section 5.1.8.3*): Targets timestamp the moment at which they acquire sampled data, permitting the Controller to time-correlate samples received from multiple, different sensors in an easier and more accurate manner. Timestamping ensures that the Controller always has the time at which sensor data acquisition occurred (subject to the timing granularity supported), even if there are latencies in moving the data from the Target to the Controller.

**Note:**

*I3C Basic only includes Asynchronous Time Control (Mode 0). The full I3C Specification includes additional Asynchronous Time Control Modes that provide different methods for measuring time and/or calibrating timing, with increasing accuracy.*

### 5.1.8.1 General Principles

The exchange of timing information is based on agreements between the Controller and Targets.

The elements of this agreement are:

1. Two I3C Common Command Codes (CCCs):

- Set Exchange Timing Information (SETXTIME), see *Section 5.1.9.3.21*, and
- Get Exchange Timing Information (GETXTIME), see *Section 5.1.9.3.22*.

These CCCs:

- Identify Bus events and markers (i.e., specific SDA edge and/or SCL edge),
- Transfer timing or control information (e.g., ‘abort’ command),
- Specify which timing control procedure is in effect, and
- Query the Target Device for Exchange Timing support details, such as which Timing Control Mode(s) are supported, the current Timing Control state, frequency, inaccuracy, etc.

2. One defined and Mode-specific marker is sent by the Controller, and used to synchronize the Targets

3. One data collection event is sent by the Target. It includes the time information previously requested by the Controller.

### 5.1.8.2 Synchronous Systems and Events

This section is not included in the I3C Basic Specification. To gain access to this capability, please contact MIPI Alliance.

In systems where multiple sensors (or other Target Devices) provide periodically sampled data, it is advantageous to instruct the Targets to be able to collect the data at essentially synchronized times, so that the Controller can read several Targets’ data in a single system awake period.

In a typical system, different Targets will sample their data at different, uncorrelated times. This is true even if all Targets are set to the same sampling frequency, because Target-to-Target oscillator accuracy differences will cause drift over time. In I3C’s Synchronous Time Control mechanism, the Controller periodically emits a synchronization pulse, called a SYNC Tick. This method permits all Target data sampling to occur very close together in time, so that Targets can prepare and activate their individual sampling mechanisms, even if there are variances across their clocks.

### 5.1.8.3 Asynchronous Systems and Events

In the full I3C Specification this section defines four variations (called Modes, summarized in *Table 14*) of a method for increasing the precision of the acquired time-of-occurrence for an event occurring in an I3C Target connected to an I3C Controller. The overall method is called Asynchronous Timing Control. In this version of the I3C Basic Specification, only Async Mode 0 is supported.

The actual event itself may or may not be periodic, and the Controller and Target Devices need not use the same time base clock (source, frequency, or accuracy). The procedure can help address the large inaccuracies/offsets to the event's acquired time-of-occurrence that IBI launch/acknowledge latencies can introduce.

In I3C Asynchronous Timing Control, a Target Device timestamps events occurring within that Target, and then notifies the Controller about it by generating an In-Band Interrupt (IBI). The Target's IBI may not reach the Controller immediately, either because the I3C Bus was busy, or because the Target lost IBI Arbitration, or because the Controller did not immediately accept the IBI. The Asynchronous mechanism allows the I3C Controller to convert the Target's timestamp value to its own internal time scale, in terms of both timing resolution and timing accuracy.

**Table 14 Asynchronous Timing Control Mode Supported in I3C Basic**

| Mode                                                                        | Description                                                                                                                                                                                                                                                        | Supported in I3C Basic v1.1.1? |
|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| <b>Async Mode 0: Asynchronous Basic Mode</b>                                | Simple for I3C Controller and I3C Target<br>Allows all I <sup>2</sup> C out-of-band interrupt usages to be replaced with I3C In-Band Interrupt                                                                                                                     | Yes                            |
| <b>Async Mode 1: Asynchronous Advanced Mode</b>                             | Extension to Async Mode 0<br>If clock used by Target's counter drifts, or is not accurate enough, then the Controller must send an aperiodic event to limit the running time of the Target's timing counter.                                                       | No                             |
| <b>Async Mode 2: Asynchronous High-Precision Low-Power Mode</b>             | Minimizes the time for which the clock driving the Target's timer counter needs to run. Devices can use burst clock sources, at the cost of Controller overhead to measure time and correlate time scales. Time reference is falling SCL when Controller ACK's IBI | No                             |
| <b>Async Mode 3: Asynchronous High-Precision Triggerable Low-Power Mode</b> | Precision controlled trigger followed by precision time-stamp of detected event.<br>Time stamp similar in operation to Mode 2, except time reference is to sync signal preceding trigger.                                                                          | No                             |

#### Terminology

- **T\_C1:** Target counter from Event occurrence to a Controller-initiated end-of-count (EOT\_C1) point depending on Mode (e.g., IBI Acknowledged point in Mode 0).
- **T\_C2:** Target counter from EOT\_C1 to a second Controller-initiated end-of-count, EOT\_C2 (e.g., T-Bit of IBI Mandatory byte in Mode 0).
- **aBE:** Additional Bus Events, which are not used in Mode 0. These events are defined for other Async Modes, and are not supported in I3C Basic.

*Figure 28* illustrates the I3C Asynchronous Timing Control model. In this model, the I3C Controller Device maintains its own notion of time ("I3C Controller Ref Counter" in the Figure) using whatever timing source and units it needs; for example, a real-time clock, or a simple 32-bit rollover timer/counter. This notion of time allows the Controller to determine the relative timing among multiple events generated by different Targets. These relative time differences can then be used to correlate the Target-generated events, for example to support sensor fusion, to plot sensor events vs. absolute time, or for other purposes.



**Figure 28 Graphical Representation of Async Mode 0 Timestamp Interpolation**

I3C Target Devices report the occurrence of sensor events to the I3C Controller using IBI, but because the IBI can be delayed before reaching the Controller, the Controller's notion of time alone is not sufficient to accurately gauge event timing. For this reason, the Target maintains its own counter ("Target Device Counter ( $T_{\_C1}$ )" in **Figure 28**), driven by its own clock. At the time when the Target is able to generate the IBI to report the occurrence of a sensor event to the I3C Controller, the number of Target clocks elapsed since the event occurred (' $T_{\_C1}$ ' in the Figure) and the calibration period (' $T_{\_C2}$ ') shall be sent as IBI payload of the same IBI.

The Target Device counts can be converted into Controller time via a Controller-provided method whereby the Target can measure the time between two points ('EOT\_C1' and 'EOT\_C2' in the Figure) as  $T_{\_C1}$ , in terms of number of its clock cycles whose approximate clock frequency is known to the Controller through the GETXTIME CCC, see **Section 5.1.9.3.22**). The Target then counts the time ( $T_{\_C2}$ ) from EOT\_C1 to EOT\_C2, and then communicates both  $T_{\_C1}$  and  $T_{\_C2}$  to the Controller as IBI payload. This allows the Controller to correlate  $T_{\_C1}$  and  $T_{\_C2}$  with its own internal counter values  $C_{\_REF}$  and  $C_{\_C2}$ , respectively. The Controller knows the center clock frequency of the Target Device (again via the GETXTIME CCC), and can compare the Target-provided count with its expected value, given the known length of time reported by  $T_{\_C2}$ . The delta between the expected count and the actual count can be used as guidance to improve the accuracy of the SC2 value, derived from the GETXTIME CCC, and thereby the accuracy of the event's calculated time-of-occurrence.

Note that the higher the frequency of the Target clock vs. the effective SCL clock frequency during the  $T_{\_C1}$ -to- $T_{\_C2}$  measurement, the more accurate the error delta will be. This means that the Controller could gain more accuracy in the scale factor by extending the  $T_{\_C1}$ -to- $T_{\_C2}$  period.

The Target shall report the  $T_{\_C1}$  value as a 2-byte (16-bit) value, transmitting the Least Significant Byte first, and then the Most Significant Byte. The Target shall report the  $T_{\_C2}$  value as a 1-byte value. If either count overflows (which can happen with a busy Bus with a large transaction), then the Target shall report values of all 1'b1 bits: 8'hFF for  $T_{\_C2}$ , and 16'hFFFF for  $T_{\_C1}$ .

A Target may choose to not count T\_C2 value if its counter's clock source is insufficiently accurate, however in this case it shall report a value of 8'h00 for T\_C2 in the IBI payload. A Controller receiving a T\_C2 value of 8'h00 shall rely solely on the frequency value reported by GETXTIME for scaling. Targets having very stable clocks, especially when fast enough, could help the Controller achieve higher time-stamping accuracy by supporting and reporting the T\_C2 count.

In all supported Asynchronous Modes, the key points are:

1. All I3C Devices supporting any of the Asynchronous Modes shall drive a Mandatory Byte after Acknowledgement of their IBI. As a result, the BCR[2] bit for these I3C Devices shall be set (i.e., shall have the value 1'b1).

In the Mandatory Byte:

- **Bits[7:5]** shall be set to 3'b100, indicating that a timestamp follows.
- **Bits[4:0]** shall be set by the Target and read by the Controller. These bits are typically used to convey some aspect of the event, and are interpreted according to a private contract between the two Devices.

2. Two mutually identifiable Events on the I3C Bus between I3C Controller and I3C Target Devices:
  - **End of T\_C1 (EOT\_C1)**: The T\_C1 latch point and the start of the Calibration Window to count T\_C2.

The actual event used depends on which of the four Asynchronous Modes is being used. It could be either the IBI ACK point of the current IBI transaction, or an SCL edge, or some other event on the I3C Bus.

- **End of T\_C2 (EOT\_C2)**: The end of the Calibration Window.

This event depends on which of the four Asynchronous Modes is being used. It could be either the T-Bit following the IBI's Mandatory Byte for the current IBI transaction, or an SCL edge, or some other event on the I3C Bus.

3. Additional common Events (**aBE**) are defined for other Asynchronous Modes, which are not supported in I3C Basic.
4. After the Mandatory Byte, the Target shall send its timestamp values:
  - **T\_C1**: The 16-bit timing counter from the original sensor-generated event
  - **T\_C2**: An 8-bit reference/calibration count
  - **aBE\_TICKS**: An optional 1-byte value indicating the number of aBEs that the Target has detected, from the sensor event to the IBI-ACK. These are not defined for Asynchronous Mode 0.

The values of both T\_C1 and T\_C2 are in terms of the Target's time scale. The Controller will convert these values into its own time scale, taking into consideration the Target's counter clock frequency as reported by the GETXTIME CCC.

In cases where the aBE event is used, the Controller then can calculate when the event occurred by taking the timestamp of the aBE event indicated by the Target (by count) and subtracting the time in T\_C1 (translated to Controller time resolution).

In order to support a wide range of applications, several degrees of accuracy are required for such timing related information. As a result, I3C Basic provides Asynchronous Mode 0 which is detailed in **Section 5.1.8.3.1**. Asynchronous Mode 0 provides a moderate level of accuracy, and presents a simple implementation for the Controller and/or Target. The SETXTIME CCC (see **Section 5.1.9.3.21**) is used to enter Asynchronous Mode 0, using the Sub-Command Byte field to select the desired Mode.

**Note:**

*The full I3C Specification defines additional Timing Control modes that present additional choices, including different levels of accuracy and distinct complexity tradeoff options for the Controller and/or Target. I3C Controllers that support the full I3C Specification may optionally use the same SETXTIME CCC to enter these other Timing Control modes, and I3C Targets that support the full I3C*

2670      *Specification might optionally implement support for such Timing Control modes. However, such*  
 2671      *Timing Control modes shall not be supported by or enabled by any I3C Devices that support the I3C*  
 2672      *Basic Specification.*

2673      *These other Timing Control modes are not included in I3C Basic. To gain access to these other*  
 2674      *Timing Control modes, please contact MIPI Alliance.*

### 5.1.8.3.1 Async Mode 0: Asynchronous Basic Mode

2675      All I3C Basic Controller Devices capable of Asynchronous Timing Control procedures shall support Async  
 2676      Mode 0, Basic Asynchronous Timestamping. This Mode expects that a reasonably accurate and stable clock  
 2677      source is available in the Target to drive the timer counter. Note that in this Mode, the two SCL edges both  
 2678      occur after the Target and the Controller agree that the transaction was valid.

2679      To select Async Mode 0, the Controller sends the SETXTIME CCC (see [Section 5.1.9.3.21](#)) with the Sub-  
 2680      Command Enter Async Mode 0 (0xDF).

#### Terminology

- **EOT\_C1:** First SCL positive-going edge after the IBI ACK for the Target Device
- **EOT\_C2:** First SCL positive-going edge after the T-Bit of the IBI's Mandatory Byte
- **aBE:** Not used

2685      **Figure 29** graphically depicts Async Mode 0 timestamp data transfer from the Target to the Controller,  
 2686      allowing the Controller to calculate the time at which sensor data sampling has taken place. It is presumed  
 2687      that the Target is able to transfer the data within a time interval that the Target's timing counter can  
 2688      meaningfully measure (i.e., that the clock driving the timing counter preserves a sufficiently stable frequency  
 2689      to increment it in a substantially linear manner with respect to time).



2690      **Figure 29 Example of Asynchronous Mode 0 Timestamp Data Transfer**

2692     Figure 29 illustrates the basic sequence of operations during a simple asynchronous time information  
2693     transfer:

- 2694       1. The top black baseline shows the events visible outside of the Target and the Controller
- 2695       2. The middle (red) baseline shows the activity inside the Target's timing counters
- 2696       3. The bottom black baseline presents the virtual and real activity inside the Controller's timing  
2697           counter

2698     In more detail, **Figure 29** illustrates that:

- 2699       1. At sensor sampling/event time, the Target shall start its internal timing counter, and initiate the IBI  
2700           request.
- 2701       2. If the IBI request is accepted, then:
  - 2702           a. Immediately:
    - 2703              • The Target shall record its internal timing counter, T\_C1
    - 2704              • The Controller shall record its internal timing counter, C\_REF
  - 2705           b. At the T-Bit of the IBI payload's mandatory byte:
    - 2706              • The Target shall record its internal timing counter, T\_C2
    - 2707              • The Controller shall record its internal timing counter, C\_C2
  - 2708           c. The Target shall transfer the recorded T\_C1 & T\_C2 values in the prescribed order.
- 2709       3. If the IBI request is not accepted, then:
  - 2710           • The Target shall continue to increment its own counter for T\_C1
  - 2711           • The Target shall wait for the next opportunity for the IBI request to be issued & accepted
  - 2712           • When the IBI request is eventually accepted, the Target shall proceed as described in step 2  
2713           above.
- 2714       4. Evaluating the timing counter data:

2715     If the numbers are non-zero, then the Controller calculates the real time interval based on its  
2716     internal timing counter, using the formula:

$$C_TS = C_{REF} - C_{C2} * T_{C1} / T_{C2}$$

- 2718       • If T\_C1 is zero, then no time information is assigned to the event
- 2719       • If T\_C2 is zero, then the scaling shall be done based on the Target Device counter's clock  
2720           frequency as can be read with GETXTIME CCC.

2721     Note that the above method of recovering the target event's timestamp is only suitable for periods during  
2722     which the Target clock is appropriately stable. The calibration time available is the duration elapsed between  
2723     EOT\_C1 and EOT\_C2, which in this mode is 9-bit durations on the I3C Bus for the Mandatory Byte. To  
2724     enable better calibration for Targets using low-frequency clocks, the Controller may optionally use clock  
2725     Stalling during the Mandatory Byte transfer, thus lengthening the calibration window; however, clock  
2726     Stalling has the disadvantage that IBIs will consume more I3C Bus time.

2727     If better calibration is required and clock Stalling is not an option, then other, more refined procedures can  
2728     be used.

**5.1.8.3.2 Async Mode 1: Asynchronous Advanced Mode**

2729 This section is not included in the I3C Basic Specification. To gain access to these capabilities, please contact  
2730 MIPI Alliance.

**5.1.8.3.3 Async Mode 2: Async High-Precision Low-Power Mode**

2731 This section is not included in the I3C Basic Specification. To gain access to these capabilities, please contact  
2732 MIPI Alliance.

**5.1.8.3.4 Async Mode 3: Async High-Precision Triggerable Mode**

2733 This section is not included in the I3C Basic Specification. To gain access to these capabilities, please contact  
2734 MIPI Alliance.

### 5.1.9 Common Command Codes (CCC)

Common Command Codes (CCCs) are I3C's standardized command set. In SDR Mode, Target support for a number of CCCs is Required, some CCCs are Conditionally required, and others are entirely Optional to support (see *Table 16*). This Section specifies how SDR Mode CCCs are formatted and transmitted on the I3C Bus, how each CCC functions, and which CCCs are Required, Conditional, and Optional for Targets to support in SDR Mode.

**Note:**

*In the HDR Modes, Targets are not required to support any of the CCC Commands listed in Table 14. Each manufacturer is free to choose to support any, all, or none of them in each supported HDR Mode.*

As detailed below, there are two main kinds of CCC:

- **Broadcast CCCs:**

- Are addressed to all I3C Target Devices on the I3C Bus.
- All Broadcast CCCs are Write CCCs.

- **Direct CCCs:**

- Are typically directed to a single, specifically-addressed Target on the I3C Bus, selected via its Dynamic Address. For some Direct Write CCCs a Group Address may also be used, per *Section 5.1.9.4*.
- If the Direct CCC definition requires a Target response, then only the single, specifically-addressed Target will reply.
- There are three types of Direct CCCs: Read, Write, and Read/Write.

### 5.1.9.1 CCC Command Formats

In SDR Mode, the CCC Command always starts with the I3C Broadcast Address, 7'h7E. That is, after a START or Repeated START, the Address field of a CCC Command shall always contain the value 7'h7E and the RnW bitfield shall always contain the value 1'b0 (Write).

All I3C Targets shall recognize:

- The 7'h7E Broadcast Address,
- Their own Dynamic Address (once it has been assigned), and
- Optionally supported Group Addresses (once they have been assigned)

**Note:**

*The 7'h7E value of I3C's Broadcast Address is selected to avoid collision with any Legacy I<sup>2</sup>C Devices that may potentially be present on the I3C Bus: Per the I<sup>2</sup>C specification (**Section 3.1.2 of [NXP01]**), no I<sup>2</sup>C Device will respond to the Address 7'h7E.*

**Note:**

*Formats for HDR Command Frames are different from the SDR Mode CCC Command format described in this Section, and are specified separately for the HDR Modes (see **Section 5.2.1.2**).*

CCC Commands are always available in SDR Mode and some CCC Commands are available in the HDR Modes, per **Table 16**. Generally, CCCs that assign Dynamic Addresses, alter I3C Bus Modes, or transfer the I3C Bus Controller Role are not allowed within HDR Modes.

The I3C Controller shall issue a CCC Command both before and after I3C Dynamic Addresses are assigned.

There are four categories of CCC Command:

1. **Broadcast Write:** A Broadcast Write CCC is seen by all I3C Targets. All Targets shall inspect every received Broadcast command, even if the Target then ignores the Broadcast command.

Every Broadcast Write CCC Command ends with a Repeated START or a STOP.

**Note:**

*If the CCC Command enters a Mode, then the new Mode ends according to its own rules.*

2. **Direct Read/Write:** A Direct Read/Write CCC may alternatively read or write data from/to one or more specific I3C Targets, one Target at a time, selected by the Target Dynamic Address(es). For example, it may Write to, and then Read back from, the same Target to verify that a change was accepted.

Every Direct Read/Write CCC Command ends with a STOP or a Repeated START, followed by the I3C Broadcast Address (7'h7E).

**Note:**

*This type may also have data both provided with the CCC (code), as well as with each write.*

3. **Direct Write:** A Direct Write CCC is directed to one or more specific I3C Targets, selected by the Target Dynamic Address(es). This CCC type is only permitted to Write. Generally, only legacy I3C v1.0 CCCs will be of this type.

Every Direct Write CCC Command ends with either a STOP, or a Repeated START followed by the I3C Broadcast Address (7'h7E).

4. **Direct Read:** A Direct Read CCC reads data from one or more specific I3C Targets, one Target at a time, selected by the Target Dynamic Address(es). This CCC type is only permitted to Read. Generally, only legacy I3C v1.0 CCCs will be of this type.

Every Direct Read CCC Command ends with either a STOP, or a Repeated START followed by the I3C Broadcast Address (7'h7E).

2797  
2798

All CCC Commands share the same general Frame format, which is shown in *Figure 30* for Broadcast CCCs, and in *Figure 31* for Direct CCCs. Each CCC Command has a unique Command Code. The fields within this Frame format are detailed in *Table 15*.



Figure 30 CCC Broadcast General Frame Format



Figure 31 CCC Direct General Frame Format

2799  
2800

2801  
2802

2803

**Table 15 CCC Frame Field Definitions**

| Field                                      | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                        |  |  |  |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| <b>S or Sr</b>                             | A CCC always begins with either START or Repeated START.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                        |  |  |  |
| <b>I3C Address Header</b>                  | This field has three parts:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                        |  |  |  |
|                                            | <b>7'h7E</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | The CCC Frame starts with the global Broadcast Address, so that all I3C Targets on the Bus will see the CCC Code that follows.                                                                                                         |  |  |  |
|                                            | <b>W</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | The RnW Bit is set to value 1'b0, indicating that the Controller is writing a Message to the Targets.<br>This Message always includes the CCC Code, and may optionally include further Data, depending upon the value of the CCC Code. |  |  |  |
|                                            | <b>ACK</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Acknowledgement (SDA driven Low) by all I3C Targets.                                                                                                                                                                                   |  |  |  |
| <b>Command Code / T</b>                    | An 8-bit value indicating which command is being sent, followed by a T-Bit.<br>All defined Command Code values are specified in <b>Section 5.1.9.3</b> .                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                        |  |  |  |
| <b>Defining Byte / T<br/>(Per CCC)</b>     | This field is used with Broadcast CCC Messages, and for some Direct Read/Write CCC Messages. It is followed by a T-Bit.<br><b>Section 5.1.9.3</b> specifies, for each defined CCC Code, the use of a Defining Byte as a selector or Sub-Command, extending CCC capability or an action associated with the CCC.<br>When the Defining Byte is used for a Direct CCC, it applies to all subsequent Direct CCC Messages (i.e., segments) until the Controller sends a new Direct CCC. For some Direct CCCs, a Defining Byte is optional; for others, it is always required. |                                                                                                                                                                                                                                        |  |  |  |
| <b>Sub-Command Byte / T<br/>(Per CCC)</b>  | This field is used with some Direct CCCs. It is followed by a T-Bit.<br>In Direct CCC framing, this field always follows the Target Address (or Group Address) for a specific Direct Write/SET CCC Message (i.e., segment) and applies only to that Message.<br><b>Section 5.1.9.3</b> specifies, for each defined CCC Code, whether a Sub-Command Byte is required or optional.<br><b>Note:</b><br><i>Sub-Command Bytes are not typically supported for Broadcast CCCs.</i>                                                                                             |                                                                                                                                                                                                                                        |  |  |  |
| <b>Data / T<br/>(Per CCC)</b>              | This field is used with Broadcast CCC Messages, and for some Direct Read/Write CCC Messages per Target (or, for some Write CCCs, per Group). It is followed by a T-Bit.<br><b>Section 5.1.9.3</b> specifies, for each defined CCC Code, how much Data (if any) appears here.<br><b>Note:</b><br><i>For Direct Read/GET CCCs, the Target shall use the T-Bit in the same manner as a typical SDR Read transfer, per <b>Section 5.1.2.3.4</b>.</i>                                                                                                                         |                                                                                                                                                                                                                                        |  |  |  |
| <b>Sr / Broadcast Address<br/>or<br/>P</b> | A CCC always ends with either a STOP or a Repeated START and Broadcast Address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                        |  |  |  |

### 5.1.9.2 Broadcast CCCs vs Direct CCCs

The Command Code space is divided into Broadcast Commands and Direct Commands:

- **Broadcast Commands** are Command Codes 0x00 to 0x7F
- **Direct Commands** are Command Codes from 0x80 to 0xFE
- Command Code 0xFF is reserved.

As a result, a Target can easily determine whether a received Command is being Broadcast to all Targets on the I3C Bus (1'b0), or is a Direct Command (1'b1) intended only for the particular Target, by inspecting Bit 7 (MSb) of the Command Code.

#### 5.1.9.2.1 End of a CCC Command

A CCC Command shall end in one of the following three I3C Bus conditions:

- A STOP after the Command or Data
- For a Broadcast Command, a Repeated START (for any Address value)
- For a Direct Command, a Repeated START followed by 7'h7E (which may be the start of a new CCC, or may be followed by a Repeated START)

If the CCC Command enters a Mode, then the Mode ends according to its own rules.

A 7'h7E following a Repeated START to end a Direct CCC may start another CCC, or may be followed by a Repeated START.

Although not a normal use, the Controller may terminate a Direct CCC Command without addressing any Target.

If the Controller invalidly terminates the data associated with a CCC prematurely, then the Target shall use best efforts to handle the termination and ascertain the proper course of action. That is, the Target may choose to disregard the event with no effect, or the Target may attempt to process the incomplete data.

### 5.1.9.2.2 Framing Model for Direct CCC Commands

In Direct CCC Commands the Frame contains first the Command Code, then one or more Repeated STARTs, then the Address of the Target, followed by Data, and finally either a STOP, or a Repeated START and 7'h7E.

A single Direct CCC Command may also optionally address more than one Target Device. To do this, an additional block is inserted before the final 7'h7E for each additional desired Target Device (see *Figure 31*). Each such block consists of Repeated START, the Target Address of the additional desired Target Device, and the Data to be sent to or from that Target Device. Per *Section 5.1.9.4*, a Group Address may also be used in the place of a Target Address for those Direct Write or Direct SET CCCs that can also be sent to an assigned Group.

With Direct Read/Write Direct CCC Commands, the Command Code may be followed by data, such as a Defining Byte. This will be explained in the details for each CCC. Further, each Target access may be a Write with 0 or more data bytes following from the Controller, or it may be a Read with 1 or more data bytes following from the Target, if it has ACKed the Read. The CCC Command Definition for each Direct CCC (see *Section 5.1.9.3*) will explain whether and how it uses the Write and Read.

Each addressed Target Device may either ACK or NACK the Direct CCC Command. For a Read request, the Target Device then returns the requested data in accordance with the SDR Read model, using the T-Bit to end the Read (see *Section 5.1.2.3.4*).

**Note:**

*Future I3C CCC definitions could be extended so as to include additional data bytes beyond the ones specified in this version of the I3C Specification. For this reason, all I3C Controller and Target Devices shall ignore any additional, unrecognized data bytes (i.e., more data bytes than this Specification defines for the given CCC Command).*

### Target Handling of Unsupported Direct CCCs

If the Target detects an unsupported Direct CCC, then the Target shall generate NACK after its own matched (i.e., assigned) Address in the Direct CCC framing, and shall then wait for STOP or Repeated START.

A CCC is considered unsupported in the following cases:

- If the Target detects a Command Code it does not support
- If the Target detects a Defining Byte it does not support, for a Command Code that it does support
- If the Target receives a matching Address (i.e., Dynamic or Group) with Write when it expects (based on that CCC's definition) a Direct Read or Direct GET
- If the Target receives a matching Dynamic Address with Read when it expects (based on that CCC's definition) a Direct Write or Direct SET

**Note:**

*Handling an unsupported CCC is not necessarily associated with Error Type TE5 (see *Section 5.1.10.1.6*), which defines how a Target handles illegally formatted CCCs. The effect of a Target generating NACK for unsupported CCCs could seem identical to the I3C Controller.*

### Optional Defining Bytes

Starting with I3C Basic v1.1.1 and I3C v1.1, some Direct GET CCCs that earlier I3C versions defined as not having Defining Bytes may now optionally use Defining Bytes. This mechanism allows Target behavior to be extended, or for the Target to indicate alternate status or capabilities, based on the Defining Byte value.

**Note:**

*This section does not apply to Direct CCCs that show the Defining Byte field as Required in *Table 16* as well as the CCC's definition in this Specification.*

In these cases, an I3C Target that supports Defining Bytes for such a CCC shall generally treat a Defining Byte value of zero as though the Defining Byte were not present; i.e., the same behavior as if the same CCC had been transmitted with no Defining Byte.

In order to properly distinguish a Direct CCC sent without a Defining Byte from one sent with a Defining Byte, each Target shall track the Command Code value as well as the Defining Byte value (if present), and then respond appropriately when it sees a Repeated START before its own matched Address. In effect, the Target can regard such a Direct CCC either as an 8-bit Command Code, or as a 16-bit Command Code that includes the optional Defining Byte.

If the Target supports a Direct CCC without a Defining Byte, but does not support that same Direct CCC when used with a particular Defining Byte value, then it shall NACK the Direct CCC Command after the Target Address. The Controller shall then assume that the Target does not support that particular Defining Byte for that Direct CCC; however, the Controller shall not infer the presence or absence of any particular Target feature or capability based solely upon the fact that the Target NACKed that particular combination of CCC and Defining Byte. The Controller should also not assume that the Target does not generally support the Direct CCC.

**Note:**

*The Controller is responsible for determining whether the Target supports any given Defining Bytes for a given CCC. Depending on the particular CCC, this can usually be determined by checking other status bits or capabilities advertised by the Target, such as by reading a value returned from a Direct GET CCC without a Defining Byte.*

*The Controller must also determine whether the Target supports Defining Bytes at all (i.e., whether the Target complies with v1.1 or higher of either the I3C Basic Specification or the full I3C Specification). If the Controller attempts to send a Direct CCC with a Defining Byte to a Target that does not comply with either I3C Basic v1.1.1 or higher or I3C v1.1 or higher, then the results may be undefined.*

### 5.1.9.2.3 Retry Model for Direct GET CCC Commands

I3C mandates a single-retry model for Direct GET CCC Commands.

Recall that a Direct GET CCC Command first sends an overall GET command to all Targets using the Broadcast Address 7'h7E, and then sends individual Dynamic Address(es) for each Target, in order to stimulate per-Target response(s). This requires the Target to be in a state allowing an immediate response if its Address is transmitted, but also to be prepared for its Address not to be transmitted (and therefore for the Target not to have to actually respond). For Direct GET CCC Commands that the Target supports in hardware, such as those dealing with information locally known within the Target (like GETBCR), this requirement generally presents no issues. But for Direct GET CCCs supported by the Target's system, or those supported by software in the Target, it's possible that the Target might not be able to respond to the Direct GET CCC in time.

Such situations are handled with the following single-retry model, which applies to Direct GET CCC Commands only.

If a Target cannot provide a response to a Direct GET CCC Command in time, then:

1. The Target shall NACK its Address.
2. The Controller shall then emit a Repeated START, followed by the Target Address. Note that this is a second transmission of the Target Address. This gives the Target extra time to prepare its response. As a further measure to give the Target even more time to prepare its response, the Controller may optionally also employ a clock delay (per *Section 5.1.2.5*) after the Target's NACK and before the Controller's Repeated START.
3. The Target should respond to the retry attempt in step 2 with an ACK, and then transmit the results requested by the Direct GET CCC.

This Retry Model is limited to a single retry. Any Target still unable (for any reason) to respond to the retry attempt from step 2 will NACK it. If a Target NACKs the second attempt in step 2, then the Controller shall not attempt further retries to that Target.

Note that step 2 only occurs if the Target NACKs the original Direct GET CCC request. As a result, this retry model never imposes a time penalty, except in cases where the Target actually needs the extra time.

### 5.1.9.3 CCC Command Definitions

**Table 16** lists all defined I3C Common Command Codes (CCCs). See also **Table 61** and **Table 62**, which specify the HDR Modes in which each CCC can be used. Below **Table 16**, a subsection details each defined CCC.

In **Table 16**:

- The **CCC is Required / Conditional / Optional** column indicates:
  - **R**: The CCC is **Required**. It shall be supported by all I3C Controllers and by all I3C Targets.
  - **C**: The CCC is **Conditionally required**. It shall be supported if the I3C Controller or I3C Target meets the “Required If:” condition shown in the Description column.
  - **O**: The CCC is **Optional**. It may be supported by an I3C Controller or I3C Target at the discretion of the manufacturer.
  - **N**: The CCC is **Not included** in I3C Basic. It shall not be supported by or used by any I3C Basic Devices.

**Note:**

*Other I3C Controller Devices that comply with the full I3C Specification should not expect to use CCCs indicated as **Not included** with an I3C Basic Target Device, and must properly mitigate any resulting interoperability issues.*

When a non-Required CCC is supported by an I3C Device, it shall be implemented as defined in this Specification.

- The **CCC Framing** columns indicate, for CCC fields **Defining Byte** and **Sub-Command Byte**:
  - **R**: The field is **Required** for this CCC (i.e., the CCC’s framing always includes the field).
  - **O**: The field is **Optional** for this CCC (i.e., the CCC’s framing allows the field to be either provided, or not provided).
  - **N**: The field is **Not permitted** for this CCC (i.e., the CCC’s framing never includes the field).

2938

**Table 16 I3C Common Command Codes**

| Command Code | CCC Type  | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                                      | Detailed in Section | Description                                                                                                                                                                                                                                                                                                                           |
|--------------|-----------|------------------------------------------|---------------|------------------|---------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |           |                                          | Defining Byte | Sub-Command Byte |                                                   |                     |                                                                                                                                                                                                                                                                                                                                       |
| <b>0x00</b>  | Broadcast | R                                        | N             | N                | <b>ENECC</b><br>Enable Events Command             | <b>5.1.9.3.1</b>    | Enable Target event driven interrupts<br>Default State: On                                                                                                                                                                                                                                                                            |
| <b>0x01</b>  | Broadcast | R                                        | N             | N                | <b>DISEC</b><br>Disable Events Command            | <b>5.1.9.3.1</b>    | Disable Target event driven interrupts<br>Default State: Off                                                                                                                                                                                                                                                                          |
| <b>0x02</b>  | Broadcast | C <sup>1</sup>                           | N             | N                | <b>ENTAS0</b><br>Enter Activity State 0           | <b>5.1.9.3.2</b>    | Set Activity State 0 (normal operation).<br>Default State: On<br><b>Required If:</b> Target supports any other ENTASx CCC(s) per <b>Section 5.1.9.3.2</b>                                                                                                                                                                             |
| <b>0x03</b>  | Broadcast | O <sup>1</sup>                           | N             | N                | <b>ENTAS1</b><br>Enter Activity State 1           | <b>5.1.9.3.2</b>    | Set Activity State 1<br>Default State: Off                                                                                                                                                                                                                                                                                            |
| <b>0x04</b>  | Broadcast | O <sup>1</sup>                           | N             | N                | <b>ENTAS2</b><br>Enter Activity State 2           | <b>5.1.9.3.2</b>    | Set Activity State 2<br>Default State: Off                                                                                                                                                                                                                                                                                            |
| <b>0x05</b>  | Broadcast | O <sup>1</sup>                           | N             | N                | <b>ENTAS3</b><br>Enter Activity State 3           | <b>5.1.9.3.2</b>    | Set Activity State 3<br>Default State: Off                                                                                                                                                                                                                                                                                            |
| <b>0x06</b>  | Broadcast | R                                        | N             | N                | <b>RSTDAA</b><br>Reset Dynamic Address Assignment | <b>5.1.9.3.3</b>    | Forget current Dynamic Address and wait for new assignment                                                                                                                                                                                                                                                                            |
| <b>0x07</b>  | Broadcast | R <sup>9</sup>                           | N             | N                | <b>ENTDAA</b><br>Enter Dynamic Address Assignment | <b>5.1.9.3.4</b>    | Controller has started the Dynamic Address Assignment procedure.<br>Per <b>Section 5.1.4.2</b> , a Target that supports Dynamic Address Assignment shall participate unless it already has an Address assigned.<br><b>Required If:</b> Target does not have an assigned Static Address, or supports Hot-Join per <b>Section 5.1.5</b> |
| <b>0x08</b>  | Broadcast | C                                        | N             | N                | <b>DEFTGTS</b><br>Define List of Targets          | <b>5.1.9.3.7</b>    | Controller defines Dynamic Address, DCR Type, and Static Address (or 0) per Target<br><b>Required If:</b> There are any Secondary Controllers per <b>Section 5.1.7</b>                                                                                                                                                                |

| Command Code | CCC Type  | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                                                        | Detailed in Section | Description                                                                                                                                                                                                           |
|--------------|-----------|------------------------------------------|---------------|------------------|---------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |           |                                          | Defining Byte | Sub-Command Byte |                                                                     |                     |                                                                                                                                                                                                                       |
| 0x09         | Broadcast | R <sup>6</sup>                           | N             | N                | <b>SETMWL</b><br>Set Max Write Length                               | <b>5.1.9.3.5</b>    | Maximum write length in a single command                                                                                                                                                                              |
| 0x0A         | Broadcast | R <sup>7</sup>                           | N             | N                | <b>SETMRL</b><br>Set Max Read Length                                | <b>5.1.9.3.6</b>    | Maximum read length in a single command                                                                                                                                                                               |
| 0x0B         | Broadcast | O                                        | N             | N                | <b>ENTTM</b><br>Enter Test Mode                                     | <b>5.1.9.3.8</b>    | Controller has entered Test Mode                                                                                                                                                                                      |
| 0x0C         | Broadcast | O                                        | N             | N                | <b>SETBUSCON</b><br>Set Bus Context                                 | <b>5.1.9.3.31</b>   | Controller specifies a higher-level protocol and/or I3C specification version that the Bus will use                                                                                                                   |
| 0xD – 0x11   | –         | N/A                                      | –             | –                | <i>MIPI Reserved</i>                                                | –                   | <i>Reserved for future use by MIPI Alliance</i>                                                                                                                                                                       |
| 0x12         | Broadcast | C                                        | R             | N                | <b>ENDXFER</b><br>Data Transfer Ending Procedure Control            | <b>5.1.9.3.25</b>   | Framework for Controllers and Targets to exchange set-up parameters for ending data transfers in supported HDR Modes<br><b>Required If:</b> Target supports HDR Flow Control per <i>Section 5.2.2.3</i>               |
| 0x13 – 0x1E  | –         | N/A                                      | –             | –                | <i>MIPI Reserved</i>                                                | –                   | <i>Reserved for future use by MIPI Alliance</i>                                                                                                                                                                       |
| 0x1F         | N/A       | C                                        | –             | –                | <b>Reserved</b><br>For use in special CCC flows for HDR Modes only. | <b>5.2.1.2.1</b>    | Dummy command code only, for use during CCC flows in HDR Modes, to signal the end of CCC modality and return to generic HDR transaction<br><b>Required If:</b> Target supports CCC flows in HDR Modes (e.g., HDR-DDR) |
| 0x20         | Broadcast | C <sup>3</sup>                           | N             | N                | <b>ENTHDR0</b><br>Enter HDR Mode 0                                  | <b>5.1.9.3.9</b>    | Controller has entered HDR-DDR Mode<br><b>Required If:</b> Target supports HDR Mode 0 per <i>Section 5.2</i>                                                                                                          |
| 0x21         | Broadcast | N <sup>3</sup>                           | N             | N                | ENTHDR1<br>Enter HDR Mode 1                                         | 5.1.9.3.9           | Controller has entered HDR-TSP Mode<br><i>This HDR Mode is not included in the I3C Basic Specification</i>                                                                                                            |
| 0x22         | Broadcast | N <sup>3</sup>                           | N             | N                | ENTHDR2<br>Enter HDR Mode 2                                         | 5.1.9.3.9           | Controller has entered HDR-TSL Mode<br><i>This HDR Mode is not included in the I3C Basic Specification</i>                                                                                                            |
| 0x23         | Broadcast | C <sup>3</sup>                           | N             | N                | <b>ENTHDR3</b><br>Enter HDR Mode 3                                  | <b>5.1.9.3.9</b>    | Controller has entered HDR-BT Mode<br><b>Required If:</b> Target supports HDR Mode 3 per <i>Section 5.2</i>                                                                                                           |

| Command Code | CCC Type  | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                                     | Detailed in Section | Description                                                                                                                                                                                      |
|--------------|-----------|------------------------------------------|---------------|------------------|--------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |           |                                          | Defining Byte | Sub-Command Byte |                                                  |                     |                                                                                                                                                                                                  |
| 0x24         | Broadcast | N <sup>3</sup>                           | N             | N                | ENTHDR4<br>Enter HDR Mode 4                      | –                   | Controller has entered HDR – Future<br><i>This HDR Mode is not included in the I3C Basic Specification, and not yet defined in the full I3C Specification</i>                                    |
| 0x25         | Broadcast | N <sup>3</sup>                           | N             | N                | ENTHDR5<br>Enter HDR Mode 5                      | –                   | Controller has entered HDR – Future<br><i>This HDR Mode is not included in the I3C Basic Specification, and not yet defined in the full I3C Specification</i>                                    |
| 0x26         | Broadcast | N <sup>3</sup>                           | N             | N                | ENTHDR6<br>Enter HDR Mode 6                      | –                   | Controller has entered HDR – Future<br><i>This HDR Mode is not included in the I3C Basic Specification, and not yet defined in the full I3C Specification</i>                                    |
| 0x27         | Broadcast | N <sup>3</sup>                           | N             | N                | ENTHDR7<br>Enter HDR Mode 7                      | –                   | Controller has entered HDR – Future<br><i>This HDR Mode is not included in the I3C Basic Specification, and not yet defined in the full I3C Specification</i>                                    |
| 0x28         | Broadcast | C                                        | N             | R                | SETXTIME<br>Exchange Timing Information          | 5.1.9.3.21          | Framework for exchanging event timing information<br><b>Required If:</b> Target supports any Timing Control mode per <b>Section 5.1.8</b>                                                        |
| 0x29         | Broadcast | O                                        | N             | N                | SETAASA<br>Set All Addresses to Static Addresses | 5.1.9.3.23          | Controller tells every Target with a Static Address to use it as the Dynamic Address                                                                                                             |
| 0x2A         | Broadcast | R                                        | R             | N                | RSTACT<br>Target Reset Action                    | 5.1.9.3.26          | Configure and query Target Reset action and timing                                                                                                                                               |
| 0x2B         | Broadcast | C                                        | N             | N                | DEFGRPA<br>Define List of Group Address          | 5.1.9.3.29          | Controller tells Secondary Controllers details about an indicated Group Address<br><b>Required If:</b> Device is a Secondary Controller and supports Group Addressing per <b>Section 5.1.4.4</b> |
| 0x2C         | Broadcast | C                                        | N             | N                | RSTGRPA<br>Reset Group Address                   | 5.1.9.3.28          | Controller removes a Target from an indicated Group Address by resetting the assigned Group Address<br><b>Required If:</b> Target supports Group Addressing per <b>Section 5.1.4.4</b>           |
| 0x2D         | Broadcast | C                                        | R             | N                | MLANE<br>Multi-Lane Data Transfer Control        | 5.1.9.3.30          | Control a Multi-Lane Data Transfer<br><b>Required If:</b> Target supports Multi-Lane per <b>Section 5.3</b>                                                                                      |

| Command Code | CCC Type  | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                                                            | Detailed in Section | Description                                                                                                                                                    |
|--------------|-----------|------------------------------------------|---------------|------------------|-------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |           |                                          | Defining Byte | Sub-Command Byte |                                                                         |                     |                                                                                                                                                                |
| 0x2E – 0x48  | –         | N/A                                      | –             | –                | MIPI I3C WG Reserved                                                    | –                   | Reserved for future use by MIPI Alliance I3C WG                                                                                                                |
| 0x49 – 0x4C  | Broadcast | N/A                                      | –             | –                | MIPI Camera WG Reserved – Broadcast CCCs                                | –                   | Reserved for future use by MIPI Alliance Camera Working Group                                                                                                  |
| 0x4D – 0x57  | Broadcast | N/A                                      | –             | –                | MIPI Reserved – Broadcast CCCs                                          | –                   | Reserved for future use by other MIPI Working Groups                                                                                                           |
| 0x58 – 0x5B  | Broadcast | N/A                                      | –             | –                | MIPI Debug WG Reserved – Broadcast CCCs                                 | –                   | Reserved for use by MIPI Alliance Debug Working Group                                                                                                          |
| 0x5C – 0x60  | Broadcast | N/A                                      | –             | –                | MIPI RIO WG Reserved – Broadcast CCCs                                   | –                   | Reserved for use by MIPI Alliance R/O Working Group                                                                                                            |
| 0x61 – 0x7F  | Broadcast | N/A                                      | –             | –                | Vendor / Standards Extension – Broadcast CCCs                           | –                   | For Vendor or Standards <sup>10</sup> use                                                                                                                      |
| 0x80         | Direct    | R                                        | N             | N                | <b>ENECC</b><br>Enable Events Command                                   | 5.1.9.3.1           | Enable Target event driven interrupts<br>Default State: On                                                                                                     |
| 0x81         | Direct    | R                                        | N             | N                | <b>DISEC</b><br>Disable Events Command                                  | 5.1.9.3.1           | Disable Target event driven interrupts<br>Default State: Off                                                                                                   |
| 0x82         | Direct    | C <sup>1</sup>                           | N             | N                | <b>ENTAS0</b><br>Enter Activity State 0                                 | 5.1.9.3.2           | Set Activity Mode to State 0 (normal operation).<br>Default State: On<br><b>Required If:</b> Target supports any other ENTASx CCC per <b>Section 5.1.9.3.2</b> |
| 0x83         | Direct    | O <sup>1</sup>                           | N             | N                | <b>ENTAS1</b><br>Enter Activity State 1                                 | 5.1.9.3.2           | Set Activity State 1<br>Default State: Off                                                                                                                     |
| 0x84         | Direct    | O <sup>1</sup>                           | N             | N                | <b>ENTAS2</b><br>Enter Activity State 2                                 | 5.1.9.3.2           | Set Activity State 2<br>Default State: Off                                                                                                                     |
| 0x85         | Direct    | O <sup>1</sup>                           | N             | N                | <b>ENTAS3</b><br>Enter Activity State 3                                 | 5.1.9.3.2           | Set Activity State 3<br>Default State: Off                                                                                                                     |
| 0x86         | Direct    | R                                        | –             | –                | <b>DEPRECATED:</b><br>RSTDAA Direct<br>Reset Dynamic Address Assignment | 5.1.9.3.3           | v1.1 Controllers shall not use<br>v1.0 Controllers should not use<br>v1.1 Targets shall NACK                                                                   |

| Command Code | CCC Type   | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                                              | Detailed in Section | Description                                                                                                                                                                                             |
|--------------|------------|------------------------------------------|---------------|------------------|-----------------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |            |                                          | Defining Byte | Sub-Command Byte |                                                           |                     |                                                                                                                                                                                                         |
| 0x87         | Direct Set | O                                        | N             | N                | <b>SETDASA</b><br>Set Dynamic Address from Static Address | <b>5.1.9.3.10</b>   | Controller assigns a Dynamic Address to a Target with a known Static Address.                                                                                                                           |
| 0x88         | Direct Set | C <sup>9</sup>                           | N             | N                | <b>SETNEWDA</b><br>Set New Dynamic Address                | <b>5.1.9.3.11</b>   | Controller assigns a new Dynamic Address to any I3C Target with an existing Dynamic Address<br><b>Required If:</b> ENTDAA is supported                                                                  |
| 0x89         | Direct Set | R <sup>2</sup>                           | N             | N                | <b>SETMWL</b><br>Set Max Write Length                     | <b>5.1.9.3.5</b>    | Maximum write length in a single command                                                                                                                                                                |
| 0x8A         | Direct Set | R <sup>2</sup>                           | N             | N                | <b>SETMRL</b><br>Set Max Read Length                      | <b>5.1.9.3.6</b>    | Maximum read length in a single command                                                                                                                                                                 |
| 0x8B         | Direct Get | R <sup>2</sup>                           | N             | N                | <b>GETMWL</b><br>Get Max Write Length                     | <b>5.1.9.3.5</b>    | Get Target's maximum possible write length                                                                                                                                                              |
| 0x8C         | Direct Get | R <sup>2</sup>                           | N             | N                | <b>GETMRL</b><br>Get Max Read Length                      | <b>5.1.9.3.6</b>    | Get Target's maximum possible read length                                                                                                                                                               |
| 0x8D         | Direct Get | C                                        | N             | N                | <b>GETPID</b><br>Get Provisioned ID                       | <b>5.1.9.3.12</b>   | Get Target's Provisioned ID<br><b>Required If:</b> ENTDAA is supported                                                                                                                                  |
| 0x8E         | Direct Get | C                                        | N             | N                | <b>GETBCR</b><br>Get Bus Characteristics Register         | <b>5.1.9.3.13</b>   | Get Target's Bus Characteristic Register (BCR)<br><b>Required If:</b> ENTDAA is supported                                                                                                               |
| 0x8F         | Direct Get | C                                        | N             | N                | <b>GETDCR</b><br>Get Device Characteristics Register      | <b>5.1.9.3.14</b>   | Get a Device's Device Characteristics Register (DCR)<br><b>Required If:</b> ENTDAA is supported                                                                                                         |
| 0x90         | Direct Get | R                                        | O             | N                | <b>GETSTATUS</b><br>Get Device Status                     | <b>5.1.9.3.15</b>   | Get a Device's operating status                                                                                                                                                                         |
| 0x91         | Direct Get | C                                        | N             | N                | <b>GETACCCR</b><br>Get Accept Controller Role             | <b>5.1.9.3.16</b>   | Active Controller is passing the Bus Controller Role to a Secondary Controller and confirming its acceptance<br><b>Required If:</b> There are Secondary Controllers per <b>Section 5.1.7</b>            |
| 0x92         | Direct     | C                                        | R             | N                | <b>ENDXFER</b><br>Data Transfer Ending Procedure Control  | <b>5.1.9.3.25</b>   | Framework for Controllers and Targets to exchange set-up parameters for ending data transfers in supported HDR Modes<br><b>Required If:</b> Target supports HDR Flow Control per <b>Section 5.2.2.3</b> |

| Command Code | CCC Type   | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                                                                        | Detailed in Section | Description                                                                                                                                                                                                          |
|--------------|------------|------------------------------------------|---------------|------------------|-------------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |            |                                          | Defining Byte | Sub-Command Byte |                                                                                     |                     |                                                                                                                                                                                                                      |
| 0x93         | Direct Set | O                                        | N             | N                | <b>SETBRGTGT</b><br>Set Bridge Targets                                              | <b>5.1.9.3.17</b>   | Controller tells Bridge (to/from I <sup>2</sup> C, SPI, UART, etc.) what endpoints it is talking to (by Dynamic Address and type/ID)                                                                                 |
| 0x94         | Direct Get | C <sup>4</sup>                           | O             | N                | <b>GETMXDS</b><br>Get Max Data Speed                                                | <b>5.1.9.3.18</b>   | Controller asks Target for its SDR Mode maximum. Read and Write data speeds (& optionally maximum Read Turnaround time)<br><b>Required If:</b> Target has BCR Bit[0] set to 1'b1 per <a href="#">Section 5.1.2.1</a> |
| 0x95         | Direct Get | C <sup>5, 8</sup>                        | O             | N                | <b>GETCAPS</b><br>(formerly <b>GETHDCAPS</b> )<br>Get Optional Feature Capabilities | <b>5.1.9.3.19</b>   | Controller asks Target what optional capabilities it supports<br><b>Required If:</b> The Target's I3C Basic version is v1.1 or later                                                                                 |
| 0x96         | Direct     | O                                        | N             | N                | <b>SETROUTE</b><br>Set Route                                                        | <b>5.1.9.3.20</b>   | Controller tells Routing Device what Route(s) to enable                                                                                                                                                              |
| 0x97         | Direct     | N                                        | –             | –                | D2DXFER<br>Device to Device(s) Tunneling Control                                    | <b>5.1.9.3.24</b>   | <i>This CCC is not included in the I3C Basic Specification.</i>                                                                                                                                                      |
| 0x98         | Direct     | C                                        | N             | R                | <b>SETXTIME</b><br>Set Exchange Timing Information                                  | <b>5.1.9.3.21</b>   | Framework for exchanging event timing information<br><b>Required If:</b> Target supports any Timing Control Mode per <a href="#">Section 5.1.8</a>                                                                   |
| 0x99         | Direct     | C                                        | N             | N                | <b>GETXTIME</b><br>Get Exchange Timing Information                                  | <b>5.1.9.3.22</b>   | Framework for exchanging event timing information<br><b>Required If:</b> Target supports any Timing Control Mode per <a href="#">Section 5.1.8</a>                                                                   |
| 0x9A         | Direct     | R                                        | R             | N                | <b>RSTACT</b><br>Target Reset Action                                                | <b>5.1.9.3.26</b>   | Configure and query Target Reset action and timing                                                                                                                                                                   |
| 0x9B         | Direct     | C                                        | N             | N                | <b>SETGRPA</b><br>Set Group Address                                                 | <b>5.1.9.3.29</b>   | Controller assigns Group Addresses<br><b>Required If:</b> Target supports Group Addressing per <a href="#">Section 5.1.4.4</a>                                                                                       |
| 0x9C         | Direct     | C                                        | N             | N                | <b>RSTGRPA</b><br>Reset Group Address                                               | <b>5.1.9.3.28</b>   | Controller removes a Target from an indicated Group Address by resetting the assigned Group Address<br><b>Required If:</b> Target supports Group Addressing per <a href="#">Section 5.1.4.4</a>                      |
| 0x9D         | Direct     | C                                        | R             | N                | <b>MLANE</b><br>Multi-Lane Data Transfer Control                                    | <b>5.1.9.3.30</b>   | Control a Multi-Lane Data Transfer<br><b>Required If:</b> Target supports Multi-Lane per <a href="#">Section 5.3</a>                                                                                                 |

| Command Code | CCC Type | CCC is Required / Conditional / Optional | CCC Framing   |                  | Command Name                               | Detailed in Section | Description                                        |
|--------------|----------|------------------------------------------|---------------|------------------|--------------------------------------------|---------------------|----------------------------------------------------|
|              |          |                                          | Defining Byte | Sub-Command Byte |                                            |                     |                                                    |
| 0x9E – 0xBF  | Direct   | N/A                                      | –             | –                | MIPI I3C WG Reserved – Direct CCCs         | –                   | Reserved for future use by MIPI Alliance I3C WG    |
| 0xC0 – 0xC3  | Direct   | N/A                                      | –             | –                | MIPI Camera WG Reserved – Direct CCCs      | –                   | Reserved for future use by MIPI Alliance Camera WG |
| 0xC4 – 0xD6  | Direct   | N/A                                      | –             | –                | MIPI Reserved – Direct CCCs                | –                   | Reserved for future use by other MIPI Alliance WGs |
| 0xD7 – 0xDA  | Direct   | N/A                                      | –             | –                | MIPI Debug WG Reserved – Direct CCCs       | –                   | Reserved for use by MIPI Alliance Debug WG         |
| 0xDB – 0xDF  | Direct   | N/A                                      | –             | –                | MIPI RIO WG Reserved – Direct CCCs         | –                   | Reserved for use by MIPI Alliance RIO WG           |
| 0xE0 – 0xFE  | Direct   | N/A                                      | –             | –                | Vendor / Standards Extension – Direct CCCs | –                   | For Vendor or Standards <sup>10</sup> use          |
| 0xFF         | –        | N/A                                      | –             | –                | MIPI I3C WG Reserved                       | –                   | Reserved for future use by MIPI Alliance I3C WG    |

**Note:**

- 1) Target Devices may self-power-manage based on this information.
- 2) Applies to Target Devices that support a variable limit on the maximum number of data bytes per Message, where that limit may exceed 16 bytes.
- 3) All I3C compliant Targets shall recognize that the Bus is entering an HDR Mode, and detect the HDR Exit Pattern.
- 4) This CCC shall be supported by Target Devices with Bus Control Register (BCR) Bit[0] set to 1'b1.
- 5) This CCC shall be supported by Target Devices that support any HDR Mode.
- 6) See **Section 5.1.9.3.5 Set/Get Max Write Length (SETMWL/GETMWL)**.
- 7) See **Section 5.1.9.3.6 Set/Get Max Read Length (SETMRL/GETMRL)**.
- 8) This CCC shall be supported by all I3C Basic v1.1.1 Devices. However, it was not included in v1.0 of the I3C Basic Specification (see **Section 5.1.9.3.19**).
- 9) A Target Device that will only ever be used on special-purpose I3C Buses that do not require Enter DAA may choose to not implement support for the ENTDAA CCC. (Such special-purposes I3C Buses use static addresses via SETAASA/SETDASA instead of ENTDAA). Such a Target may also choose not to implement support for the SETNEWDA CCC, per **Section 5.1.9.3.11**; in this case, the Target's Static Address effectively becomes its fixed Dynamic Address.
- 10) Standards use of Vendor CCC's controlled by Bus Context. (See **Section 5.1.9.3.31** and public registry at [https://www.mipi.org/MIPI\\_I3C\\_bus\\_context\\_byte\\_values\\_public.html](https://www.mipi.org/MIPI_I3C_bus_context_byte_values_public.html) [MIP107].

### 5.1.9.3.1 Enable/Disable Target Events Command (ENEC/DISEC)

These four Direct (*Figure 32*) or Broadcast (*Figure 33*) CCCs allows the Controller to control when Target-initiated traffic is allowed (i.e., Enabled) vs. is not allowed (i.e., Disabled) on the I3C Bus. This control governs a Target's attempts to request an Interrupt (ENINT/DISINT), to request the Controller Role (ENCR/DISCR), or to signify a Hot-Join event (ENHJ/DISHJ).

**Table 17 Enable/Disable Target Events Command Codes (ENEC/DISEC)**

| Command      | Support  | Command Codes |        | Purpose               |
|--------------|----------|---------------|--------|-----------------------|
|              |          | Broadcast     | Direct |                       |
| <b>ENEC</b>  | Required | 0x00          | 0x80   | Enable Target Events  |
| <b>DISEC</b> | Required | 0x01          | 0x81   | Disable Target Events |



**Figure 32 ENEC/DISEC Format 1: Direct**



**Figure 33 ENEC/DISEC Format 2: Broadcast**

2947 **Table 18** and **Table 19** show the bits to set in the Target Events Byte to enable and disable, respectively, the four supported I3C Target/Secondary Controller event  
 2948 types. Reserved bits are for future MIPI use.

**Table 18 Enable Target Events Command Byte Format**

| Bit 7    | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2    | Bit 1 | Bit 0 |
|----------|-------|-------|-------|-------|----------|-------|-------|
| Reserved |       |       |       | ENHJ  | Reserved | ENCR  | ENINT |

**Table 19 Disable Target Events Command Byte Format**

| Bit 7    | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2    | Bit 1 | Bit 0  |
|----------|-------|-------|-------|-------|----------|-------|--------|
| Reserved |       |       |       | DISHJ | Reserved | DISCR | DISINT |

2951 The supported I3C Target/Secondary Controller event types are:

- **Target Interrupt Requests:** Enable (ENINT) / Disable (DISINT)

2952 These bits allow the Controller to control when Target-initiated (i.e., In-Band) Interrupts are (ENINT) and are not (DISINT) allowed on the I3C Bus.

2953 Note that this capability is enabled by default in Targets that support In-Band Interrupt capability.

- **Controller Role Requests:** Enable (ENCR) / Disable (DISCR)

2954 These bits allow the Active Controller to control when Controller Role Requests from Secondary Controllers are (ENCR) and are not (DISCR) allowed  
 2955 on the I3C Bus.

2956 This capability shall be enabled by default in Secondary Controllers that support Controller Role Request capability.

- **Hot-Join Event:** Enable (ENHJ) / Disable (DISHJ)

2957 These bits allow the Controller to control when Target-initiated Hot-Join is (ENHJ) and is not (DISHJ) allowed on the I3C Bus. The Controller can  
 2958 Broadcast this CCC in order to command Devices to refrain from making Dynamic Address Assignment requests until later authorized by the Controller,  
 2959 in case the Controller isn't ready to service the Hot-Joining Device(s). (Hot-Join events are asynchronous.)

2960 This capability shall be enabled by default in Targets that support Hot-Join capability.

### 5.1.9.3.2 Enter Activity State 0–3 (ENTAS0–ENTAS3)

These four Direct (*Figure 34*) and four Broadcast (*Figure 35*) CCCs allow the Active Controller to inform one or all Target Devices that it will not be active on the I3C Bus for an approximated amount of time, so that the Target Devices may use a lower power state during that period (see *Section 5.1.3.3*). There is one Direct CCC and one Broadcast CCC per Activity State.

**Note:**

*These CCCs do not place any requirements on Target Devices; they merely signal the Active Controller's intent to be inactive, i.e., a lower power state. However, all I3C Target Devices shall maintain I3C communications capabilities in all Activity States, regardless of the Active Controller's state.*

Table 20 Enter Activity State 0–3 Command Codes (ENTAS0–ENTAS3)

| Command | Support     | Command Codes |        | Purpose                |
|---------|-------------|---------------|--------|------------------------|
|         |             | Broadcast     | Direct |                        |
| ENTAS0  | Conditional | 0x02          | 0x82   | Enter Activity State 0 |
| ENTAS1  | Optional    | 0x03          | 0x83   | Enter Activity State 1 |
| ENTAS2  | Optional    | 0x04          | 0x84   | Enter Activity State 2 |
| ENTAS3  | Optional    | 0x05          | 0x85   | Enter Activity State 3 |



Figure 34 ENTASx Format 1: Direct



Figure 35 ENTASx Format 2: Broadcast

**Table 21** gives the expected minimum Bus activity interval for each Activity State.

Table 21 Enter Activity State CCCs (ENTASx)

| CCC           | Activity State   | Minimum Bus Activity Interval     |
|---------------|------------------|-----------------------------------|
| <b>ENTAS0</b> | Activity State 0 | 1 $\mu$ s: Latency-free operation |
| <b>ENTAS1</b> | Activity State 1 | 100 $\mu$ s                       |
| <b>ENTAS2</b> | Activity State 2 | 2 ms                              |
| <b>ENTAS3</b> | Activity State 3 | 50 ms: Lowest-activity operation  |

### 5.1.9.3.3 Reset Dynamic Address Assignment (RSTDAA)

This Broadcast CCC (*Figure 36*) indicates to all I3C Devices that the Controller requires them to clear/reset their Controller-assigned Dynamic Address. If the I3C Device supports the Group Address feature, then receipt of an RSTDAA CCC shall also reset (clear) all of its assigned Group Addresses. After clearing their Dynamic Address, the Devices shall be ready to participate in an I3C procedure such as Dynamic Address Assignment (*Section 5.1.4*), SETDASA (*Section 5.1.9.3.10*), or SETAASA (*Section 5.1.9.3.23*), or is configured to communicate via I<sup>2</sup>C (though without a Spike Filter).

The Command Code for the RSTDAA Broadcast CCC is 0x06. Support for this CCC is required.



Figure 36 RSTDAA Format

### 5.1.9.3.4 Enter Dynamic Address Assignment (ENTDAA)

This Broadcast CCC (*Figure 37*) indicates to all I3C Devices that the Controller requires them to enter the Dynamic Address Assignment procedure described in *Section 5.1.4*. Target Devices that already have a Dynamic Address assigned shall not respond to this command.

The Command Code for the ENTDAA Broadcast CCC is 0x07. Support for this CCC is required, unless this I3C Device has an I<sup>2</sup>C Static Address.



Figure 37 ENTDAA Format

### 5.1.9.3.5 Set/Get Max Write Length (SETMWL/GETMWL)

These Direct and Broadcast CCCs (Direct Set or Get in *Figure 38*, Broadcast Set in *Figure 39*) allow the I3C Controller to Set or Get a maximum data write length in bytes for one or all Target Devices. This Max Write Length does not affect data write lengths for Broadcast CCCs, since their data payloads are defined for each CCC. The Set/Get Max Write Length value is transmitted over two bytes, with the most significant byte (MSB) transmitted first. The minimum value that Max Write Length can be set to is 16 bytes.

This CCC is required if (and only if) any private Write Message(s) and/or any extended Write CCC(s) implemented by the Target Device support a variable limit on the maximum number of data bytes per Message, and this limit is greater than 16 bytes. This allows the Target to limit the number of bytes the Controller sends. A Target Device with no such settable limit may optionally support this CCC, but is not expected to do so. A return of 0 by the Target to GETMWL means a value less than 16 bytes.

**Table 22 Set/Get Max Write Length Command Codes (SETMWL/GETMWL)**

| Command       | Support   | Command Codes |        | Purpose              |
|---------------|-----------|---------------|--------|----------------------|
|               |           | Broadcast     | Direct |                      |
| <b>SETMWL</b> | See above | 0x09          | 0x89   | Set Max Write Length |
| <b>GETMWL</b> | See above | –             | 0x8B   | Get Max Write Length |



**Figure 38 Direct SETMWL/GETMWL Format**

3000  
3001



Figure 39 Broadcast SETMWL Format

### 5.1.9.3.6 Set/Get Max Read Length (SETMRL/GETMRL)

These Direct and Broadcast CCCs (Direct Set or Get in *Figure 40*, Broadcast Set in *Figure 41*) allow the I3C Controller to Set or Get a maximum data read length, and optionally a maximum IBI payload size.

The Set/Get Max Read Length value is transmitted over the first two bytes, with most significant byte (MSB) transmitted first. The minimum value to which Max Read Length can be set is 16 bytes. A return of 0 by the Target to GETMRL means a value less than 16 bytes.

For Devices with BCR bit 2 set to 1'b1, the Max IBI payload size value is added as a third byte, where a value of 0 indicates an unlimited payload size. If Timing Control is used, then the minimum IBI payload size is either four bytes or five bytes, per the Timing Control method that is supported. If Timing Control (see *Section 5.1.8*) is not used, then the minimum IBI payload size is one (one byte).

This CCC is optional for the Target, with two exceptions:

1. This CCC is required if both (a) any private Read Request Message(s) and/or any extended Read Request CCC(s) implemented by the Target support a variable limit on the maximum number of data bytes that the Target may return per Message, and (b) this limit is greater than 16 bytes.
2. This CCC is required if the Target both (a) supports an IBI Payload (as indicated with BCR bit 2), and (b) will transmit more than one byte of private payload (not counting Timing Control bytes, when Timing Control used).

**Table 23 Set/Get Max Read Length Command Codes (SETMRL/GETMRL)**

| Command       | Support   | Command Codes |        | Purpose             |
|---------------|-----------|---------------|--------|---------------------|
|               |           | Broadcast     | Direct |                     |
| <b>SETMRL</b> | See above | 0x0A          | 0x8A   | Set Max Read Length |
| <b>GETMRL</b> | See above | —             | 0x8C   | Get Max Read Length |



**Figure 40 Direct SETMRL/GETMRL Format**

3017  
3018



Figure 41 Broadcast SETMRL Format

### 5.1.9.3.7 Define List of Targets (DEFTGTS)

3019 **Note:**

3020 In previous versions of the I3C Basic Specification (as well as some versions of the full I3C Specification), this CCC was named “DEFSLVS”. The usage and  
3021 data format for this CCC are unchanged.

3022 This Broadcast CCC (*Figure 42*) is only relevant to Secondary Controllers. This CCC tells Secondary Controller Devices what Targets (and Groups) are present  
3023 on the I3C Bus, via four consecutive Data Bytes per Target (or Group). First the Active Controller identifies itself by transmitting its own data in the first set of  
3024 four data bytes, using the value 7'h7E as the Static Address. Then each additional Target or Group on the I3C Bus is represented by a further set of four data bytes.

3025 If the Active Controller supports the Group Address function, then the Active Controller shall then send the Secondary Controllers any configured Group Address  
3026 information, using the DEFTGTS CCC in the same manner used to transmit the Dynamic Address information. Each Group is treated as a virtual I3C Device on  
3027 the I3C Bus, described by: Group Address, reserved DCR, BCR, and Static Address as defined below. The Group Address bytes may be transmitted within the  
3028 same DEFTGTS CCC message as the Target Devices.

3029 The Command Code for the DEFTGTS Broadcast CCC is 0x08. All Secondary Controllers are required to support this CCC.



**Figure 42 DEFTGTS Format**

3032 **Count** is the number of Targets and Groups present on the I3C Bus. Each Target or Group is represented by a set of four data bytes, as specified in *Table 24*.

3033  
3034  
3035  
3036

**Note:**  
For each configured Group Address, the DEFGRPA CCC (see [Section 5.1.9.3.29](#)) is used to provide more information about the Group, such as the list of I3C Targets that have been assigned to that Group Address.

**Table 24 DEFTGTS Data Bytes for Target or Group**

| Field                  | Byte | For Target                                                                                                                                                                                                                                                                      | For Group                                                                                                                                                                    |
|------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Dynamic Address</b> | 0    | The 7 most significant bits (Bits[7:1]) shall contain the current value of the Target's assigned 7-bit Dynamic Address.<br>The least significant bit (Bit[0]) is filled with the value 1'b0.<br>For a Legacy I <sup>2</sup> C Device, this field shall contain the value 7'h00. | The Group Address                                                                                                                                                            |
| <b>DCR Type</b>        | 1    | The Target's Device Characteristics Register value, or the value 0x00 if unknown.<br>For a Legacy I <sup>2</sup> C Device, this field shall contain the value of the Device's Legacy Virtual Register (LVR).                                                                    | This field shall contain the value 8'hFF (all 1's), to indicate that a Group is being described.<br>See <a href="#">Section 5.1.1.2.2</a> for how to identify a Group value. |
| <b>BCR Type</b>        | 2    | The Target's Bus Characteristics Register value, or 0x00 if unknown.                                                                                                                                                                                                            | Reserved for Group information<br>This field shall not be used as a BCR.                                                                                                     |
| <b>Static Address</b>  | 3    | The Target's original 7-bit static I <sup>2</sup> C Address in the 7 most significant bits (Bits[7:1]), with the least significant bit (Bit[0]) filled with the value 1'b0.<br>If no Static Address, then the value shall be 7'h00.                                             | Reserved for Group information                                                                                                                                               |

3037 The Active Controller shall not send the DEFTGTS CCC unless at least one Secondary Controller Device is present on the I3C Bus. The Active Controller shall  
3038 send the DEFTGTS CCC following every Hot-Join event (i.e., after each Dynamic Address Assignment), and as necessary, i.e., when any Dynamic Address or  
3039 Group Address changes must be sent to Secondary Controller Devices.

### 5.1.9.3.8 Enter Test Mode (ENTTM)

This Broadcast CCC (*Figure 43*) informs all I3C Devices that the Controller is entering a specified Test Mode during manufacturing or Device test. The Enter Test Mode command Frame format includes a byte that specifies which Test Mode to enter. Supporting I3C Devices shall enter the indicated Test Mode upon receipt of the Enter Test Mode CCC. *Table 25* lists the defined Test Mode byte values.

The Command Code for the ENTTM Broadcast CCC is 0x0B. Support for this CCC is optional.



**Figure 43 ENTTM Format**

**Table 25 ENTTM Test Mode Byte Values**

| Byte Value  | I3C Test Mode    | Description                                                                                                                                    |
|-------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00        | Exit Test Mode   | This value removes all I3C Devices from Test Mode                                                                                              |
| 0x01        | Vendor Test Mode | This value indicates that I3C Devices shall return a random 32-bit value in the Provisioned ID during the Dynamic Address Assignment procedure |
| 0x02 – 0xFF | MIPI Reserved    | Reserved for future use by MIPI Alliance                                                                                                       |

### 5.1.9.3.9 Enter HDR Mode 0–7 (ENTHDR0–ENTHDR7)

These eight Broadcast CCCs inform all I3C Devices that the Bus is being switched into the indicated HDR Mode. See the indicated Section of this Specification for further details on each HDR Mode.

Support for each CCC shall depend on whether the I3C Device supports the associated HDR Mode (see *Section 5.2*).

**Note:**

*Of the eight possible HDR Modes, only HDR Mode 0 (HDR-DDR) and HDR Mode 3 (HDR-BT) are included in I3C Basic. To gain access to the capabilities of the other HDR Modes, please contact MIPI Alliance.*

**Table 26 Enter HDR Mode CCCs (ENTHDRx)**

| Command        | Command Code<br>(All are Broadcast) | Enter HDR Mode | HDR Mode Name                                                           | Supported in<br>I3C Basic? | See Section          |
|----------------|-------------------------------------|----------------|-------------------------------------------------------------------------|----------------------------|----------------------|
| <b>ENTHDR0</b> | 0x20                                | HDR Mode 0     | HDR-DDR                                                                 | Y                          | <b>Section 5.2.2</b> |
| ENTHDR1        | 0x21                                | HDR Mode 1     | HDR-TSP                                                                 | N                          | <b>Section 5.2.3</b> |
| ENTHDR2        | 0x22                                | HDR Mode 2     | HDR-TSL                                                                 | N                          | <b>Section 5.2.3</b> |
| <b>ENTHDR3</b> | 0x23                                | HDR Mode 3     | HDR-BT                                                                  | Y                          | <b>Section 5.2.4</b> |
| ENTHDR4        | 0x24                                | HDR Mode 4     | HDR Modes 4–7 are<br>Reserved for future definition<br>by MIPI Alliance |                            |                      |
| ENTHDR5        | 0x25                                | HDR Mode 5     |                                                                         |                            |                      |
| ENTHDR6        | 0x26                                | HDR Mode 6     |                                                                         |                            |                      |
| ENTHDR7        | 0x27                                | HDR Mode 7     |                                                                         |                            |                      |

### 5.1.9.3.10 Set Dynamic Address from Static Address (SETDASA)

This CCC (*Figure 44* and *Figure 45* illustrate the two distinct command formats) allows the Controller to assign a Dynamic Address to one Target using the Target's Static Address. This is faster than the ENTDAA Dynamic Address Assignment procedure (see *Section 5.1.9.3.4*). The SETDASA CCC should be used before the ENTDAA CCC is used; all Targets without assigned Dynamic Addresses will respond to the ENTDAA CCC.

**Note:**

The SETDASA Command Code is unusual in that it addresses the desired I<sup>2</sup>C Target by its I<sup>2</sup>C Static Address, rather than by its assigned Dynamic Address. As a result, this CCC can only be sent to a Target that has an I<sup>2</sup>C Static Address.

Per *Section 5.1.4.2*, SETDASA is intended as an optimization. An I<sup>2</sup>C Target that supports SETDASA and does not support ENTDAA cannot be relied on to be assigned a Dynamic Address on a generic I<sup>2</sup>C Bus, and also will not support Hot-Join (per *Section 5.1.5*). Use of SETDASA requires the I<sup>2</sup>C Controller to have prior knowledge of the I<sup>2</sup>C Target. Dynamic Address Assignment with ENTDAA is generally recommended for most use cases.

The newly assigned Address is transmitted in the Dynamic Address Byte shown in *Figure 44*, where the 7 most significant bits (Bits[7:1]) contain the 7-bit Dynamic Address, and the least significant bit (Bit[0]) is filled with the value 1'b0.

The Command Code for the SETDASA Direct CCC is 0x87. Support for this CCC is optional; however, the I<sup>2</sup>C Target that supports this CCC must have an I<sup>2</sup>C Static Address.



Figure 44 SETDASA Format 1: Primary

### SETDASA Minimal Bus Point-to-Point Communication

The SETDASA CCC may also be specially used for simple point-to-point communication in I3C Minimal Bus use cases (per **Section 5.1.1** and **Figure 11**). An I3C Minimal Bus is an I3C Bus with one I3C Controller Device (potentially with reduced functionality), and one I3C Target Device. In this special usage of the SETDASA CCC, the Controller Device both uses the fixed value 7'h01 as the Static Address, and uses the fixed (and reserved) value of 7'h01 as the Dynamic Address (see **Figure 45**). This special usage of the SETDASA CCC allows for simpler Controller Devices, and optionally simpler Target Devices intended for use specifically in Minimal Bus configurations.

I3C Target Devices should support this special usage of the SETDASA CCC unless such support would make the Target Device unusable in a Minimal Bus use case. A Target Device supporting this special Minimal Bus usage of the SETDASA CCC shall match the Static Address 7'h01, and then accept 7'h01 as its new Dynamic Address (same as the natural result of SETDASA). The Target Device may choose to behave differently after receiving its Dynamic Address in this manner.

An I3C Controller shall not use this special form of the SETDASA CCC unless the I3C Bus is known to have precisely one Controller and:

**Either:**

- One active I3C Target Device that is capable of supporting this special usage of the SETDASA CCC,

**Or:**

- One or more I3C Target Devices that act strictly as receivers, i.e., that do not use In-Band Interrupt and that will not be sent Read requests. This arrangement permits a single Controller Device to, in effect, Broadcast to the Target Devices.



Figure 45 SETDASA Format 2: Point-to-Point

### 5.1.9.3.11 Set New Dynamic Address (SETNEWDA)

This Direct CCC (*Figure 46*) allows the I3C Controller to assign a new Dynamic Address to one I3C Target or Secondary Controller. In the Dynamic Address field, the 7 most significant bits (Bits[7:1]) contain the 7-bit Dynamic Address, and the least significant bit (Bit[0]) is filled with the value 1'b0.

If an I3C Target (or Secondary Controller) supports this CCC and accepts the new 7-bit Dynamic Address from the Controller via this CCC, then this shall change its current Dynamic Address. After accepting the new Dynamic Address, the Target (or Secondary Controller) shall respond to subsequent transactions that are directly addressed to this new Dynamic Address (per *Section 5.1.2.1*) and not to the previous Dynamic Address.

**Note:**

*This CCC may only be used to change the currently assigned Dynamic Address, which must be initially assigned via any supported method (per **Section 5.1.4.2**). If an I3C Target (or Secondary Controller) has not received its Dynamic Address via the ENTDAA CCC (i.e., Dynamic Address Assignment) or via the SETAASA and/or SETDASA CCCs (i.e., from an I<sup>2</sup>C Static Address), then it cannot respond to the SETNEWDA CCC.*

*In version 1.0 of the I3C Basic Specification, all I3C Targets were required to support this CCC. Starting with I3C Basic version 1.1, this CCC is now required only for Targets that also implement support for Dynamic Address Assignment via the ENTDAA CCC (see **Section 5.1.9.3.4**). This CCC is now optional for Targets that have I<sup>2</sup>C Static Addresses and do not support the ENTDAA CCC; therefore, such Targets must only receive Dynamic Addresses via the SETAASA and/or SETDASA CCCs (per **Section 5.1.4.2**). For most Targets with I<sup>2</sup>C Static Addresses and that do not support the ENTDAA CCC, support for the SETNEWDA CCC is recommended; however, if such a Target does not support the SETNEWDA CCC, then it shall not respond (i.e., shall NACK its current Dynamic Address).*

The Command Code for the SETNEWDA Direct CCC is 0x88. Support for this CCC is required, unless the I3C Target has an I<sup>2</sup>C Static Address and does not support the ENTDAA CCC.



Figure 46 SETNEWDA Format

### 5.1.9.3.12 Get Provisioned ID (GETPID)

This Direct CCC (see *Figure 25* and *Figure 47*) is a Get request for one I3C Target Device to return its 48-bit Provisioned ID to the Controller, as described in *Section 5.1.4*. Following transmission of the GETPID CCC, the 48-bit value is transmitted as 6 bytes, with MSB first.

The Command Code for the GETPID Direct CCC is 0x8D. If an I3C Target supports Dynamic Address Assignment with the ENTDAAC CCC, then it shall also support this CCC. If an I3C Target does not support Dynamic Address Assignment with the ENTDAAC CCC, then support for this CCC is optional.



Figure 47 GETPID Format

### 5.1.9.3.13 Get Bus Characteristics Register (GETBCR)

This Direct CCC (*Figure 48*) is a Get request for one I3C Target Device to return its Bus Characteristics Register (BCR) to the Controller, as described in [Section 5.1.1.2.1](#). The BCR value is transmitted in one byte, with the MSb transmitted first.

The Command Code for the GETBCR Direct CCC is 0x8E. If an I3C Target supports Dynamic Address Assignment with the ENTDAAC CCC, then it shall also support this CCC. If an I3C Target does not support Dynamic Address Assignment with the ENTDAAC CCC, then support for this CCC is optional.



Figure 48 GETBCR Format

### 5.1.9.3.14 Get Device Characteristics Register (GETDCR)

This Direct CCC (*Figure 49*) is a Get request for one I3C Target Device to return its Device Characteristics Register (DCR) to the Controller, as described in [Section 5.1.1.2.2](#). The DCR value is transmitted in one byte, with the MSb transmitted first.

The Command Code for the GETDCR Direct CCC is 0x8F. If an I3C Target supports Dynamic Address Assignment with the ENTDAAC CCC, then it shall also support this CCC. If an I3C Target does not support Dynamic Address Assignment with the ENTDAAC CCC, then support for this CCC is optional.



Figure 49 GETDCR Format

### 5.1.9.3.15 Get Device Status (GETSTATUS)

This Direct CCC is a Get request for one I3C Target Device to return its current Status.

It has two formats:

- GETSTATUS Format 1 (*Figure 50*) returns the two-byte format detailed in *Table 27*.
- The optional GETSTATUS Format 2 (*Figure 51*) adds a Defining Byte (*Table 28*) and returns a variable number of data bytes. The number of data bytes returned and their format depend upon the Defining Byte value. GETSTATUS Format 2, including its Defining Byte value PRECR, is detailed below.

The Command Code for the GETSTATUS Direct CCC is 0x90. Support for this CCC is required.



Figure 50 GETSTATUS Format 1

3131

**Table 27 GETSTATUS MSB-LSB Format 1**

| Byte       | Bits        | Field                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MSB</b> | <b>15:8</b> | <b>Vendor Reserved</b>   | Reserved for vendor-specific meaning.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>LSB</b> | <b>7:6</b>  | <b>Activity Mode</b>     | <p>Contains the two-bit ID of the Target Device's current Activity Mode (i.e., its readiness to support data read of sensor or related information).</p> <p>A Controller-capable Device (i.e., Secondary Controller) must use this field to indicate when it is unable to participate in any of the steps to prepare for Handoff of the Controller Role (see <b>Section 5.1.7.1</b>). If such a Device is currently unable to participate, then it shall return a value of 2'b11. Any other value shall indicate that the Device may be ready to participate.</p> <p>For all other Target Devices, the meanings of the four possible values are not defined by this Specification; instead, they depend upon a private contract between the Controller and each Target.</p> |
|            | <b>5</b>    | <b>Protocol Error</b>    | 1'b1: The Target detected a protocol error since the last Status read. The Target might or might not be able to check for such errors. Note that this value self-clears upon every successful completion of a Controller read of the Target's Status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|            | <b>4</b>    | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|            | <b>3:0</b>  | <b>Pending Interrupt</b> | Contains the interrupt number of any pending interrupt, or 0 if no interrupts are pending. This encoding allows for up to 15 numbered interrupts. If more than one interrupt is set, then the highest priority interrupt shall be returned.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## GETSTATUS Format 2

The optional GETSTATUS Format 2 (*Figure 51*) adds a Defining Byte (*Table 28*) and returns a variable number of data bytes. The number of data bytes returned and their format depend upon the Defining Byte value.

Support for the GETSTATUS Format 2 CCC is optional, typically depending upon the Device's role, capabilities, or other extended behavior. Before using GETSTATUS Format 2 for a given Target, a Controller shall determine whether that Target supports it. One way is to send the GETCAPS Format 1 CCC (no Defining Byte) and find that in Byte 3 (GETCAP3) of the data that the Target returns, bit 4 contains 1'b1 (see *Table 37*)

GETSTATUS Format 2 conforms to the CCC Direct General Frame Format (*Figure 31*):

- **If the addressed Target Device does not support the given Defining Byte value for GETSTATUS Format 2:** Then the Target shall NACK its Target Address, thus terminating the Direct CCC.
- **If the addressed Target Device does support the given Defining Byte value for GETSTATUS Format 2:** Then the Target shall ACK its Target Address and return the requested data byte(s). The number of data bytes returned shall depend on the particular Defining Byte and its associated capabilities, as detailed below.
- **If the addressed Target Device is unable to immediately respond to the GETSTATUS Format 2 CCC with the given Defining Byte:** Then, per the Retry Model for Direct GET CCC Commands (*Section 5.1.9.2.3*), the Target shall NACK the first attempt, and then the Controller shall attempt a single retry. If the Controller receives a NACK after a retry, then the Controller shall assume that the Target does not support the GETSTATUS Format 2 CCC with the given Defining Byte, and hence cannot return data describing any capabilities corresponding to that Defining Byte value. In most cases the Controller can proceed as though it had read a value equivalent to all zeros as a default value. However, a NACK after a retry does not guarantee that the Target does not possess any capability or feature set associated with the given Defining Byte value.

A Target that supports the GETSTATUS Format 2 CCC (i.e., GETSTATUS with any optional Defining Bytes) shall return a value of 1'b1 in bit 4 of Byte 3 (GETCAP3), when the GETCAPS CCC is sent without a Defining Byte. A Controller that sees that bit set to 1'b1 will know that the Target is capable of supporting at least one Defining Byte with the GETSTATUS Format 2 CCC. The ACK/NACK method explained above allows the Target to indicate which Defining Byte values it actually supports.



Figure 51 GETSTATUS Format 2

Table 28 GETSTATUS Format 2 Defining Byte Values

| Value       | Encoding          | Description                                                                                                                                                                                                                                                                                                       | Data Bytes Returned |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| 0x00        | TGTSTAT           | Returns Target Status (standard format). Equivalent to GETSTATUS Format 1 (without a Defining Byte).                                                                                                                                                                                                              | 2                   |
| 0x01 – 0x90 | Reserved          | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                            | —                   |
| 0x91        | PRECR             | Returns alternate Status format describing a Controller-capable Device (i.e., Secondary Controller) per subsection below.<br>Recommended if an I3C Device is both compliant with I3C Basic Specification v1.1 or higher, and advertises as Controller-capable (i.e., if the value of the BCR[7:6] bits is 2'b01). | 2                   |
| 0x92 – 0xBF | Reserved          | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                            | —                   |
| 0xC0 – 0xDF | Reserved          | Reserved for future definition by other MIPI Alliance WGs                                                                                                                                                                                                                                                         | —                   |
| 0xE0 – 0xFE | Vendor Extensions | For Vendor use                                                                                                                                                                                                                                                                                                    | —                   |
| 0xFF        | Reserved          | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                            | —                   |

## Get Secondary Controller Status (GETSTATUS Format 2, Defining Byte PRECR)

3156 **Note:**

3157     *This Section describes the GETSTATUS Format 2 CCC when the value of the Defining Byte is 0x91 (PRECR)*

3158 Support for the GETSTATUS Format 2 CCC with the PRECR Defining Byte is optional. All Controller-capable Devices should support the GETSTATUS Format  
3159 2 CCC with the PRECR Defining Byte while in Target mode, if they might enter such a deep sleep state, or might require significant time to recover and/or re-  
3160 synchronize their internal state based on Broadcast data sent by the Active Controller.

3161 This Direct CCC (*Figure 52*) allows the Active Controller to query a Controller-capable (i.e., Secondary Controller) I3C Device, to read the current state of the  
3162 Device (*Table 29*) in order to determine whether it entered a “deep sleep” state during which it might have missed any Broadcast DEFTGTS CCCs or DEFGRPA  
3163 CCCs sent by the Active Controller, or is currently processing data from these Broadcast CCCs and is unable to safely accept the Controller Role until it has  
3164 finished processing that data and updated its internal state.

3165 It is anticipated that some classes of Controller-capable Devices operating as a Secondary Controller (i.e., in Target mode) may enter a deep sleep state, and hence  
3166 may not only miss these Broadcast CCCs while in that state, but may also require a significant amount of time (from the perspective of the Bus and the Active  
3167 Controller) to process these Broadcast CCCs sent by the Active Controller in an attempt to re-synchronize all Secondary Controller Devices, in preparation for a  
3168 Controller Role handoff. If such a Device has entered a deep sleep state, then the Device shall indicate this state until it has received at least one Broadcast  
3169 DEFTGTS CCC from the Active Controller. It is also expected that such a Device will remain active for a sufficient amount of time (i.e., after indicating its current  
3170 Secondary Controller Status and processing the Broadcast CCC data received from the Active Controller) to ensure that it does not re-enter a deep sleep state which  
3171 would invalidate any efforts to bring it back online and up to date.

3172 When receiving the GETSTATUS Format 2 CCC with the PRECR Defining Byte, the Device returns its Status using the two-byte format detailed in *Table 29*.

3173 A Device that is not Controller-capable shall NACK its Target Address, to indicate that it does not support the GETSTATUS Format 2 CCC with the PRECR  
3174 Defining Byte.

3175 It is the responsibility of the Active Controller to determine whether a Controller-capable Device supports the GETSTATUS Format 2 CCC with the PRECR  
3176 Defining Byte, and whether the deep sleep handling and re-synchronization is necessary before a Controller Role handoff.

3177 **Resynchronization:** A Secondary Controller that may require re-synchronization due to a returning from a deep sleep state shall indicate this capability when the  
3178 GETCAPS CCC is sent with a Defining Byte value of CRCAPS (see *Section 5.1.9.3.19*). A Controller that sees that this capability is indicated knows that it then  
3179 needs to send the GETSTATUS Format 2 CCC with Defining Byte value PRECR to read the current Secondary Controller Status from this Device, in order to  
3180 determine its need to re-synchronize from a deep sleep state, or check to see whether it is processing the Broadcast CCC data, before expecting this Device to  
3181 successfully ACK the GETACCCR CCC as part of the Controller Role handoff.

3182 **Additional Time:** A Secondary Controller requiring additional time to process data from these Broadcast CCCs sent by the Active Controller shall indicate this  
3183 capability when the GETCAPS CCC is sent with a Defining Byte value of CRCAPS (see *Section 5.1.9.3.19*). If the Controller sees that capability is indicated, then  
3184 it shall send this CCC with Defining Byte value PRECR to poll the Device, in order to frequently check its Status and determine when it has finished processing  
3185 this data. This Secondary Controller shall indicate its current processing Status, by returning a value of 1'b1 in Bit[1] in the alternate Status two-byte format detailed  
3186 below, until it has finished processing the data and can accept the Controller Role.



Figure 52 GETSTATUS Format 2 with Defining Byte PRECR

Table 29 Status Bytes for GETSTATUS Format 2 with Defining Byte PRECR

| Byte       | Bits        | Field                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MSB</b> | <b>15:8</b> | <b>Vendor Reserved</b>             | Reserved for vendor-specific meaning.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|            | <b>7:2</b>  | <b>Reserved</b>                    | Reserved for future definition by MIPI Alliance I3C WG.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>LSB</b> |             | <b>1</b> <b>Handoff Delay NACK</b> | <p>This bit indicates whether this Device is currently processing any DEFTGTS CCC (and DEFGRPA CCC, if supported) Broadcasts that may have been sent by the Active Controller. It is expected that this Device might take significant time to process the data in such Broadcasts.</p> <p><b>1'b1:</b> The Active Controller may wait to send GETACCCR CCC to this Device, or should at least be aware that any attempts to send GETACCCR CCC to this Device will be met with a NACK response, until this bit is read again later with a value of 1'b0, to indicate that the Device has finished processing the data in these Broadcasts and has updated its internal state.</p> <p><b>1'b0:</b> This Device is not currently processing Broadcast data, or has finished processing this data; in either case, it can safely accept the Controller Role.</p> |
|            | <b>0</b>    | <b>Deep Sleep Detected</b>         | <p>This bit indicates whether this Device has entered a “deep sleep” state, in which it might have missed any DEFTGTS CCC (and DEFGRPA CCC, if supported) Broadcasts sent by the Active Controller. Consequently, this Device’s internal state of known Target Devices (and known Group Addresses, if applicable) should be considered outdated.</p> <p><b>1'b1:</b> The Active Controller is obligated to send a fresh Broadcast of DEFTGTS CCC (and DEFGRPA CCC, if applicable and supported) to update this Device’s internal state before sending GETACCCR CCC to this Device.</p> <p><b>1'b0:</b> This Device has not entered a “deep sleep” state, or is not capable of doing so.</p>                                                                                                                                                                  |

### 5.1.9.3.16 Get Accept Controller Role (GETACCCR)

This Direct GET CCC (*Figure 53*) is used both to verify a Controller Role Request, if received earlier, and to allow the Active Controller to offer (i.e., to pass) the Controller Role to an I3C Secondary Controller, even if it was not previously requested. The GET is used to confirm acceptance; to do so, the Secondary Controller returns its 7-bit Dynamic Address as shown in *Figure 53*. The value of the 7-bit Dynamic Address will be the same as the value of the Target Address. If the Secondary Controller does not accept, then it shall NACK the Get request as shown in *Figure 54*.

A Secondary Controller requesting the Controller Role will gain the Controller Role only if all three of the following steps occur in the indicated order. The Active Controller may offer the Controller Role after preparing for handoff as detailed in *Section 5.1.7.1*.

1. The Active Controller transmits a GETACCCR command to the Secondary Controller.
2. The Secondary Controller correctly replies with its 7-bit Dynamic Address. The value of the 7-bit Dynamic Address will be the same as the value of the Target Address.

If the Secondary Controller instead responds with NACK (*Figure 54*), or with an incorrect 7-bit Address (*Figure 55*), then:

- The Secondary Controller will not acquire the Controller Role
- The GETACCCR command is canceled, and
- The Active Controller can then either (a) Retry the CCC, or (b) Simply issue a Repeated START followed by 7'h7E to cancel (*Figure 55*).

3. The Active Controller issues a STOP and then begins the Controller to Controller Handoff Procedure per *Section 5.1.7.2*.

If the Active Controller instead issues a Repeated START, then:

- The Secondary Controller will not gain the Controller Role
- The GETACCCR command is canceled (*Figure 55*), and
- The Active Controller can then either (a) Retry the CCC, or (b) End the transaction by providing a STOP.

The Command Code for the GETACCCR Direct CCC is 0x91. If a Controller-capable Device (e.g., a Primary Controller or Secondary Controller) intends to pass the Controller Role to another Controller-capable Device, then it shall support this CCC. All Secondary Controller Devices (i.e., those that initialize as Secondary Controllers) should support this CCC.



Figure 53 GETACCCR Format 1: Accepted

Note:

The value of the 7-Bit Dynamic Address will be the same as the value of the Target Address, and PAR is odd parity:  $\sim\text{XOR}(\text{Target Address}[7:1])$ .



Figure 54 GETACCCR Format 2: Not Accepted



Figure 55 GETACCCR Format 3: Incorrect Cancel

### 5.1.9.3.17 Set Bridge Targets (SETBRGTGT)

This Direct CCC (*Figure 56*) is only relevant to Bridge Devices. An I3C Controller shall only send this CCC to known Bridge Devices that accept it.

The Command Code for the SETBRGTGT Direct CCC is 0x93. Support for this CCC is optional.



**Figure 56 SETBRGTGT Format**

**Target Addr** is the I3C Dynamic Address of the Bridge Device.

**Count** is the number of bridged endpoints that will be exposed as Targets.

Each described bridged Target is represented by two fields:

- **Dynamic Address**: The 7 most significant bits (Bits[7:1]) contain the Target's assigned 7-bit Dynamic Address, and the least significant bit (Bit[0]) is filled with the value 1'b0. For Legacy I<sup>2</sup>C Devices, the value of the Dynamic Address shall be 7'h00.
- **ID**: A 16-bit unambiguous identifier for the bridged Target (two bytes)

The meaning of the ID field is not defined by this Specification, and should be a contract between the Bridge and the Controller (or any other entity that supplies such information to the Controller). For example, the upper nibble of the MSB could indicate the communication type (e.g., I<sup>2</sup>C, SPI, UART, LIN, etc.), and the remaining 12 bits (i.e., lower nibble of MSB plus full LSB) could be the port (as port number and Device selector).

3232   **Note:**

- 3233   1. If the Controller needs to change the Dynamic Address of a bridged Target that was configured using SETBRGTGT, then the change shall be performed  
3234   using an updated SETBRGTGT, and not SETNEWDA.
- 3235   2. The Controller shall not rely on each bridged Target having a unique BCR, DCR, or PID; so, use of GETBCR, GETDCR, and GETPID may return the  
3236   same result for each.
- 3237   3. The Controller shall not rely on each bridged Target handling directed CCCs as unique. So, for example, SETMRL to one bridged Target may affect all  
3238   Targets accessed via the same bridge.
- 3239   4. Use of GETMXDS is recommended for bridged Targets, such that each may return its own appropriate values based on protocol being bridged to.

### 5.1.9.3.18 Get Max Data Speed (GETMXDS)

The Controller uses this Direct CCC (there are three formats: *Figure 58*, *Figure 59*, and *Figure 60*) to determine the SDR Mode data speed limitations of one Target Device. The Controller is required to use this CCC only when Bit[0] of the addressed Target Device's Bus Control Register (BCR) is set to 1'b1 (see *Table 5*). A Target Device is required to support this CCC only when Bit[0] of its Bus Control Register (BCR) is set to 1'b1 (see *Table 5*).

Bit[0] of the Bus Characteristics Register shall be set in any Target Device with a Clock-to-Data turnaround time greater than 12 ns. Target Devices within the t<sub>SCO</sub> delay range should not set the limitation bit (i.e., Bit[0]) unless other limitations exist. But Devices should support this CCC to allow better factoring of each number when computing the maximum effective frequency for reads, since the Controller/System-designer can be told the t<sub>SCO</sub> parameter along with line length (propagation time), line capacitance, number of Targets, and stubs if present.

As shown in *Figure 147*, the t<sub>SCO</sub> delay is the measurement of the total internal delay from the SCL input to the start of SDA output (see also *[MIPI03]*), excluding other factors like line capacitance and path delay that are factored out of the Device computation and put into the broader computation. The t<sub>SCO</sub> delay is applicable to both Controller Devices and Target Devices, since Controller Devices may behave as Target Devices in a Multi-Controller system based on the system configuration.



$t_1$ : Time from Clock Flop Q to Pad

$t_2$ : Time through output pad (PFET/NFET)  
(tested over  $90\ \Omega$ ,  $50\ pF$  line C)

$t_3$ : Time over wires pad-pad: Controller drive + Line Cap + Tpath

$t_4$ : Time through input pad of Target

$t_5$ : Time inside Target, from SCL input to SDA out ( $t_{SCO}$ )  
(to gate drive of SDA)

$t_6$ : Time through output pad of Target

$t_7$ : Time over wires pad-pad: Target drive + Line Cap + Tpath

$t_8$ : Time through iData input pad (Schmitt input)

$t_9$ : Time from iData pad to D input for serializer

#### LEGEND

- - - Internal delay (excluding pads)
- - - PAD delays on a standard Bus model

Figure 57 Components of Clock-to-Data Turnaround Delay ( $t_{SCO}$ )

3253 Any Target Devices with a Clock-to-Data turnaround ( $t_{SCO}$ ) delay greater than 12 ns shall set the Clock to Data Turnaround field of the maxRD Byte to 3'b111 and  
3254 report this value to the Controller by private agreement.

3255 Maximum Read Turnaround Time is used to notify the Controller how long to wait before reading the data it requested. This allows the Controller to get the Target  
3256 Device's turnaround delay time for data read requests (excluding In-Band Interrupt responses). This is useful because some Targets may exhibit data read delays  
3257 (as contrasted with CCC reads) due to clock-starting effects, bridging, slower inner processors, etc. The Controller can use the returned delay factor to avoid  
3258 NACKs that would result from reading the Device too soon. The Target may have the data ready before the time reported, and the Controller can also estimate the  
3259 time and retry reading before the maximum Read Turnaround time. The Controller should be aware that any NACKs for read requests from the Target before the  
3260 maximum time is a normal condition, and no recovery methods are required; by contrast, NACKs after the maximum Data Turnaround time shall be dealt with  
3261 accordingly.

3262 Bit[6] of the maxRd byte indicates whether the Controller may insert a STOP between the Write (index) and the Read. If the value of Bit[6] is 1'b1, then the  
3263 Controller can use the extra time for other communications or end the communication and re-initiate it at the appropriate time. If the value of Bit[6] is 1'b0, then  
3264 the Controller shall keep within one Frame. If the Maximum Read Turnaround time is more than a few micro-seconds, then the Target should permit STOP between  
3265 the Write and Read.

3266 **Note:**

3267     *This CCC relates to bit data rates and Read Turnaround times, not data sizes. Data sizes are the subject of the CCCs Get Max Read Length (GETMRL, see*  
3268     **Section 5.1.9.3.6**) and Get Max Write Length (GETMWL, see **Section 5.1.9.3.5**).

3269 The Target Device shall return:

3270 **Either:**

- 3271 • **GETMXDS Format 1:** Two data bytes containing the Target Device's Maximum Write Speed and Maximum Read Speed (see *Figure 58*),

3272 **Or:**

- 3273 • **GETMXDS Format 2:** Five data bytes containing the Target Device's Maximum Write Speed, Maximum Read Speed, and a three-byte Maximum Read  
3274 Turnaround Time (see *Figure 59*).

3275 The Target signals which Format it is returning via the number of returned data bytes: Two bytes indicates Format 1, and five bytes indicates Format 2.

3276 The Target's selection of Format 1 vs. Format 2 should be based upon whether Maximum Read Turnaround Time needs to be communicated to the Controller  
3277 Device.

3278 Interpretation of the returned fields maxWr, maxRd, and (for Format 2 only) maxRdTurn is shown in *Table 30*, *Table 31*, and *Table 32* respectively.

3279 When reading the GETMXDS value from a Target, the SCL clock rate should be slowed (by frequency or duty cycle) to accommodate a possible slow Clock-to-  
3280 Data turnaround ( $t_{SCO}$ ). This is only needed if the BCR bit has indicated a limitation. If BCR is not known (e.g., if SETDASA or SETAASA was used), then either  
3281 read GETBCR slowly, or simply read GETMXDS slowly no matter what. See also **Section 5.1.4 BCR Use** in the *MIPI I3C System Integrators App Note [MIPI03]*.

3282 The Command Code for the GETMXDS Direct CCC is 0x94. Support for this CCC is required if Bit[0] of the I3C Target's Bus Control Register (BCR) is set to  
3283 1'b1.



3288

**Table 30 maxWr Byte Format**

| <b>Bits</b> | <b>Field</b>                                                                                       | <b>Description</b>                                                                                                                                                                     |
|-------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4         | Reserved                                                                                           | Reserved for future use by MIPI Alliance                                                                                                                                               |
| 3           | <b>Defining Byte Support</b>                                                                       | Does this I3C Device support an optional Defining Byte for this CCC?<br><b>0:</b> No<br><b>1:</b> Yes                                                                                  |
| 2:0         | <b>Maximum Sustained Data Rate for non-CCC Messages sent by Controller Device to Target Device</b> | <b>Values:</b><br><b>0:</b> $f_{SCL}$ Max (default value)<br><b>1:</b> 8 MHz<br><b>2:</b> 6 MHz<br><b>3:</b> 4 MHz<br><b>4:</b> 2 MHz<br>5–7: Reserved for future use by MIPI Alliance |

3289

**Table 31 maxRd Byte Format**

| <b>Bits</b> | <b>Field</b>                                                                                       | <b>Description</b>                                                                                                                                                                                                                                                            |
|-------------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7           | Reserved                                                                                           | Reserved for future use by MIPI Alliance                                                                                                                                                                                                                                      |
| 6           | <b>Write-to-Read Permits Stop Between</b>                                                          | If maxRdTurn is not 0, then this field is used to tell the Controller whether the Target permits the Write-to-Read to be split by a STOP.<br><b>0:</b> STOP would cancel the Read<br><b>1:</b> The Target permits the Write-to-Read to be split by a STOP.                    |
| 5:3         | <b>Clock to Data Turnaround Time (tsco)</b>                                                        | <b>Values:</b><br><b>0:</b> $\leq 8$ ns (default value)<br><b>1:</b> $\leq 9$ ns<br><b>2:</b> $\leq 10$ ns<br><b>3:</b> $\leq 11$ ns<br><b>4:</b> $\leq 12$ ns<br>5–6: Reserved for future use by MIPI Alliance<br>7: tsco is $> 12$ ns, and is reported by private agreement |
| 2:0         | <b>Maximum Sustained Data Rate for non-CCC Messages sent by Target Device to Controller Device</b> | <b>Values:</b><br><b>0:</b> $f_{SCL}$ Max (default value)<br><b>1:</b> 8 MHz<br><b>2:</b> 6 MHz<br><b>3:</b> 4 MHz<br><b>4:</b> 2 MHz<br>5–7: Reserved for future use by MIPI Alliance                                                                                        |

3290

Table 32 maxRdTurn Format

| Byte | Field                  | Description                                                              |
|------|------------------------|--------------------------------------------------------------------------|
| 0    | Least Significant Byte | Maximum Read Turnaround Time in $\mu$ s.                                 |
| 1    | Middle Byte            |                                                                          |
| 2    | Most Significant Byte  | 24-bit field can encode turnaround times from 0.0 seconds to 16 seconds. |

### GETMXDS Format 3

3291 Additionally, some I3C Devices may support this CCC with an optional Defining Byte (*Figure 60*), to return other capabilities based on the value of the Defining Byte.  
3292 This support may be required as part of the Device's role, capabilities, or other extended behavior. It is the Controller's responsibility to determine whether  
3293 the Device supports this CCC with an optional Defining Byte. The Controller may determine whether the Target has such support, by first sending this CCC without  
3294 a Defining Byte, and checking for a value of 1'b1 in bit 3 of Byte 1 (maxWr) in the data read from the Target (see *Table 31*).



Figure 60 GETMXDS Format 3: With Defining Byte

3295 To read the other Device capabilities accessed via a Defining Byte, the Controller shall send this CCC with a Defining Byte, according to the CCC Direct General  
3296 Frame Format (*Figure 31*). If the Device identified by the Target Address does not support a particular Defining Byte value for this CCC, then it shall NACK its  
3297 Target Address to terminate the Direct CCC. If the Device does support a particular Defining Byte, then it shall ACK its Target Address and return additional bytes  
3298 of data. The length of the data returned shall depend on the particular Defining Byte and its associated capabilities (see *Table 33* for supported Defining Byte  
3299 values; see subsections below for specifics per Defining Byte value).  
3300  
3301

3302

**Table 33 GETMXDS Defining Byte Values**

| <b>Value</b>       | <b>Encoding</b>          | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>0x00</b>        | <b>WRRDTURN</b>          | Describes standard (Target) Write/Read speed parameters, and optional Maximum Read Turnaround time. Equivalent to the GETMXDS CCC without a Defining Byte.                                                                                                                                                                                                                             |
| 0x01 – 0x90        | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                 |
| <b>0x91</b>        | <b>CRHDLY</b>            | Describes delay parameters for a Controller-capable (i.e., Secondary Controller) Device, and its expected Activity State during the Controller handoff (see subsection below). Recommended if an I3C Device is compliant with version 1.1 or higher of the I3C Basic Specification, and if it advertises itself as Controller-capable (i.e., if BCR bits 7:6 contain the value 2'b01). |
| 0x92 – 0xBF        | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                 |
| 0xC0 – 0xDF        | Reserved                 | Reserved for future definition by other MIPI Alliance WGs                                                                                                                                                                                                                                                                                                                              |
| <b>0xE0 – 0xFE</b> | <b>Vendor Extensions</b> | For Vendor use                                                                                                                                                                                                                                                                                                                                                                         |
| 0xFF               | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                 |

3303 According to the Retry Model for Direct GET CCC Commands, if a Device cannot provide an immediate response to this CCC with a particular Defining Byte,  
 3304 then it shall NACK the first attempt, and then the Controller shall attempt a single retry (see *Section 5.1.9.2.3*). If the Controller receives a NACK after a retry,  
 3305 then the Controller shall assume that the Device does not support this CCC with this particular Defining Byte, and hence has no data that would be returned for  
 3306 any capabilities relating to that Defining Byte value. In most cases, the Controller may proceed as though it read a value equivalent to all zeros as a default value.  
 3307 However, a NACK after a retry should not be interpreted as meaning that the Device does not possess a capability or feature set associated with that Defining Byte  
 3308 value.

3309 A Target that supports this CCC with any optional Defining Bytes shall return a value of 1'b1 in bit 3 of Byte 1 (maxWr) when this CCC is sent without a Defining  
 3310 Byte. If the Controller sees that bit set to 1'b1, then it knows that the Target is capable of supporting at least one Defining Byte with this CCC. The ACK/NACK  
 3311 method explained above allows the Target to indicate which Defining Byte values it actually supports.

### Get Controller Handoff Delay Parameters (GETMXDS Format 3, Defining Byte CRHDLY)

This Direct CCC with Defining Byte value CRHDLY (*Figure 61*) allows the Active Controller to query a Controller-capable (i.e., Secondary Controller) I3C Device, to read what optional Controller handoff delays or other timing parameters that Device will utilize. It is anticipated that a Device may advertise these parameters, to indicate whether it will enter an Activity State that requires the Active Controller to wait for an appropriate delay, before confirming its Controller Role or attempting the CE3 Error Recovery flow.

It is recommended that all Controller-capable Devices should support this CCC with this Defining Byte in Target mode. If such a Device does not follow the default delay settings, or if it indicates other non-default timing parameters, then the Device shall support this Defining Byte.

A Controller-capable Device may return one data byte, labeled CRHDLY1 per *Figure 61*.

A Device that is not Controller-capable shall NACK its Target Address, to indicate that it does not support this CCC with this particular Defining Byte.

Fields within the CRHDLY1 Byte are detailed in *Table 34*.



Figure 61 GETMXDS Format 3 With Defining Byte CRHDLY

3323

**Table 34 CRHDLY1 Byte Format**

| <b>Bits</b> | <b>Field</b>                             | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3         | Reserved                                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2           | <b>Set Bus Activity State</b>            | <p>This bit indicates whether the Active Controller should set the Bus to the Activity State indicated in bits 1:0 before handing the Controller Role off to this I3C Device as part of the normal flow.</p> <p><b>Values:</b></p> <p><b>0:</b> The Active Controller should not set the Bus to any Activity State before handoff to this Device.</p> <p><b>1:</b> The Active Controller should set the Bus to the Activity State indicated by bits 1:0 before handoff to this Device.</p> <p><i>For the Activity States and their delay intervals, see <b>Table 11</b>.</i></p>                                                                                                                                                                                                                                                                                                                                                           |
| 1:0         | <b>Controller Handoff Activity State</b> | <p>This 2-bit integer indicates whether this I3C Device initially acts with a given Activity State, after becoming Active Controller on the Bus according to the Controller handoff flow. The indicated Activity State implies that the Device may have a delayed response to Bus activity, and so the former Controller should wait the specified delay time for the indicated Activity State before testing this Device, to confirm that it is controlling the Bus before initiating the CE3 error recovery flow.</p> <p><b>Values:</b></p> <p><b>0:</b> Acts according to Activity State 0.</p> <p><b>1:</b> Acts according to Activity State 1.</p> <p><b>2:</b> Acts according to Activity State 2.</p> <p><b>3:</b> Acts according to Activity State 3.</p> <p><i>For the Activity States and their delay intervals, see <b>Table 11</b>.</i></p> <p><i>For the Error Type CE3 recovery flow, see <b>Section 5.1.10.2.4</b>.</i></p> |

### 5.1.9.3.19 Get Optional Feature Capabilities (GETCAPS)

This Direct CCC allows the Controller to query an I3C Target to determine what optional I3C features that Target supports. It replaces the GETHDRCAP CCC, which was defined in version 1.0 of the full I3C Specification.

**Note:**

All I3C Targets that support I3C Basic version 1.1 or greater shall support Format 1 of the GETCAPS CCC.

It has two formats:

- For **GETCAPS Format 1** (*Figure 62*) the I3C Target may return the first 2, 3, or all 4 of the GETCAP1 through GETCAP4 Bytes shown in *Figure 62*. Fields within each GETCAPx Byte are detailed in *Table 35* through *Table 38*.
  - If the I3C Target supports I3C Basic version 1.1 or greater, then it must return at least the first 2 data bytes (GETCAP1 and GETCAP2).
- The optional **GETCAPS Format 2** (*Figure 63*) adds a Defining Byte (*Table 39*) and returns a variable number of data bytes. The number of data bytes returned and their format depend upon the Defining Byte value. GETCAPS Format 2 is detailed below.

The Command Code for the GETCAPS Direct CCC is 0x95. Support for this CCC is required for all I3C Targets.



Figure 62 GETCAPS Format 1

**Note:**

An I3C Controller that supports I3C Basic version 1.1 or greater might be used with an I3C Target Device that supports version 1.0 of the full I3C Specification. In this case, such an I3C Target might support some HDR Modes (such as HDR-DDR), and might only return one byte (i.e., only the GETCAP1 Byte) as a response to the GETCAPS CCC (see note in *Table 5*). Therefore, the I3C Controller must recognize this as a valid configuration, even though the I3C Target would return just a single byte and would have limited capabilities. *Figure 62* is provided as a reference for I3C Target Devices that support version 1.1 of the I3C Basic Specification and must return at least 2 bytes as a response to the GETCAPS CCC.

3343

**Table 35 GETCAP1 Byte Format**

| <b>Bit 7</b>                  | <b>Bit 6</b>                  | <b>Bit 5</b>                  | <b>Bit 4</b>                  | <b>Bit 3</b>           | <b>Bit 2</b>                                       | <b>Bit 1</b>                                       | <b>Bit 0</b>            |
|-------------------------------|-------------------------------|-------------------------------|-------------------------------|------------------------|----------------------------------------------------|----------------------------------------------------|-------------------------|
| HDR Mode 7<br><i>Reserved</i> | HDR Mode 6<br><i>Reserved</i> | HDR Mode 5<br><i>Reserved</i> | HDR Mode 4<br><i>Reserved</i> | HDR Mode 3<br>(HDR-BT) | HDR Mode 2<br><i>Not included<br/>in I3C Basic</i> | HDR Mode 1<br><i>Not included<br/>in I3C Basic</i> | HDR Mode 0<br>(HDR-DDR) |

**Note:**

3344 The HDR Modes marked “Not included in I3C Basic” in **Table 35** are defined in the full I3C Specification but not included in I3C Basic. To gain access to these capabilities, please contact MIPI Alliance.

3345 An I3C Target that supports I3C Basic shall not indicate support for any of the HDR Modes marked “Not included in I3C Basic” in **Table 35**.

3346 An I3C Controller that supports any version of the I3C Basic Specification might receive a GETCAP1 Byte from an I3C Target that supports the full I3C Specification, and might also support some of the HDR Modes marked “Not included in I3C Basic”. In such a case, the I3C Controller must ignore any such HDR Modes in the GETCAP1 Byte that are indicated as supported by the I3C Target, as the I3C Controller would not have the capability to support such HDR Modes (since such HDR Modes are not included in the I3C Basic Specification).

3352

**Table 36 GETCAP2 Byte Format**

| Bits | Field                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | <b>HDR-DDR Abort CRC</b>                   | Is this I3C Target capable of emitting the CRC Word when a transaction in HDR-DDR Mode is aborted?<br><b>0:</b> No<br><b>1:</b> Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6    | <b>HDR-DDR Write Abort</b>                 | Is this I3C Target capable of issuing the Write Abort in HDR-DDR Mode?<br><b>0:</b> No<br><b>1:</b> Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5:4  | <b>Group Address Capabilities</b>          | This 2-bit integer indicates the Group Address function capabilities of this I3C Device.<br><b>Values:</b><br><b>0:</b> Does not support Group Address function<br><b>1:</b> Can be assigned one Group Address<br><b>2:</b> Can be assigned two Group Addresses<br><b>3:</b> Can be assigned three or more Group Addresses                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0  | <b>I3C Basic 1.x Specification Version</b> | This 4-bit integer indicates the minor version number of the MIPI I3C Basic Specification with which this I3C Basic v1.x Device complies. That is, the 'x' in "I3C Basic v1.x".<br><b>Examples:</b><br>If Bits[3:0] are set to 4'b0001 (decimal 1), then the Device complies with I3C Basic v1.1.1 or possible future v1.1.y<br>If Bits[3:0] are set to 4'b0010 (decimal 2), then the Device complies with possible future I3C Basic v1.2 or v1.2.y<br><b>Note:</b><br><i>An I3C Device that complies with the full I3C Specification shall use the same encoding to indicate the version number of the full I3C Specification to which it complies.</i><br><b>Note:</b><br><i>Bits[3:0] set to 4'b0000 is an illegal value.</i> |

3353

**Table 37 GETCAP3 Byte Format**

| Bit | Field                                                | Description                                                                                                                                                                                                                                                                                                                  |
|-----|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | Reserved                                             | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                       |
| 6   | <b>IBI MDB Support for Pending Read Notification</b> | Does this I3C Target expect that it can send In-Band Interrupt requests with a specific range of Mandatory Data Byte values to indicate a Pending Read Notification, which the Controller shall then follow with a Private Read request to fetch the data? (See <b>Section 5.1.6.2.2.</b> )<br><b>0:</b> No<br><b>1:</b> Yes |
| 5   | <b>HDR-BT CRC-32 Support</b>                         | Does this I3C Target support CRC-32 data integrity verification in HDR Bulk Transport Mode? (See <b>Section 5.2.4.3.</b> )<br><b>0:</b> No<br><b>1:</b> Yes                                                                                                                                                                  |
| 4   | <b>Defining Byte Support in GETSTATUS</b>            | Does this I3C Target support an optional Defining Byte for the GETSTATUS CCC?<br><b>0:</b> No<br><b>1:</b> Yes                                                                                                                                                                                                               |
| 3   | <b>Defining Byte Support in GETCAPS</b>              | Does this I3C Target support an optional Defining Byte for this CCC (GETCAPS)?<br><b>0:</b> No<br><b>1:</b> Yes                                                                                                                                                                                                              |
| 2   | Device to Device Transfer (D2DXFER) IBI Capable      | These capabilities are not included in the I3C Basic Specification. To gain access to them, please contact MIPI Alliance.                                                                                                                                                                                                    |
| 1   | Device to Device Transfer (D2DXFER) Support          |                                                                                                                                                                                                                                                                                                                              |
| 0   | <b>Multi-Lane (ML) Data Transfer Support</b>         | Does this I3C Target support Multi-Lane (ML) Data Transfer? (See <b>Section 5.1.9.3.30</b> and <b>Section 5.3</b> )<br><b>0:</b> No<br><b>1:</b> Yes                                                                                                                                                                         |

3354

**Note:**

An I3C Target that supports I3C Basic shall not indicate support for any of the features or capabilities marked as “Not included in I3C Basic” in **Table 37**.

3355  
3356  
3357  
3358

An I3C Controller that supports supports any version of the I3C Basic Specification might receive a GETCAP3 Byte from an I3C Target that supports the full I3C Specification, and might also support some of the features or capabilities marked as “Not included in I3C Basic”. In such a case, the I3C Controller must ignore any such features or capabilities reported by the I3C Target, as the I3C Controller would not support them.

3359

**Table 38 GETCAP4 Byte Format**

| Bits | Field    | Description                                            |
|------|----------|--------------------------------------------------------|
| 7:0  | Reserved | Reserved for future definition by MIPI Alliance I3C WG |

### **GETCAPS Format 2**

The optional GETCAPS Format 2 (*Figure 63*) adds a Defining Byte (*Table 39*) and returns a variable number of data bytes. The number of data bytes returned and their format depend upon the Defining Byte value.

Support for the GETCAPS Format 2 CCC is optional, typically depending upon the Device's role, capabilities, or other extended behavior. Before using GETCAPS Format 2 for a given Target, a Controller shall determine whether that Target supports it. One way is to send the GETCAPS Format 1 CCC (no Defining Byte) and find that in Byte 3 (GETCAP3) of the data that the Target returns, bit 4 contains 1'b1 (see *Table 37*)

GETCAPS Format 2 conforms to the CCC Direct General Frame Format (*Figure 31*):

- **If the addressed Target Device does not support the given Defining Byte value for GETCAPS Format 2:** Then the Target shall NACK its Target Address, thus terminating the Direct CCC.
- **If the addressed Target Device does support the given Defining Byte value for GETCAPS Format 2:** Then the Target shall ACK its Target Address and return the requested data byte(s). The number of data bytes returned shall depend on the particular Defining Byte and its associated capabilities, as detailed below.
- **If the addressed Target Device is unable to immediately respond to the GETCAPS Format 2 CCC with the given Defining Byte:** Then, per the Retry Model for Direct GET CCC Commands (*Section 5.1.9.2.3*), the Target shall NACK the first attempt, and then the Controller shall attempt a single retry. If the Controller receives a NACK after a retry, then the Controller shall assume that the Target does not support the GETSTATUS Format 2 CCC with the given Defining Byte, and hence cannot return data describing any capabilities corresponding to that Defining Byte value. In most cases the Controller can proceed as though it had read a value equivalent to all zeros as a default value. However, a NACK after a retry does not guarantee that the Target does not possess any capability or feature set associated with the given Defining Byte value.

A Target that supports the GETCAPS Format 2 CCC (i.e., GETCAPS with any optional Defining Bytes) shall return a value of 1'b1 in bit 4 of Byte 3 (GETCAP3), when the GETCAPS CCC is sent without a Defining Byte. A Controller that sees that bit set to 1'b1 will know that the Target is capable of supporting at least one Defining Byte with the GETCAPS Format 2 CCC. The ACK/NACK method explained above allows the Target to indicate which Defining Byte values it actually supports.



Figure 63 GETCAPS Format 2

3381  
3382

**Table 39 GETCAPS Format 2 Defining Byte Values**

| Value              | Encoding                 | Description                                                                                                                                                                                                                                                                                                                                                                                           | Data Bytes Returned               |
|--------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| <b>0x00</b>        | <b>TGTCAPS</b>           | Describes standard (Target) capabilities and features.<br>Equivalent to GETCAPS Format 1 (same CCC but without a Defining Byte).                                                                                                                                                                                                                                                                      | <b>2 – 4</b><br>(GETCAP1–GETCAP4) |
| 0x01 – 0x59        | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                | —                                 |
| <b>0x5A</b>        | <b>TESTPAT</b>           | Return a fixed 32-bit test pattern, to be used for signal integrity and speed testing (i.e., Debug test platforms).<br>Recommended if an I3C Device supports the MIPI Debug for I3C Specification as a Debug-capable Target System ('TS', see <a href="#">[MIPI04]</a> ).                                                                                                                             | <b>4</b><br>(TESTPAT1–TESTPAT4)   |
| 0x5B – 0x90        | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                | —                                 |
| <b>0x91</b>        | <b>CRCAPS</b>            | Describes capabilities and features relating to a Controller-capable (i.e., a Secondary Controller) Device, and its behavior during the Controller handoff (see below).<br>Recommended if an I3C Device is both compliant with the I3C Specification version 1.1 or higher, and advertises as Controller-capable (i.e., the value of BCR[7:6] bits is 2'b01, see <a href="#">Section 5.1.1.2.1</a> ). | <b>1 – 2</b><br>(CRCAP1–CRCAP2)   |
| 0x92               | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                | —                                 |
| <b>0x93</b>        | <b>VTCAPS</b>            | Describes capabilities and features relating to a Virtual Target capable Device.<br>Required if an I3C Device both is compliant with v1.1 or higher of the I3C Basic Specification, and presents multiple Virtual Targets (i.e., the value of BCR[4] bit is 1'b1, see <a href="#">Section 5.1.1.2.1</a> ).                                                                                            | <b>1 – 2</b><br>(VTCAP1–VTCAP2)   |
| 0x94 – 0xBF        | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                | —                                 |
| 0xC0 – 0xD6        | Reserved                 | Reserved for future definition by other MIPI Alliance WGs                                                                                                                                                                                                                                                                                                                                             | —                                 |
| <b>0xD7</b>        | <b>DBGCAPS</b>           | Describes capabilities and features relating to a Debug-capable Device conforming to the MIPI Debug for I3C specification <a href="#">[MIPI04]</a> .<br>Recommended if an I3C Device supports the MIPI Debug for I3C Specification as a Debug-capable Target System ('TS', see <a href="#">[MIPI04]</a> ).                                                                                            | <b>1 – N</b><br>(DBGCAP1–DBGCAPN) |
| 0xD8 – 0xDF        | Reserved                 | Reserved for future definition by other MIPI Alliance WGs                                                                                                                                                                                                                                                                                                                                             | —                                 |
| <b>0xE0 – 0xFE</b> | <b>Vendor Extensions</b> | For Vendor use                                                                                                                                                                                                                                                                                                                                                                                        | —                                 |
| 0xFF               | Reserved                 | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                | —                                 |

### Read Fixed Test Pattern (GETCAPS Format 2, Defining Byte TESTPAT)

**Note:**

*This Section describes the GETCAPS Format 2 CCC when the value of the Defining Byte is 0x5A (TESTPAT)*

This Direct CCC (**Figure 64**) allows the Active Controller to request a Device to return a fixed 32-bit test pattern, which may be used by a Controller to test signal integrity of the I3C Bus or perform speed testing on the I3C Bus. This is useful for Bus implementations where a Controller may not be built into the system (i.e., a Debug probe joining the Bus as Secondary Controller) and might need to perform testing, in order to determine the maximum safe speed for communicating with a Device within a Debug-capable Target System (TS).

All Debug-capable Devices should support this test pattern, and should return it when addressed by the GETCAPS Format 2 CCC with Defining Byte TESTPAT (0x5A) in Target mode. Additionally, any other Target Devices that share the same Bus as a Debug-capable Device should also support this test pattern.

Per **Figure 64**, a Device that supports this Defining Byte shall return a fixed 32-bit test pattern, consisting of the value 0xA55AA55A. The Active Controller may terminate the read on each byte boundary.

A Device that does not support this test pattern shall NACK its Target Address, to indicate that it does not support the GETCAPS Format 2 CCC with Defining Byte TESTPAT (i.e., 0x5A).

Additional Defining Bytes that return other test patterns may be defined at the discretion of the implementer, in order to perform more advanced signal integrity or speed testing procedures.



**Figure 64 GETCAPS Format 2 with Defining Byte TESTPAT**

3400

**Table 40 TESTPAT Message Format**

| Byte                       | Meaning                   | Description                                                    |
|----------------------------|---------------------------|----------------------------------------------------------------|
| <b>TESTPAT1 – TESTPAT4</b> | <b>Fixed Test Pattern</b> | Four bytes containing the fixed test pattern value 0xA55AA55A. |

**Get Controller Feature Capabilities (GETCAPS Format 2, Defining Byte CRCAPS)**

3401  
**Note:**

3402     *This Section describes the GETCAPS Format 2 CCC when the value of the Defining Byte is 0x91 (CRCAPS)*

3403 This Direct CCC (**Figure 65**) allows the Active Controller to query a Controller-capable (Secondary Controller) I3C Device, to read what optional Controller  
3404 features and capabilities that Device supports. An Active Controller might do this in order to determine whether a Controller-capable Device will abide by the  
3405 Active Controller's configuration or implied expectations regarding the overall Bus Controller Role flow. The Active Controller can use this information to decide  
3406 whether to ACK or NACK a Controller Role Request (CRR) from this Controller-capable Device, in the event that errors or undesirable situations arise from any  
3407 mismatch of configuration or expectations.

3408 All Controller-capable Devices should support the GETCAPS Format 2 CCC (with Defining Byte) in Target mode. If such a Device does not follow the default  
3409 capability settings, or if it has restrictions or limitations on its capabilities while operating as Active Controller, then the Device shall support the GETCAPS Format  
3410 2 CCC (with Defining Byte).

3411 Per **Figure 65**, a Controller-capable Device shall return either only the CRCAP1 data byte, or both data bytes CRCAP1 and CRCAP2, in that order. The Active  
3412 Controller may terminate the read on each byte boundary. If only the one CRCAP1 data byte is returned, then the Active Controller may assume that the default  
3413 values for the CRCAP2 data byte apply (i.e., as though CRCAP2 had been received with every bitfield set to 1'b0).

3414 A Device that is not Controller-capable shall NACK its Target Address, to indicate that it does not support the GETCAPS Format 2 CCC with Defining Byte  
3415 CRCAPS (i.e., 0x91).

3416 Fields within the CRCAP1 and CRCAP2 data bytes indicate various Controller features and capabilities, as detailed in **Table 41** and **Table 42**, respectively. CRCAP1  
3417 generally addresses I3C Bus configuration, and CRCAP2 generally addresses Controller interaction with other I3C Devices.



Figure 65 GETCAPS Format 2 with Defining Byte CRCAPS

Table 41 CRCAP1 Byte Format

| Bits | Field                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3  | Reserved                        | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2    | <b>Multi-Lane Support</b>       | <p><b>1'b1:</b> This Device may use the MLANE CCC to change the ML configuration of other I3C Targets, to operate with additional data Lanes (see <a href="#">Section 5.1.9.3.30</a>).</p> <p><b>1'b0:</b> This Device shall not use the MLANE CCC to change the ML configuration of other I3C Targets. It shall either use the I3C Bus as previously configured for ML transfers, or else reset I3C Targets to a default mode or compatible ML configuration.</p>                                                                                                                                                                                       |
| 1    | <b>Group Management Support</b> | <p><b>1'b1:</b> This Device may support Group Address handoff or management capabilities. It may use the SETGRPA and RSTGRPA CCCs to create groups, change Device membership, and remove Devices from groups. It shall also use the DEFGRPA CCC to announce the current group membership data after making any changes.</p> <p><b>1'b0:</b> This Device does not support Group Address capabilities, and shall not use the SETGRPA or RSTGRPA CCCs. It will ignore any DEFGRPA CCC Broadcasts while it is not Active Controller, and it shall not send DEFGRPA CCC Broadcasts before a Controller Role handoff to another Controller-capable Device.</p> |
| 0    | <b>Hot-Join Support</b>         | <p><b>1'b1:</b> This Device may support Hot-Join, and will ACK an I3C Target Hot-Join Request while it is Active Controller on the Bus. It shall support Dynamic Address Assignment, and shall also send the DEFTGTS CCC to announce the presence of newly joined I3C Targets to other Controller-capable Devices.</p> <p><b>1'b0:</b> This Device does not support Hot-Join, and will NACK any I3C Target Hot-Join Requests. It may also send DISEC CCC with the DISHJ bit set to disable Hot-Join Requests.</p>                                                                                                                                        |

3421

**Table 42 CRCAP2 Byte Format**

| Bits | Field                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4  | Reserved                          | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3    | <b>Delayed Controller Handoff</b> | <p><b>1'b1:</b> This Device may need additional time to process Broadcast CCC data sent from the Active Controller, before it can successfully complete the Controller Role Handoff Procedure and accept the Controller Role:</p> <ul style="list-style-type: none"> <li>If this Device indicates that it supports deep sleep re-synchronization (Bit 3) or indicates the “Handoff Delay NACK” state (via the GETSTATUS CCC with the PRECR [i.e., 0x91] Defining Byte, <a href="#">Section 5.1.9.3.15</a>), then the Active Controller shall periodically check the value returned from the GETSTATUS CCC with the PRECR Defining Byte to determine whether this Device is still processing data, or is ready to accept the Controller Role.</li> <li>If this Device does not support Deep Sleep resynchronization, or if the Active Controller has exceeded its timeout for checking the status of this Device, then this Device may restart the process by initiating a new Controller Role Request.</li> </ul> <p><b>1'b0:</b> This Device does not need additional time to process Broadcast CCC data sent from the Active Controller. The Active Controller may expect it to ACK the GETACCCR CCC as part of the Controller Role Handoff Procedure, even if this Device did not initially send a Controller Role Request.</p> |
| 2    | <b>Deep Sleep Capable</b>         | <p><b>1'b1:</b> This Device may enter a deep sleep state during which it may miss some Broadcast DEFTGTS and DEFGRPA CCCs sent by the Active Controller. It will require re-synchronization upon re-entering a normal operating state, before it can accept the Controller Role with the GETACCCR CCC. The current status of the Device shall be reported via the GETSTATUS CCC with the PRECR Defining Byte (i.e., 0x91, see <a href="#">Section 5.1.9.3.15</a>).</p> <p><b>1'b0:</b> This Device shall remain active and continue to monitor the I3C Bus to listen for these Broadcast CCCs, and shall not enter a deep sleep state from which it must be re-synchronized by the Active Controller before it can accept the Controller Role.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | <b>Controller Pass-Back</b>       | <p><b>1'b1:</b> This Device shall automatically pass the Controller Role back to the former Active Controller from which it received its Controller Role. It shall do so via the GETACCCR CCC, once it has finished performing any tasks that require it to request and gain the Controller Role. This Device may also support a Controller Role Request from the former Active Controller, or from any Controller-capable Device.</p> <p><b>1'b0:</b> This Device shall not automatically pass the Controller Role back to the former Active Controller. However, this Device shall support a Controller Role Request from any Controller-capable Device.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0    | <b>In-Band Interrupt Support</b>  | <p><b>1'b1:</b> This Device may choose to accept an IBI request from any I3C Target, when operating as Active Controller on the Bus. It may use the Target's Address to determine whether to accept or refuse the IBI. It may selectively or globally enable interrupts upon receiving the Controller Role, and shall disable interrupts before passing the Controller Role on to another Controller-capable Device.</p> <p><b>1'b0:</b> This Device shall not accept any IBI requests, and will respond with NACK; it may also send the DISEC CCC with the DISINT bit set, to disable interrupts (see <a href="#">Section 5.1.9.3.1</a>).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### Get Debug Feature Capabilities (GETCAPS Format 2, Defining Byte DBGCAPS)

**Note:**

This Section describes the GETCAPS Format 2 CCC when the value of the Defining Byte is 0xD7 (DBGCAPS)

This Direct CCC (**Figure 66**) allows the Active Controller to query a Debug-capable I3C Device, to read the version of the MIPI Debug for I3C specification supported by that Device, as well as the optional Debug features and capabilities that Device supports. An Active Controller might do this in order to set up a session for a Debug software connection to the Device acting as part of a Debug-capable Target System (TS).

All Debug-capable Devices should support the GETCAPS Format 2 CCC (with Defining Byte) in Target mode.

Per **Figure 66**, a Debug-capable Device shall return at least one data byte, with optional additional data bytes depending on the Debug features and capabilities of the Device. The total number of data bytes will depend upon the version and capabilities of the Device. The data bytes shall be returned in a defined order, depending on the MIPI Debug for I3C version, per **Table 43**. The meaning and formatting of the data bytes is fully described in Section 5 of the MIPI Debug for I3C specification **[MIPI04]**.

The Active Controller may terminate the read on each byte boundary. The Active Controller shall not make any assumptions about the presence of any Debug features or capabilities, beyond the contents of any data bytes received from the Device.

These data bytes may be used by Debug software running on a Host system using a Debug-enabled Active Controller, in order to determine the Device's Debug capabilities and configure the Debug software appropriately to access its Debug features and capabilities.

A Device that is not Debug-capable shall NACK its Target Address, to indicate that it does not support the GETCAPS Format 2 CCC with Defining Byte DBGCAPS (0xD7).



**Figure 66 GETCAPS Format 2 with Defining Byte DBGCAPS**

3440

**Table 43 DBGCAPS Message Format**

| Byte                     | Meaning                                | Description                                                                                                                            |
|--------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <b>DBGCAP1</b>           | <b>Debug for I3C Version</b>           | This byte indicates the version of the MIPI Debug for I3C specification <a href="#">[MIP104]</a> supported by this Device. (Required)  |
| <b>DBGCAP2 – DBGCAPN</b> | <b>Debug Features and Capabilities</b> | Number, meaning, and formatting of all subsequent bytes are defined in the MIPI Debug for I3C specification <a href="#">[MIP104]</a> . |

#### Get Virtual Target Capabilities (GETCAPS Format 2, Defining Byte VTCAPS)

3441  
**Note:**

3442     *This Section describes the GETCAPS Format 2 CCC when the value of the Defining Byte is 0x93 (VTCAPS)*

3443 This Direct CCC (**Figure 67**) allows the Active Controller to query a Virtual Target capable I3C Device, to read what optional features and capabilities that Device  
3444 supports. An Active Controller might do this in order to determine whether or how such a Device presents multiple Targets; whether other Virtual Target Addresses  
3445 are presented by, controlled by, or embodied within this Device; whether this Device will request In-Band Interrupts; or how this Device will respond to other  
3446 CCCs (e.g., RSTACT, ENTDA, or GETPID). The Active Controller can use this information to fully configure the Bus and enable advanced applications using  
3447 Virtual Targets with multiple Dynamic Addresses in a single Device.

3448 All Devices that report Virtual Target capabilities (i.e., that have BCR Bit[4] set to 1'b1; see **Section 5.1.2.1.2**) should support this CCC (GETCAPS Format 2 with  
3449 Defining Byte VTCAPS [0x93]) in Target mode. If such a Device contains multiple Virtual Target Addresses, and if using other CCCs will have unexpected side  
3450 effects on those Virtual Targets, then the Device shall support this CCC (i.e., GETCAPS Format 2 with Defining Byte VTCAPS [0x93]).

3451 Per **Figure 67**, a Virtual Target capable Device shall return either only the VTCAP1 data byte, or both data bytes VTCAP1 and VTCAP2, in that order. The Active  
3452 Controller may terminate the read on each byte boundary. If only the one VTCAP1 data byte is returned, then the Active Controller may assume that the default  
3453 values for the VTCAP2 data byte apply (i.e., as though the VTCAP2 data byte had been received with every bitfield set to 1'b0).

3454 Fields within the VTCAP1 and VTCAP2 data bytes indicate various Virtual Target features and capabilities. **Table 44** covers the features and capabilities dealing  
3455 with the Device's configuration, and **Table 45** advertises how the Device handles any downstream Virtual Targets or other Devices, if those are supported.

3456 A Device that is Virtual Target capable and that has multiple Virtual Targets that use shared Peripheral logic shall also support the Virtual Target Detect Operation.  
3457 The Controller can use the Virtual Target Detect Operation to detect the other Virtual Targets sharing that same Peripheral logic, if this is supported. This operation  
3458 is controlled by the Active Controller using the RSTACT CCC with Defining Byte 0x04 (see **Section 5.1.9.3.26**).

3459 A Device that is Virtual Target capable and acts as a Bridge Device (see **Section 5.1.9.3.17**) or as a Routing Device (see **Section 5.1.9.3.20**) shall indicate how it  
3460 should be configured by the Active Controller. It shall also indicate how it will configure any downstream Devices attached to its private Buses or Segments, and  
3461 how it handles any upstream requests from those private Buses or Segments to this Bus.

3462 A Device that is not Virtual Target capable (i.e., that has BCR Bit[4] set to 1'b0) shall NACK its Target Address, to indicate that it does not support the GETCAPS  
3463 Format 2 CCC with Defining Byte VTCAPS (0x93).

3464  
3465

Figure 67 GETCAPS Format 2 with Defining Byte VTCAPS

**Table 44 VTCAP1 Byte Format**

| Bits | Field                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6  | Reserved                        | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5    | <b>Shared Peripheral Detect</b> | <p><b>1'b0:</b> Device does not use shared Peripheral logic.</p> <p><b>1'b1:</b> Device uses shared Peripheral logic and supports the Virtual Target Detect operation as a Defining Byte for the RSTACT CCC (see <a href="#">Section 5.1.9.3.26</a>). Required for Virtual Target type 3'd5; Recommended for other Virtual Target types. See MIPI I3C Application Note for System Integrators [<a href="#">MIP103</a>].</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4    | <b>Side Effects</b>             | <p><b>1'b0:</b> No impact on other Virtual Targets supported by this Device, if sending CCCs to reconfigure this Target's Dynamic Address.</p> <p><b>1'b1:</b> Configuration CCCs sent to this Virtual Target's Dynamic Address may impact other Virtual Targets that are connected to or exposed by this Device (example CCCs: SETNEWDA, SETMRL).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3    | Reserved                        | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0  | <b>Virtual Target Type</b>      | <p><b>Values:</b></p> <p><b>3'd0:</b> This Device does not support or declare any Virtual Target capabilities.</p> <p><b>3'd1:</b> This Device is a Bridge Device, and uses the SETBRGTGT CCC (<a href="#">Section 5.1.9.3.17</a>) to configure its virtualized (bridged) Targets.</p> <p><b>3'd2:</b> This Device is a Bridge Device, but does not require the use of the SETBRGTGT CCC; the Device will set up its own bridged Targets.</p> <p><b>3'd3:</b> This Device is a Routing Device, and uses the SETROUTE CCC (<a href="#">Section 5.1.9.3.20</a>) to configure its Routes to one or more I3C Buses.</p> <p><b>3'd4:</b> This Device is a mixed-function Debug Virtual Target, which uses a single Target Address to access both Debug functionality and application functionality.</p> <p><b>3'd5:</b> This Device supports multiple Virtual Target Addresses with shared Peripheral logic.</p> <p><b>3'd6:</b> This Device is a Hub that supports pass-through transactions to other Target Devices.</p> <p><b>3'd7:</b> Reserved</p> |

**Table 45 VTCAP2 Byte Format**

| <b>Bits</b> | <b>Field</b>                                                                                              | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5         | Reserved                                                                                                  | Reserved for future definition by MIPI Alliance I3C WG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4:3         | <b>Bus Context and Conditions</b><br><br><i>Valid for Virtual Target types 3'd1, 3'd2, and 3'd3 only.</i> | <p><b>2'd0:</b> Device manages all downstream Device configuration automatically.</p> <p><b>2'd1:</b> Device will re-broadcast any context and event enable/disable commands (i.e., SETBUSCON, ENEC, or DISEC) to all downstream Devices when received from the Active Controller. Device can request Active Controller to send a fresh configuration.</p> <p><b>2'd2:</b> Device will cache previously Broadcast context and event enable/disable configuration, and use that to configure all new downstream Devices that join its downstream Bus segments.</p> <p><b>2'd3:</b> Reserved</p> |
| 2           | <b>Address Remapping</b><br><br><i>Valid for Virtual Target types 3'd1, 3'd2, and 3'd3 only.</i>          | <p><b>1'b0:</b> Device will pass addresses of downstream Devices as they are assigned.</p> <p><b>1'b1:</b> Device will transparently re-map addresses of downstream Devices to mask them from this Bus.</p>                                                                                                                                                                                                                                                                                                                                                                                    |
| 1:0         | <b>Interrupt Requests</b><br><br><i>Valid for Virtual Target types 3'd1, 3'd2, and 3'd3 only.</i>         | <p><b>Values:</b></p> <p><b>2'd0:</b> Device will not coalesce or route interrupt requests from any downstream Devices.</p> <p><b>2'd1:</b> Device must coalesce interrupt requests from downstream Devices, using this Target Address.</p> <p><b>2'd2:</b> Device must route interrupt requests from downstream Devices using their Virtual Target Addresses.</p> <p><b>2'd3:</b> Device may do either (i.e., coalesce and/or route) when forwarding interrupts from downstream Devices.</p>                                                                                                  |

### 5.1.9.3.20 Set Route (SETROUTE)

This Direct CCC (**Figure 68**) is used by an I3C Controller to configure a Routing Device (Routing Devices are described below). Because this CCC is only relevant to Routing Devices, a Controller shall only send the SETROUTE CCC to a known Routing Device that accepts it.

The Command Code for the SETROUTE Direct CCC is 0x96. Support for this CCC is optional.



Figure 68 SETROUTE Format

**Target Addr** is the Address of the Routing Device: either the Target's original 7-bit static I<sup>2</sup>C Address, or else the current value of the Target's assigned 7-bit Dynamic Address. This Target Address is used both for the Routing Device itself, and the other operations of the Device into which the routing behavior and logic is integrated.

**Count** is the number of configured Routes to be defined/assigned with this CCC (not the number of Routes the Routing Device provides).

Each Route is represented by three fields:

- **Dynamic Address:** The 7 most significant bits (Bits[7:1]) contain the current value of the Target's assigned 7-bit Dynamic Address, and the least significant bit (Bit[0]) is filled with the value 1'b0. This Address (not the Target Addr) is used when sending transactions to the associated I3C Bus.
- **ID:** An 8-bit identifier, implementation-specific to the Routing Device, identifying the specific Route to the I3C Bus endpoint provided by the Routing Device.
- **Start Trans Count:** An 8-bit value to which the Routing Device shall reset the transaction counter when initializing the Route.

The method by which the Controller is informed about the identifiers for the various Routes provided by the Routing Device is not defined by this Specification; the Controller shall have prior knowledge of the identifiers, through either discovery registers or a priori knowledge. Although the identifiers used by the Routing Device are arbitrary, they shall be unique per I3C Bus endpoint.

3486 Only one Controller using the SETROUTE CCC shall configure a set of Routes at any given time. Any Controller accessing the Routing Device on any of the I3C  
 3487 Buses shall configure the Route(s). Only one Controller and its associated configured Routes shall be active at any given time. Each time a different Controller  
 3488 desires to configure its Route(s) through the Routing Device, it shall negotiate for ownership of the I3C Bus first.

### Routing Devices

3489 A Routing Device enables an I3C Controller on a given I3C Bus to communicate to one or more other I3C Buses (see **Figure 69**). That is, a Routing Device enables  
 3490 a connection (also known as a Route), or multiple distinct connections, to exist between the connected I3C Buses. These I3C Buses are independent, and may have  
 3491 different sets of Dynamic Addresses.

3492 A Routing Device is distinguished from a Bridge Device, in that a Routing Device is not transparent; the transactions are relayed between the I3C Buses. Since the  
 3493 Routing Device inevitably incurs delays on the transactions, it shall handle transactions through buffers/queues in order to meet the transmit/receive requirements  
 3494 of the I3C protocol on each connected I3C Bus. Transactions from the Controller on its I3C Bus are queued by the Routing Device, and then sent to the other I3C  
 3495 Buses configured by the Controller. Each Route should have its own separate queue, in order to handle differences in timing and clocking.



**Figure 69 Example Routing Device**

3496 Routes through the Routing Device will work either in a single direction, or in multiple directions, depending on the capabilities of each I3C Bus endpoint.  
 3497

#### Examples

- An I3C Bus endpoint that is both a Target and a Secondary Controller supports Routes in both directions through that endpoint.
- An I3C Bus endpoint that is only a Target, and not a Secondary Controller, only supports single-direction Routes (i.e., inward to the Routing Device).

3498 Responses are queued and tagged with a transaction count, so that the original sender of the transaction can associate the responses with the original transaction.  
 3499 Each Route shall have its own counter. The initial value of the counter should be configurable, to allow the Controller to reset the counter to a previous value after  
 3500 a change in ownership.

### 5.1.9.3.21 Set Exchange Timing Information (SETXTIME)

As detailed in [Section 5.1.8](#), the SETXTIME CCC provides the framework for Controller(s) and Target(s) to exchange event timing information for purposes such as synchronizing controls, collecting or reconstructing timestamps, and specifying the timing data procedure. The SETXTIME CCC is available both as a Broadcast Command ([Figure 70](#)) and as a Direct Command ([Figure 71](#)).

The SETXTIME CCC always includes the one-byte Sub-Command field, which acts as an identifier that defines the specific function of the CCC. For some Sub-Command values, additional Data Bytes follow. Interpretation of these additional Data Bytes depends upon the particular Sub-Command value, as detailed in [Table 47](#).

**Note:**

*Of the possible sub-commands that are defined, or that might be defined, for various Timing Control Modes in the full I3C Specification, I3C Basic includes only the ones that are required to enable or disable Async Mode 0 (Asynchronous Basic Mode). To gain access to the other Timing Control Modes and their sub-commands, please contact MIPI Alliance.*

**Table 46 Set Exchange Timing Information Command Codes (SETXTIME)**

| Command  | Support     | Command Codes |        | Purpose                         |
|----------|-------------|---------------|--------|---------------------------------|
|          |             | Broadcast     | Direct |                                 |
| SETXTIME | Conditional | 0x28          | 0x98   | Set Exchange Timing Information |



**Figure 70 SETXTIME Format 1: Broadcast**



Figure 71 SETXTIME Format 2: Direct

Table 47 SETXTIME Sub-Command Byte Values

| Sub-Command Value | Sub-Command Function             | Description                                                                                                                                                                                                                                                                                                                                                                                 | Additional Data Bytes   |
|-------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| 0x7F              | Sync Tick 'ST'                   | These capabilities are not included in the I3C Basic Specification. To gain access to them, please contact MIPI Alliance.                                                                                                                                                                                                                                                                   | None                    |
| 0xBF              | Delay Time 'DT'                  |                                                                                                                                                                                                                                                                                                                                                                                             | One byte                |
| <b>0xDF</b>       | <b>Enter Async Mode 0</b>        | Commands all I3C Targets and Controllers on the Bus to operate in Async Basic Mode. See <a href="#">Section 5.1.8.3.1</a> . Anchor points: In-Band Interrupt ACK and T-Bit after the first In-Band Interrupt Payload byte.<br>Upon receiving this Sub-Command, all I3C Devices shall reset all internal counts. All I3C Controllers that support Timing Control shall support Async Mode 0. | None                    |
| 0xEF              | Enter Async Mode 1               | These capabilities are not included in the I3C Basic Specification. To gain access to them, please contact MIPI Alliance.                                                                                                                                                                                                                                                                   | None                    |
| 0xF7              | Enter Async Mode 2               |                                                                                                                                                                                                                                                                                                                                                                                             | None                    |
| 0xFB              | Enter Async Mode 3               |                                                                                                                                                                                                                                                                                                                                                                                             | None                    |
| 0xFD              | Async Trigger (for Async Mode 3) |                                                                                                                                                                                                                                                                                                                                                                                             | None                    |
| 0x3F              | TPH                              |                                                                                                                                                                                                                                                                                                                                                                                             | One or more bytes       |
| 0x9F              | TU                               |                                                                                                                                                                                                                                                                                                                                                                                             | One byte                |
| 0x8F              | ODR                              |                                                                                                                                                                                                                                                                                                                                                                                             | One byte                |
| <b>0xFF</b>       | <b>Exit</b>                      | Commands all I3C Targets to exit from the enabled timing modes, or to turn timing control off entirely.                                                                                                                                                                                                                                                                                     | None                    |
| All Others        | Reserved                         | Available Sub-Command values for future definition of new SETXTIME CCC Sub-Commands                                                                                                                                                                                                                                                                                                         | (For future definition) |

### 5.1.9.3.22 Get Exchange Timing Support Information (GETXTIME)

This Direct CCC (*Figure 72*), whose use is further detailed in *Section 5.1.8*, provides the framework for the Controller to query the Exchange Timing capabilities supported by the I3C Targets. The GETXTIME CCC causes the addressed Target to return four data bytes containing key information on supported Timing Control modes, current state, and internal oscillator/clock frequency and inaccuracy.

The Command Code for the GETXTIME Direct CCC is 0x99. Support for this CCC is required if an I3C Target supports any Timing Control modes (see *Section 5.1.8*).



Figure 72 GETXTIME Format

The queried I3C Target returns four data bytes, with the following interpretations:

- **Supported Modes Byte:** Bit mask indicating which Timing Control Mode(s) the Target supports (see *Table 48*). If a bit is set (has value 1'b1), then that Target supports the corresponding Timing Control Mode.

Table 48 GETXTIME Supported Modes Byte Fields

| Bit 7    | Bit 6    | Bit 5    | Bit 4                                                     | Bit 3                                                     | Bit 2                                                     | Bit 1                 | Bit 0                                                  |
|----------|----------|----------|-----------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------|-----------------------|--------------------------------------------------------|
| Reserved | Reserved | Reserved | Supports Async Mode 3<br><i>Not included in I3C Basic</i> | Supports Async Mode 2<br><i>Not included in I3C Basic</i> | Supports Async Mode 1<br><i>Not included in I3C Basic</i> | Supports Async Mode 0 | Supports Sync Mode<br><i>Not included in I3C Basic</i> |

- 3532 • **State Byte:** Bit mask indicating which Timing Control Mode (if any) is currently enabled for the Target, and whether any counter overflows have  
 3533 occurred since the most recent previous check (see *Table 49*). If a Timing Control Mode bit is set (has value 1'b1), then that Target has currently enabled  
 3534 the corresponding Timing Control Mode. If the Overflow bit is set (has value 1'b1), then that Target experienced a counter overflow since the most  
 3535 recent previous check.

**Table 49 GETXTIME State Byte Fields**

| Bit 7    | Bit 6    | Bit 5    | Timing Control Mode Bits                                    |                                                             |                                                             |                         |                                                          |
|----------|----------|----------|-------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|-------------------------|----------------------------------------------------------|
|          |          |          | Bit 4                                                       | Bit 3                                                       | Bit 2                                                       | Bit 1                   | Bit 0                                                    |
| Overflow | Reserved | Reserved | Async Mode 3<br>Enabled<br><i>Not included in I3C Basic</i> | Async Mode 2<br>Enabled<br><i>Not included in I3C Basic</i> | Async Mode 1<br>Enabled<br><i>Not included in I3C Basic</i> | Async Mode 0<br>Enabled | Sync Mode<br>Enabled<br><i>Not included in I3C Basic</i> |

**Note:**

The Timing Control Modes marked “Not included in I3C Basic” in *Table 49* are defined in the full I3C Specification but not included in I3C Basic. To gain access to these capabilities, please contact MIPI Alliance.

An I3C Target that supports I3C Basic shall not indicate support for any of the Timing Control Modes marked “Not included in I3C Basic” in *Table 49*, and shall not report any of them as Enabled.

- 3542 • **Frequency Byte:** This byte represents the frequency of the Target’s internal oscillator, in increments of 0.5 MHz (i.e., 500 KHz), up to 127.5 MHz. The  
 3543 value 0 is an exception, and indicates an internal oscillator frequency of approximately 32 KHz.  
 3544     **Example:** A value of 8'd20 represents an oscillator frequency of 10.0 MHz.  
 3545 • **Inaccuracy Byte:** This byte represents the maximum variation of the Target’s internal oscillator in 1/10<sup>th</sup> percent (0.1%) increments, up to 25.5%.  
 3546     **Example:** A value of 8'd25 represents a maximum frequency variation of 2.5%.

### 5.1.9.3.23 Set All Addresses to Static Address (SETAASA)

This CCC (*Figure 73*) allows the Controller to request that all connected Targets that have I<sup>2</sup>C Static Addresses use their I<sup>2</sup>C Static Address as their Dynamic Address. This is the fastest method to assign I3C Dynamic Addresses to all I3C Targets with I<sup>2</sup>C Static Addresses (see *Section 5.1.4.2*).

**Note:**

Per *Section 5.1.4.2*, SETAASA is intended as an optimization. An I3C Target that supports SETAASA and does not support ENTDAA cannot be relied on to be assigned a Dynamic Address on a generic I3C Bus, and also will not support Hot-Join (per *Section 5.1.5*). Use of SETAASA requires the I3C Controller to have prior knowledge of the I3C Target, as well as all other I3C Targets that support SETAASA. Dynamic Address Assignment with ENTDAA is recommended for most use cases.

The Command Code for the SETAASA Broadcast CCC is 0x29. Support for this CCC is optional; however, any I3C Target that supports this CCC shall have an I<sup>2</sup>C Static Address.



Figure 73 SETAASA Format

### 5.1.9.3.24 Device to Device(s) Tunneling Control (D2DXFER)

This CCC is not included in the I3C Basic Specification. To gain access to this capability, please contact MIPI Alliance.

### 5.1.9.3.25 Data Transfer Ending Procedure Control (ENDXFER)

As detailed in [Section 5.2.2.3](#), the ENDXFER CCC provides the framework for Controllers and Targets to exchange set-up parameters for ending data transfers in supported HDR Modes. The ENDXFER CCC is available as both a Broadcast Command ([Figure 74](#)) and a Direct Command ([Figure 75](#)).

**Note:**

*Whereas the full I3C Specification includes several ENDXFER sub-commands, I3C Basic only includes the ones that are required to exchange set-up parameters for ending data transfers in HDR-DDR Mode. The additional sub-commands in the full I3C Specification define exchange of set-up parameters for other HDR Modes that are not included in the I3C Basic Specification, and enable other features and capabilities that are not included in I3C Basic. To gain access to the other sub-commands and their related features and capabilities, please contact MIPI Alliance.*

The ENDXFER CCC always includes the one-byte Defining Byte field, which acts as a sub-command identifier defining the specific function of the CCC. For some Sub-Commands (i.e., for some values of the Defining Byte field), additional Data Bytes follow. Interpretation of these additional Data Bytes depends upon the particular Defining Byte value, as detailed in [Table 51](#).

**Table 50 Data Transfer Ending Procedure Control Command Codes (ENDXFER)**

| Command | Support     | Command Codes |        | Purpose                                |
|---------|-------------|---------------|--------|----------------------------------------|
|         |             | Broadcast     | Direct |                                        |
| ENDXFER | Conditional | 0x12          | 0x92   | Data Transfer Ending Procedure Control |



**Figure 74 ENDXFER Format 1: Broadcast**



Figure 75 ENDXFER Format 2: Direct

3572  
3573

3574

**Table 51 ENDXFER Defining Byte Values**

| Defining Byte Value | Sub-Command Function                                                                                                      | Description                                                                                                                                                                                                                                     | Additional Data Bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x7F                | Sub-commands for HDR-TSL and HDR-TSP protocols                                                                            | These capabilities are not included in the I3C Basic Specification. To gain access to them, please contact MIPI Alliance.                                                                                                                       | One Byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x55                |                                                                                                                           |                                                                                                                                                                                                                                                 | One Byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>0xF7</b>         | For HDR-DDR protocol:<br><b>SET/GET Data Transfer Early Termination Parameters</b>                                        | SET and GET the parameters for the Data Transfer Early Termination procedure, for the HDR-DDR protocol (see <b>Section 5.2.2.3.4</b> ).                                                                                                         | <p>One Byte</p> <p><b>Bits[7:6]: CRC Word Indicator</b><br/> <b>2'b11:</b> No CRC Word follows Early Termination request<br/> <b>2'b01:</b> CRC Word follows Early Termination request<br/>           (Checksum uses CRC-5 algorithm per <b>Section 5.2.2.5</b>)<br/>           Other: Reserved for future definition by MIPI Alliance</p> <p><b>Bit[5]: Enable WRITE Early Termination Request</b><br/> <b>1'b0:</b> Enable<br/> <b>1'b1:</b> Disable</p> <p><b>Bit[4]: Enable ACK/NACK Capability for WRITE Command</b><br/> <b>1'b0:</b> Enable<br/> <b>1'b1:</b> Disable</p> <p><b>Bits[3:0]:</b> Reserved for future use</p> |
| <b>0xAA</b>         | For HDR-DDR protocol:<br><b>Confirm Set-up and Initiate Data Transfer</b> using Data Transfer Early Termination Procedure | Commands either all I3C Devices on the Bus, or else only some directly addressed Devices on the Bus, to begin operating using the Data Transfer Early Termination procedure, as previously set up and confirmed using ENDXFER sub-command 0xF7. | <p>One Byte</p> <p><b>For WRITE:</b> The value 0xAA</p> <p><b>For READ:</b> The value of the currently enabled Additional Data byte, as it pertains to ENDXFER sub-command 0xF7.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0xFC                | Sub-command for Monitoring Device Early Termination Capability                                                            | These capabilities are not included in the I3C Basic Specification. To gain access to them, please contact MIPI Alliance.                                                                                                                       | One Byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| All Other Values    | Reserved                                                                                                                  | Defining Byte values reserved and available for future definition<br>(i.e., for new ENDXFER Sub-Commands)                                                                                                                                       | Reserved for future definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 5.1.9.3.26 Target Reset Action (RSTACT)

This Broadcast (*Figure 76*), Direct Read (*Figure 77*), and Direct Write (*Figure 78*) CCC is used to configure the next Target Reset action, and may be used to retrieve a Target's reset recovery timing. The RSTACT CCC is used in conjunction with the Target Reset Pattern (*Section 5.1.11.3*), i.e., the reset action previously configured in a Target via the RSTACT CCC is triggered when the immediately following Target Reset Pattern is received.

The RSTACT CCC uses a Defining Byte (*Table 53*).

- For the Broadcast and Direct Write formats, the Defining Byte indicates which Target Reset action (including to take no action) is to be configured (values 0x00 through 0x7F).
  - Defining Bytes 0x00 and 0x01 are required: A Target shall support these operations, and shall ACK its Target Address if issued as a Direct CCC.
  - Support for other Defining Bytes (values 0x02 through 0x7F) is optional, and depends on other conditions or support for other capabilities. If a Target does not support such an operation, then it shall NACK its Target Address for such a Defining Byte, as well as any related Defining Bytes defined for the Direct Read format (values 0x82 through 0xFF) if issued as a Direct CCC.
- For the Direct Read format, the Defining Byte may also indicate the Controller's desire to read back the Target's reset recovering timing or other parameters for the operation (values 0x81 through 0xFF).
  - If the CCC is NACKed and the related reset operation is supported, then the Controller should assume the default reset return times of 1 ms to reset the Peripheral (i.e., the reset operation for Defining Byte 0x01) and 1 second to reset the whole Target Device (i.e., the reset operation for Defining Byte 0x02).

**Table 52 Target Reset Action Command Codes (RSTACT)**

| Command | Support  | Command Codes |        | Purpose             |
|---------|----------|---------------|--------|---------------------|
|         |          | Broadcast     | Direct |                     |
| RSTACT  | Required | 0x2A          | 0x9A   | Target Reset Action |



**Figure 76 RSTACT Format 1: Broadcast**



Figure 77 RSTACT Format 2: Direct Write



Figure 78 RSTACT Format 3: Direct Read

3593

3594

3595

3596

**Table 53 RSTACT Defining Byte Values**

| Defining Byte Value       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | NACK Means Default Of                | Notes                                                                                                                                                           | SET / GET |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| 0x00                      | <b>No Reset on Target Reset Pattern</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | —                                    |                                                                                                                                                                 | SET / GET |
| 0x01                      | <b>Reset the I3C Peripheral Only</b> (Default)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                    |                                                                                                                                                                 | SET / GET |
| 0x02                      | <b>Reset the Whole Target</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Not supported                        |                                                                                                                                                                 | SET / GET |
| 0x03                      | <b>Debug Network Adaptor Reset</b><br>(The Target shall not reset the I3C Peripheral)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Debug for I3C not supported          | <b>SET:</b> No data (Defining Byte is the value)<br><br><b>GET:</b> Returns currently set Defining Byte value (i.e., previously received in Direct SET) or 0x00 | SET / GET |
| 0x04<br>(Direct CCC only) | <b>Virtual Target Detect</b> <ul style="list-style-type: none"> <li><b>SET:</b> The Target shall not prepare for reset, but shall set a flag in its shared Peripheral logic that can be read by all other linked Virtual Targets. This flag can be cleared with Defining Byte 0x00 (Direct or Broadcast)</li> <li><b>GET:</b> The Target shall return 0x01 if the flag is set, i.e., if a previous SET operation was directed to any linked Virtual Target in this Device (including itself), without an intervening use of Defining Byte 0x00. The Target shall return 0x00 if no SET was received, or if the flag was cleared by the RSTACT CCC with Defining Byte 0x00 (No Reset on the Target Reset Pattern)</li> </ul> | Device is not Virtual Target capable |                                                                                                                                                                 | SET / GET |
| 0x05 – 0x3F               | Reserved by MIPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                                    |                                                                                                                                                                 | —         |
| 0x40 – 0x7F               | Reserved for Vendors and external standards                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | —                                    |                                                                                                                                                                 | —         |
| 0x80                      | Reserved by MIPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                                    |                                                                                                                                                                 | —         |
| 0x81                      | <b>Return Time to Reset Peripheral</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1 ms                                 |                                                                                                                                                                 | GET       |
| 0x82                      | <b>Return Time to Reset Whole Target</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1 s                                  |                                                                                                                                                                 | GET       |
| 0x83                      | <b>Return Time for Debug Network Adaptor Reset</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 100 ms                               |                                                                                                                                                                 | GET       |
| 0x84                      | <b>Return Virtual Target Indication</b><br>Return 0x01 if this Target is a Virtual Target and supports Defining Byte 0x04 (Virtual Target Detect). Otherwise return 0x00.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Target is not Virtual                | <b>SET:</b> Ignored (not used)<br><br><b>GET:</b> Returns the time, based upon the Defining Byte                                                                | GET       |
| 0x85 – 0xBF               | Reserved for timing for MIPI reserved values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —                                    |                                                                                                                                                                 | GET       |
| 0xC0 – 0xFF               | Reserved for timing for Vendor and external standards reserved values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                                    |                                                                                                                                                                 | GET       |

**Note:**

1. The Target shall clear its reset action (as configured via the RSTACT CCC) upon receipt of the next START (but not Repeated START).
2. The Defining Byte value for a Debug Network Adaptor Reset operation (Defining Byte 0x03) is intended for Target Devices that support the MIPI Debug for I3C specification [MIPI04]. Support for this reset operation is strongly recommended for any Debug-capable I3C Device that supports MIPI Debug for I3C as a Debug-capable Target System (TS). A Target Device that does not support this reset operation shall NACK its Target Address for this Defining Byte (if issued as a Direct CCC) or ignore the RSTACT CCC (if issued as a Broadcast CCC).  
*The Debug Network Adaptor Reset operation (Defining Byte 0x03) does not reset the I3C Peripheral or its Target Address; it only resets the Device's Debug for I3C Network Adaptors and all attached Debug Function logic. If issued as a Broadcast CCC, then it shall only affect Targets that support a Debug Network Adaptor reset operation.*
3. The Defining Byte value for a Virtual Target Detect operation (Defining Byte 0x04) is intended for composite Devices that support multiple Virtual Targets that share the same Peripheral logic (see **Section 5.1.2.1.2**). Support for this Defining Byte is required for any such Device that reports Virtual Target capabilities (i.e., BCR bit[4] is set to 1'b1, and GETCAPS CCC with Defining Byte VTCAPS indicates multiple Virtual Targets using shared Peripheral logic). A Device that does not support this operation shall NACK its Target Address for this Defining Byte (if issued as a Direct CCC).
  - This operation does not configure a Target or its shared Peripheral logic for any defined Target Reset action. It is only used for identification and association of any linked Virtual Targets.
  - This Defining Byte is only supported with Direct CCCs, not Broadcast CCCs.
  - The flag that resides in the shared Peripheral logic and which is set by Defining Byte 0x04 shall not be accessible or writeable from any application-specific logic connected to any Virtual Target. The state of this flag may only be accessed by a Controller, via this CCC (RSTACT) with this Defining Byte (0x04); or cleared by using this CCC (RSTACT) with Defining Byte 0x00.
  - Additionally, if a shared Peripheral is implemented in a manner that passes incoming RSTACT CCC events as messages up to application-specific queues or buffers for any Virtual Targets, then the shared Peripheral shall not pass any RSTACT CCC events as messages if they contain Defining Byte 0x04 or 0x84, as these messages might notify a Virtual Target that the flag is being set or accessed by a Controller.
4. The Reset the Whole Target operation (Defining Byte 0x02) is optional, but support for this reset operation is recommended. A Target Device that does not support this reset operation shall NACK its Target Address for this Defining Byte (if issued as a Direct CCC) or ignore the RSTACT CCC (if issued as a Broadcast CCC).

### 5.1.9.3.27 Set Group Address (SETGRPA)

This Direct CCC (*Figure 79*) allows the Active Controller to assign a Group Address to an I3C Target supporting the Group Address feature. The Target will then respond to both the configured Group Address and its Dynamic Address. If multiple I3C Targets are configured with the same Group Address, then a single Message sent by the Active Controller to that Group Address will be received by all of those I3C Targets simultaneously.

**Note:**

*In this CCC, an I3C Target to be assigned a Group Address is indicated by its Dynamic Address. As a result, this CCC cannot be used until the Target has been assigned a Dynamic Address.*

If the Target supports multiple Group Addresses, then the same Dynamic Address can be used in multiple SETGRPA CCCs (up to the maximum number of Group Addresses supported by the I3C Device), supplying a different Group Address in each instance. The Target will then respond to any of the configured Group Addresses, in addition to its Dynamic Address.

When a Target is assigned to the maximum number of groups that it is capable of supporting, the Target shall inform the Controller that this maximum capability has been reached by NACKing the Target Address for this Direct CCC.

The Group Address to be assigned is transmitted in the Group Address byte shown in *Figure 79*, where the 7 most significant bits (Bits[7:1]) contain the 7-bit Group Address, and the least significant bit (Bit[0]) is filled with the value 1'b0.

The Command Code for the SETGRPA Direct CCC is 0x9B. Support for this CCC is required if the I3C Target supports Group Addressing (per *Section 5.1.4.4*).



Figure 79 SETGRPA Format

### 5.1.9.3.28 Reset Group Address (RSTGRPA)

This CCC is available in Direct and Broadcast versions:

- **Direct (Figure 80):** This CCC allows the Active Controller to remove one or more I3C Target Devices from a Group by resetting their assigned Group Address. If a Group Address is used instead of a Target Address (**Figure 81**), then this CCC also allows the Active Controller to disband the indicated Group (i.e., the assigned Group Address is reset for all Devices in the Group, with the result that no Devices remain in the Group).
- **Broadcast (Figure 82):** This CCC allows the Active Controller to disband all Groups, by resetting the assigned Group Address for all Devices with the result that no Devices remain in any Group.

**Table 54 Reset Group Address Command Codes (RSTGRPA)**

| Command | Support     | CCC Codes |        | Purpose             |
|---------|-------------|-----------|--------|---------------------|
|         |             | Broadcast | Direct |                     |
| RSTGRPA | Conditional | 0x2C      | 0x9C   | Reset Group Address |



**Figure 80 RSTGRPA Format 1: Direct**



Figure 81 Resetting a Group Address with the RSTGRPA Direct CCC



Figure 82 RSTGRPA Format 2: Broadcast

### 5.1.9.3.29 Define List of Group Addresses (DEFGRPA)

This Broadcast CCC (*Figure 83*) is only relevant to Secondary Controllers (as with the DEFTGTS CCC; see [Section 5.1.9.3.7](#)). The DEFGRPA CCC tells the Secondary Controller more details about a particular Group, including the list of I3C Targets that are members of the Group. If multiple Groups have been configured, then the Active Controller should issue one DEFGRPA CCC for each configured Group. Each use of the DEFGRPA CCC shall include the Group Address that uniquely identifies the Group, as well as the Dynamic Addresses of its I3C Targets.

The Command Code for the DEFGRPA Broadcast CCC is 0x2B. Support for this CCC is required if an I3C Secondary Controller supports Group Addressing (per [Section 5.1.4.4](#)), as well as handoff and/or management of Group Addresses, as part of Controller Role Handoff.



Figure 83 DEFGRPA Format

- **Group Descriptor**: Identifier for this Group, using the same format and the same MIPI-defined values as the DCR (see [Section 5.1.1.2.2](#) and MIPI-maintained web-based registry of defined values [[MIPI02](#)]).  
**Examples**: 8'd0 for Generic v1.0 Device, 8'd33 for Touch, 8'd129 for Proximity, etc.
- **Count**: The number of the I3C Targets that are members of this Group. This is the same as the number of Dynamic Addr bytes that follow.
- **Dynamic Address**: For each instance, the 7 most significant bits (Bits[7:1]) contain a member Target's current 7-bit Dynamic Address. The least significant bit (Bit[0]) has the value 1'b0.

### 5.1.9.3.30 Multi-Lane Data Transfer Control (MLANE)

The MLANE CCC is available in Broadcast (*Figure 84*) and Direct (*Figure 85*) versions. It is used to set up and control ML functionality for ML-capable Target Devices (see *Section 5.3.1*) by setting or getting, for a given I3C Mode (*Table 56*), the number of Additional Data Lanes (*Table 78*) and Data Transfer Coding number (see *Section 5.3.2*) to use while communicating to the Target using that I3C Mode.

This CCC always includes the one-byte Defining Byte field, which acts as a GET, SET, or SET/GET sub-command. Many of the defined sub-commands that have Broadcast CCC or Direct SET CCC versions also require one or more additional Data Bytes, as detailed in *Table 56*.

**Note:**

*For SDR Mode Only: The GET version of the SET/GET MLANE CCC requires the addressed Target to provide the DATA/T values on the Additional Data Lanes (i.e., on SDA[1] for DUAL Lane configurations, and on SDA[1], SDA[2], and SDA[3] for QUAD Lane configurations). The Controller can use this to test whether the Target is connected to the Additional Data Lanes. Since I3C Basic only supports Multi-Lane transfers for HDR-BT Mode, this shall apply for Defining Byte 0x23 only. Figure 86 shows the CCC GET format for QUAD Lane configurations; the version for DUAL Lane configurations does not use SDA[2] or SDA[3].*

*For HDR Modes: See MLANE Command Name in Table 61 for details on the format of the Target's response to the Format 2 (Direct GET) MLANE CCC while in HDR Modes.*

Table 55 Multi-Lane Data Transfer Control Command Codes (MLANE)

| Command | Support     | Command Codes |        | Purpose                          |
|---------|-------------|---------------|--------|----------------------------------|
|         |             | Broadcast     | Direct |                                  |
| MLANE   | Conditional | 0x2D          | 0x9D   | Multi-Lane Data Transfer Control |



Figure 84 MLANE Format 1: Broadcast



Figure 85 MLANE Format 2: Direct



Figure 86 MLANE Direct GET Version of SET/GET CCC (SDR Mode Only)

**Table 56 MLANE Defining Bytes and Data Bytes**

| Defining Byte Value | Sub-Command Function                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Additional Data Bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xFF                | <b>Get ML Capabilities</b><br><br>Direct Read<br>Get only | The directly addressed I3C Target responds with a 2-byte description of supported ML Frame formats, in every I3C Mode for which ML is supported:<br><br><b>Example:</b> For a Target capable of ML on HDR-BT (Sub-Command 0x23), with all supported codings (i.e., Coding 0 and Coding 3) on Dual Lanes, two byte pairs are needed. The first byte of both pairs is the HDR-BT value (0x23). The second byte of the first pair is {5'd0, 3'd1} or 0x01, and the second byte of the second pair is {5'd3, 3'd1} or 0x19.<br><br>The addressed Target therefore transfers the four bytes: 0x23, 0x01, 0x23, 0x19 | One byte pair per every I3C Mode for which the Target supports ML functionality.<br><br>Within each byte pair:<br><br><b>First Byte:</b> Identifier for the I3C Mode supported (same values used in the Sub-Command Function column at left):<br><b>0x23: HDR-BT</b><br><i>Note: Multi-Lane in other I3C Modes is not supported in I3C Basic</i><br><br><b>Second Byte:</b> 3-bit number of Additional Data Lanes and 5-bit Data Transfer Coding number, formatted as described below |
| 0x7F                | <b>Reset ML</b><br><br>Broadcast or<br>Direct Set         | <b>Broadcast SET:</b> All I3C Targets return to Basic 2-wire I3C mode and a default Data Transfer Coding, for all supported ML Frame formats.<br><br><b>Direct SET:</b> The directly addressed Target returns to Basic 2-wire I3C mode and a default Data Transfer Coding, for all supported ML Frame formats. If the Target also supports separate Group ML configurations (see 0x9B and 0x9C), then these shall also be reset to the same default state.                                                                                                                                                     | No additional data bytes for this sub-command. Target(s) now return to a default state, where they can be addressed in Basic 2-wire I3C mode. Useful before a Controller Handoff to an I3C Secondary Controller that is not connected to additional Lanes.                                                                                                                                                                                                                            |

| Defining Byte Value | Sub-Command Function                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Additional Data Bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00                | SDR-ML<br>(Not supported)                       | Multi-Lane support for SDR Mode is not included in I3C Basic.<br>To gain access to this capability, please contact MIPI Alliance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | One byte, as the ML Frame format, concatenating: <ul style="list-style-type: none"><li>• Bits[2:0]: Number of Additional Data Lanes:<ul style="list-style-type: none"><li>3'b000: Basic 2-wire I3C – SINGLE Lane config</li><li>3'b001: One additional Lane – DUAL Lane config</li><li>3'b011: Three additional Lanes – QUAD config</li><li>Other values not used</li></ul></li><li>• Bits[7:3]: Data Transfer Coding number to use (see <a href="#">Section 5.3.2</a>)</li></ul>                                                                                                                                                                                                                                                                                                                               |
| 0x20                | HDR-DDR-ML<br>(Not supported)                   | Multi-Lane support for HDR-DDR Mode is not included in I3C Basic.<br>To gain access to this capability, please contact MIPI Alliance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x21                | HDR-TSP-ML<br>(Not supported)                   | Multi-Lane support for HDR-TSP Mode is not included in I3C Basic.<br>To gain access to this capability, please contact MIPI Alliance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x23                | <b>HDR-BT</b><br><b>Frame Format</b><br>Set/Get | Sets or returns the current ML configuration (i.e., the ML Frame format) for HDR-BT Mode. The Defining Byte value indicates the I3C Mode and its available ML Frame formats to which the sub-command shall apply: <ul style="list-style-type: none"><li>• <b>0x23:</b> HDR-BT ML Frame formats: see <a href="#">Section 5.3.2.4</a></li></ul> <p><b>Direct SET to an assigned Dynamic Address:</b> The Target uses the provided ML Frame format variation with the indicated number of Additional Data Lanes and Data Transfer Coding version.</p> <p><b>Direct SET to an assigned Group Address</b> (if supported, per <a href="#">Section 5.3.1.1.1</a>): The Target uses the provided ML Frame format variation (as above) for all subsequent transfers addressing that Group Address. Changes shall not apply to the ML configuration for Dynamic Address(es).</p> <p><b>Broadcast SET:</b> If the Target supports the given I3C Mode, then it shall use the provided ML Frame format for all assigned Dynamic Addresses and Group Addresses (if applicable). See <a href="#">Section 5.3.1.1</a> and sub-sections for full configuration requirements.</p> <p><b>Direct GET to an assigned Dynamic Address:</b> The Target responds with one byte (see right column) indicating which variation of the ML Frame format is selected for ML operations involving that Dynamic Address. If the Target also supports separate Group ML configurations (per <a href="#">Section 5.3.1.1.1</a>) or multiple Dynamic Addresses (per <a href="#">Section 5.3.1.1.2</a>), then the data byte shall apply to transactions involving that Dynamic Address (i.e., not any other assigned Addresses).</p> | For Broadcast or Direct SET: The Target shall only accept a valid and supported ML Frame format for a given I3C Mode, as indicated by Defining Byte 0xFF. See sub-sections below.<br>If the Target also supports Group Address capabilities (per <a href="#">Section 5.1.4.4</a> ), then it shall also support Defining Byte 0x9B (i.e., the sub-command for <b>Group ML Capabilities</b> ).<br>If the Target also supports separate Group ML configurations (per <a href="#">Section 5.3.1.1.1</a> ), then it shall also support Defining Byte 0x9C (i.e., the sub-command for <b>Get Group ML Report</b> ).<br>For additional details and requirements, see <a href="#">Section 5.3.1.1</a> and sub-sections. Specific exceptions may apply per I3C Mode, per <a href="#">Section 5.3.2</a> and sub-sections. |

| Defining Byte Value | Sub-Command Function                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Additional Data Bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-------------------|-------------------------------------------------------|-------------------|----------------------------------------------------------------|-------------------|----------------------------------------------------------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x9B                | <b>Group ML Capabilities (optional)</b><br><br>Direct Read<br>Get only | <b>Direct GET to an assigned Dynamic Address:</b> The directly addressed Target responds with one byte (see Additional Data Bytes column) indicating whether it supports separate Group ML configurations, and if so, in what way. Required if the Target supports Group Addresses in any I3C Modes using ML. If the Target does not support Group Addresses in any I3C Modes using ML, then it shall NACK its Target Address.<br><br><b>See Section 5.3.1.1.1 for additional requirements.</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | One byte, concatenating: <ul style="list-style-type: none"><li>• <b>Bits [1:0]:</b> Whether separate Group ML configurations are supported:<ul style="list-style-type: none"><li>2'b00: Not Supported (all configured Group Addresses use the same ML Frame format as the Target Address); this variant is not included in I3C Basic</li><li>2'b01: Supported; each newly configured Group Address has its own configuration, set to a common frame format, when the Target is assigned to a Group Address</li><li>Other values not used</li></ul></li><li>• <b>Bits [5:2]:</b> The number of Group Addresses to which the Target is currently assigned (value from 4'd0 to 4'd15)</li><li>• <b>Bits [7:6]:</b> Reserved</li></ul> |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x9C                | <b>Get Group ML Report (optional)</b><br><br>Direct Read<br>Get only   | <b>Direct GET to an assigned Dynamic Address:</b> The directly addressed Target responds with a report on the number of separate Group ML configurations (i.e., separate ML Frame formats for a Group Address) that it will support, followed by a 3-byte tuple describing the currently configured ML Frame format for each supported I3C Mode for each Group Address to which the Target is assigned.<br><br>Required if the Target supports Group Addresses in any I3C Modes using ML. If the Target does not support separate Group ML configurations, then it may return a 1-byte message of 0x00, or NACK its Target Address.<br><br><b>Example:</b> For a Target that supports up to 4 Group Addresses, supports ML only in HDR-BT Mode, and that is currently assigned to 3 Groups, the Target returns the byte 0x04 to indicate 3 separate Group ML configurations, followed by a 3-byte tuple for each. The first byte of each tuple is the Group Address, the second byte is the HDR-BT value (0x23), and the third byte is the ML Frame format's data byte. This Target is assigned to Group Addresses 7'h71, 7'h72, and 7'h74.<br><br>The addressed Target therefore transfers the following thirteen bytes: <table><tbody><tr><td>0x04,</td><td>The number of Group ML configurations across all I3C Modes</td></tr><tr><td>0x71, 0x23, 0x00,</td><td>Group Address 7'h71, HDR-BT mode 0x00, 1-Lane default</td></tr><tr><td>0x72, 0x23, 0x01,</td><td>Group Address 7'h72, HDR-BT mode 0x01, 2-Lane ML with Coding 0</td></tr><tr><td>0x74, 0x23, 0x1B,</td><td>Group Address 7'h74, HDR-BT mode 0x1B, 4-Lane ML with Coding 3</td></tr><tr><td>0x00, 0x00, 0x00</td><td>Not configured</td></tr></tbody></table> | 0x04,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | The number of Group ML configurations across all I3C Modes | 0x71, 0x23, 0x00, | Group Address 7'h71, HDR-BT mode 0x00, 1-Lane default | 0x72, 0x23, 0x01, | Group Address 7'h72, HDR-BT mode 0x01, 2-Lane ML with Coding 0 | 0x74, 0x23, 0x1B, | Group Address 7'h74, HDR-BT mode 0x1B, 4-Lane ML with Coding 3 | 0x00, 0x00, 0x00 | Not configured | One byte for the number of separate Group ML configurations that can be configured, followed by a 3-byte tuple for each described Group ML configuration.<br><br>Within each byte tuple: <ul style="list-style-type: none"><li>• <b>First Byte:</b> The Group Address (if assigned), or 0x00 (if not configured, which means the Second Byte and Third Byte are not valid)</li><li>• <b>Second Byte:</b> If configured, the identifier for the I3C Mode supported (see 0xFF above)</li><li>• <b>Third Byte:</b> If configured, the 3-bit number of Additional Data Lanes and 5-bit Data Transfer Coding number, formatted as described above</li></ul><br>For all valid Group ML configuration tuples, the first two bytes shall be unique. <ul style="list-style-type: none"><li>• All valid (configured) Group ML configurations shall be returned before any invalid (non-configured). A Target may terminate the transfer after at least one Group ML configuration tuple consisting only of all ZEROs.</li></ul> |
| 0x04,               | The number of Group ML configurations across all I3C Modes             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x71, 0x23, 0x00,   | Group Address 7'h71, HDR-BT mode 0x00, 1-Lane default                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x72, 0x23, 0x01,   | Group Address 7'h72, HDR-BT mode 0x01, 2-Lane ML with Coding 0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x74, 0x23, 0x1B,   | Group Address 7'h74, HDR-BT mode 0x1B, 4-Lane ML with Coding 3         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x00, 0x00, 0x00    | Not configured                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| All Others          | Reserved                                                               | Available Defining Byte values. Reserved for future definition of new MLANE CCC Sub-Commands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                            |                   |                                                       |                   |                                                                |                   |                                                                |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

3687      **Note:**

3688      An I3C Controller that supports any version of the I3C Basic Specification might be on the same I3C Bus with an I3C Target that supports the full I3C  
3689      Specification, and it might receive a report using the MLANE Direct GET CCC with the Sub-Command for **Get ML Capabilities** (i.e., Defining Byte 0xFF) or  
3690      other Sub-Commands that include ML Frame formats for I3C Modes that the I3C Controller does not support. In such a case, the I3C Controller shall ignore  
3691      any ML Frame formats that pertain to such I3C Modes (i.e., those marked as “Not included in I3C Basic” in **Table 57**), and shall not use the corresponding  
3692      Sub-Commands for such I3C Modes, as the I3C Controller would not have the capability to support Multi-Lane Data Transfers for such I3C Modes.

#### Direct SET Sub-Commands Sent to a Dynamic Address

3693      The Controller may send the MLANE Direct SET CCC with the Sub-Commands to set the ML Frame format for supported I3C Modes (i.e., Defining Byte 0x23)  
3694      when addressed to a Target Device’s Dynamic Address. The Target shall receive and acknowledge the CCC, to write a supported ML Frame format with the  
3695      Additional Data Byte for that I3C Mode, and the Target shall store this Data Byte in its ML configuration (i.e., configured ML Frame format) for the corresponding  
3696      I3C Mode. Unless defined otherwise for a particular I3C Mode, the Target shall return this same Data Byte from its stored ML configuration upon receiving the  
3697      MLANE Direct GET CCC with the same sub-command, addressed to the same Dynamic Address. The Target shall not reset or change this stored ML configuration,  
3698      unless it properly receives the Sub-Command for Reset ML, or receives any other valid action that might be defined for specific I3C Modes (i.e., as defined in sub-  
3699      sections of **Section 5.3.2**). The stored ML configuration for each supported I3C Mode shall be stored and used for subsequent transfers involving this Dynamic  
3700      Address (and the Broadcast Address, if the Target supports CCC flows in HDR Modes per **Section 5.2.1.2**) unless it is subsequently reset, or changed by a SET  
3701      Sub-Command (or another valid action). See **Section 5.3.1.1** for more details on ML-capable Device configuration.

3702      If the Device presents multiple Virtual Targets and uses shared Peripheral logic to manage transactions addressed to multiple Dynamic Addresses (per  
3703      **Section 5.1.2.1.2**), then the ML configurations (i.e., configured ML Frame formats) for each assigned Dynamic Address shall be configured and stored  
3704      independently. All conditions above shall apply for each Dynamic Address, and the Device shall honor the SET/GET semantics for the MLANE Direct CCC with  
3705      Sub-Commands addressed to any Dynamic Addresses. Each CCC with Sub-Command to set a stored ML configuration shall only change the ML configuration for  
3706      the particular Dynamic Address (per **Section 5.3.1.1** and **Section 5.3.1.1.2**) unless other requirements apply for specific I3C Modes (i.e., as defined in sub-sections  
3707      of **Section 5.3.2**) that have valid actions that would create exceptions to the requirements in **Section 5.3.1.1.2** for independent ML configurations per each Dynamic  
3708      Address.

3709      **Note:**

3710      *The Controller should determine whether such a Device has multiple Dynamic Addresses and presents multiple Virtual Targets using shared Peripheral  
3711      logic, before attempting to set an ML configuration with the MLANE Direct SET CCC to any Dynamic Address exposed by such a Device.*

### Direct SET Sub-Commands Sent to a Group Address

If the Target Device supports Group Address capabilities (per **Section 5.1.4.4**) and also supports separate Group ML configurations (i.e., variant 2'b01 per **Section 5.3.1.1.1**), then the Target shall also receive and acknowledge the MLANE Direct SET CCC with Sub-Commands for supported I3C Modes (i.e., Defining Byte 0x23) when addressed to an assigned Group Address. If the Target accepts the CCC with such a Sub-Command, then it shall only set its stored ML configuration (i.e., configured ML Frame format) for transactions involving that Group Address, but shall not change the stored ML configuration for any other assigned addresses. For HDR Modes, if the Target accepts the CCC with such a Sub-Command, then the stored ML configuration (if valid) shall be used for all subsequent transfers addressed to that Group Address (i.e., generic HDR Write commands); if the Target also supports CCC flows in that HDR Mode (per **Section 5.2.1.2**), then this ML configuration shall also be used for Direct SET CCCs that are addressed to that Group Address in that particular HDR Mode (per **Section 5.2.1.2.6**). See **Section 5.3.1.1.1** for more details on Group ML configuration. The Target shall not acknowledge the CCC with such a Sub-Command when addressed to any Group Address to which it has not been assigned.

**Note:**

*If the Target does not support Group Address capabilities, then the Target shall only acknowledge the MLANE Direct SET CCC with Sub-Commands for its supported I3C Modes (i.e., Defining Byte 0x23) when addressed to its assigned Dynamic Address.*

*An I3C Controller that supports any version of the I3C Basic Specification shall properly handle any I3C Targets that might report as variant 2'b00 and do not support separate ML configurations for assigned Group Addresses. See **Section 5.3.1.1.1** for more information.*

### Broadcast SET Sub-Commands

The Controller may also send the MLANE CCC with the Sub-Commands to set the ML Frame format for supported I3C Modes (i.e., Defining Byte 0x23) as a Broadcast CCC, and all Target Devices on the I3C Bus shall acknowledge the CCC (per **Table 15**). However, only Targets that support the MLANE CCC and also support the particular I3C Mode indicated by the Defining Byte may attempt to apply the ML configuration that follows the Defining Byte in the Broadcast SET CCC message. Each such Target shall compare the ML configuration to see whether it is valid (i.e., supported) for that I3C Mode: if so, then it shall store this Data Byte in its ML configuration (i.e., configured ML Frame format) for the corresponding I3C Mode, as applied to its assigned Dynamic Address (or all assigned Dynamic Addresses, if it is a Device that presents multiple Virtual Targets, per **Section 5.1.2.1.2** and **Section 5.3.1.1.2**) as well as all currently assigned Group Addresses (if supported, per **Section 5.3.1.1.1**). See **Section 5.3.1.1** for more details on ML-capable Device configuration.

If the provided ML configuration is not valid (i.e., not supported) for that I3C Mode, then the Target shall not apply the Data Byte and shall not make any configuration changes based on the Broadcast SET CCC message. Additionally, if the Target does not support the particular I3C Mode indicated by the Defining Byte, then it shall not act on the rest of the Broadcast SET CCC message. However, in both cases the Controller would not know that the Target did not make any changes to its ML configuration as a result of this Broadcast SET CCC, so the Controller should follow up by sending the MLANE Direct GET CCC with the same sub-command, addressed to each Dynamic Address that is known to support that particular I3C Mode.

**Note:**

*If some I3C Targets on the Bus do not support certain I3C Modes, or if some Targets do not support certain ML Frame formats for a given I3C Mode, then the MLANE Broadcast CCC with a given Defining Byte and Data Byte would not always configure all such Targets to use the same ML Frame format for the same I3C Mode. It is the responsibility of the I3C Controller to determine which ML configuration changes (including those sent using the MLANE CCC as a Broadcast SET CCC) have been accepted by all Targets, and whether any such Targets might not have acted on the Broadcast SET CCC message. For situations where the Controller discovers that some Targets did not accept or apply such an ML configuration change, the Controller must resolve the situation by ensuring that all Targets are configured to use ML Frame formats that are mutually interoperable for each I3C Mode, or using an error recovery procedure which might include the Sub-Command for Reset ML (i.e., Defining Byte 0x7F).*

### 5.1.9.3.31 Set Bus Context (SETBUSCON)

This optional Broadcast CCC (*Figure 87*) allows the I3C Controller to specify that a particular context (*Table 57*) is being used on the I3C Bus, i.e., allows the Controller to set the Bus context. The context will usually be a higher-level protocol specification published by a standards-developing organization that relies upon MIPI I3C for the communication, but it may also indicate which version of the MIPI I3C Basic Specification is being used.

This CCC allows Targets to activate any special functions needed to support the selected higher-level protocol on this I3C Bus. This activation includes the definition of Vendor-specific or Standards-specific CCCs, and might include initiating any preparations required before starting the selected higher-level protocol, or potentially control of any other Device capabilities.

**Example:** A given Target might need to reduce, expand, or modify its support for the given Bus, based upon the requirements of the selected higher-level protocol specification.

The SETBUSCON CCC is normally emitted only once during Bus initialization; however, the Controller might need to emit SETBUSCON again after a Hot-Join, a Target Reset, or any other situation that might cause a Target to lose its context.

**Note:**

*In the SETBUSCON model, Targets only react to Bus context byte values that they recognize. For example, a Debug-capable Target (or Debug part of a Target) will react only to the Debug context byte value, whereas the normal application Target will react only to the context byte value representing the main context.*

The Command Code for the SETBUSCON Broadcast CCC is 0x0C. Support for this CCC is optional, and shall depend on the supported context(s).

#### Layered Protocol Contexts

On a given Bus, SETBUSCON CCC is typically used with only one context value. However in some situations it can be used more than once, with different context byte values, in order to support a layered protocol context.

**Examples:**

1. Emitting both the MIPI I3C Basic Specification revision context, and the context of a given higher-level protocol. The order would be: first emit the I3C Basic Specification revision context value, and then emit the higher-level protocol context value.
2. Adding an isolated, mixed-channel use, for example Debug. This allows a normal higher-level protocol to be used alongside Debug-specific Messages, in an intermixed manner. In such cases both contexts may be emitted.
3. Setting Bus context for JEDEC SPD changes rules for Dynamic Address Assignment, and defining a set of Vendor-specific / Standards-specific CCCs.



Figure 87 SETBUSCON Format

3769  
3770

3771

**Table 57 SETBUSCON Context Values**

| Context Byte Value | Context Group                                    | Context Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                         |    |             |                   |                         |    |             |
|--------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------|----|-------------|-------------------|-------------------------|----|-------------|
| 0                  | None                                             | Reserved, do not use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                         |    |             |                   |                         |    |             |
| 1 – 63             | <b>MIPI I3C Specification v1.Y Minor Version</b> | <p><b>Bits[7:6]:</b> 2'b00</p> <p><b>Bit[5]:</b> I3C Specification Editorial Revision (within Minor Version)</p> <ul style="list-style-type: none"> <li>1'b0: Version 1.Y.0</li> <li>1'b1: Version 1.Y.1 or greater</li> </ul> <p><b>Bit[4]:</b> I3C Specification Family</p> <ul style="list-style-type: none"> <li>1'b0: MIPI I3C Specification</li> </ul> <p><b>Note:</b> An I3C Controller that supports the I3C Basic Specification shall not use the value 1'b0 in this field.</p> <ul style="list-style-type: none"> <li>1'b1: MIPI I3C Basic Specification</li> </ul> <p><b>Bits[3:0]:</b> I3C Specification Minor Version (v1.Y)</p> <ul style="list-style-type: none"> <li>4'b0000: Illegal, do not use (see Note below)<br/>(It would encode v1.0, but SETBUSCON was not available in I3C Basic v1.0)</li> <li>4'b0001–4'b1111: Version 1.1 – Version 1.15</li> </ul> <p><b>Examples:</b></p> <table style="margin-left: 20px; border-collapse: collapse;"> <tr> <td style="padding-right: 10px;">I3C Basic v1.1.1:</td> <td style="padding-right: 10px;">1'b1    1'b1    4'b0001</td> <td style="padding-right: 10px;">or</td> <td style="padding-right: 10px;">8'b00110001</td> </tr> <tr> <td>I3C Basic v1.2.0:</td> <td>1'b0    1'b1    4'b0010</td> <td>or</td> <td>8'b00010010</td> </tr> </table> | I3C Basic v1.1.1: | 1'b1    1'b1    4'b0001 | or | 8'b00110001 | I3C Basic v1.2.0: | 1'b0    1'b1    4'b0010 | or | 8'b00010010 |
| I3C Basic v1.1.1:  | 1'b1    1'b1    4'b0001                          | or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8'b00110001       |                         |    |             |                   |                         |    |             |
| I3C Basic v1.2.0:  | 1'b0    1'b1    4'b0010                          | or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8'b00010010       |                         |    |             |                   |                         |    |             |
| 64 – 127           | <b>Other MIPI Working Groups</b>                 | Reserved for higher-level protocols defined by other MIPI Alliance specifications that use MIPI I3C for communications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   |                         |    |             |                   |                         |    |             |
| 128 – 191          | <b>Other Standards Organizations</b>             | Reserved for higher-level protocols defined by other standards developing organizations. The values are assigned by MIPI Alliance I3C WG.<br>See public registry at <a href="https://www.mipi.org/MIPI_I3C_bus_context_byte_values_public.html">https://www.mipi.org/MIPI_I3C_bus_context_byte_values_public.html</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   |                         |    |             |                   |                         |    |             |
| 192 – 255          | <b>Vendor Custom</b>                             | Available for private, per-vendor use (not tracked by MIPI Alliance)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                         |    |             |                   |                         |    |             |

### Note:

An I3C Controller that supports version 1.1 or greater of the full I3C Specification might emit the SETBUSCON CCC with Bit[4] set to 1'b0. In that case, an I3C Target that supports version 1.1 or greater of the I3C Basic Specification should ignore Bit[4].

An I3C Controller that supports any version of the I3C Basic Specification shall not emit the SETBUSCON CCC with Bit[4] set to 1'b0; for an I3C Basic Controller, 1'b1 is the only valid value for Bit[4].

206

#### 5.1.9.4 Direct CCCs and Group Addresses

If a Target supports Group Address capabilities (see **Section 5.1.4.4**) and has been assigned a Group Address, then it may receive and acknowledge certain Direct SET or Direct Write CCCs sent to an assigned Group Address, for Direct CCCs that are either defined in **Table 16**, or otherwise reserved for other MIPI WGs or custom definition. The Controller may send a Direct CCC as a Write to a Group Address, such that all Targets in the Group may receive and acknowledge such Direct CCCs (if supported). Each such Target that supports such CCCs shall ACK the Direct CCC as a Write sent to an assigned Group Address, as indicated in this section, using the same manner for acknowledging a Direct CCC as a Write that would be sent to its assigned Dynamic Address (per **Section 5.1.9.2.2**).

**Note:**

*If no such Targets ACK a Direct SET or Direct Write CCC that is sent to an assigned Group Address, then the Controller shall detect this as a NACK (i.e., a failure to ACK the CCC).*

**Table 58** specifies which Direct CCCs are either recommended for use (with possible limitations) or not supported for use with a Group Address.

- A Target that supports any of these CCCs marked as ‘Not supported’ that might otherwise be supported (i.e., when sent to its assigned Dynamic Address) shall not acknowledge the same CCC when sent to a Group Address to which it is currently assigned.
- A Target that supports any of these CCCs marked as ‘May use as multicast’ may choose to acknowledge the CCC when sent to either its Dynamic Address or any assigned Group Address, with identical meaning. Such ‘multicast’ writes may be used for convenience of configuration.
  - The Controller should follow up with a Direct GET form of the same CCC (if applicable) to each Target’s Dynamic Address to confirm that the Direct SET to the Group Address was accepted.
  - If a Target does not support such a CCC when sent to a Group Address, then the Controller might not see its lack of acknowledgement.
- A Target that supports any of these CCCs marked as ‘Limited support’ or ‘Not recommended’ might support Group Addresses for certain formats or when used with certain Defining Bytes, for particular use cases only. In such cases, the Target might not support the CCC in the same manner as though it were sent to its Dynamic Address.

3805

**Table 58 Direct CCC Support for Group Addresses**

| Command Name                                                     | Status                                  | Notes and Limitations                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ENECDISEC</b>                                                 | May use as multicast                    | Note that the event conditions that are controlled by these CCCs relate to Target Interrupt Requests, which cannot be sent from a Group Address                                                                                                                                                                                                                         |
| <b>ENTAS0</b><br><b>ENTAS1</b><br><b>ENTAS2</b><br><b>ENTAS3</b> | May use as multicast                    | Activity State configuration generally applies to the whole Device. Note that many uses of these CCCs are to communicate expected latencies to expect in response to pulling SDA Low, which do not apply to an assigned Group Address, since a Target Interrupt Request cannot be generated from a Group Address.                                                       |
| <b>SETMWL</b>                                                    | May use as multicast                    | Maximum write length applies to the whole Device, not an individual Group Address. No standard method is defined to read the maximum write length for only a Group Address, as opposed to a Dynamic Address.                                                                                                                                                            |
| <b>SETMRL</b>                                                    | <i>Not recommended</i>                  | Multicast configuration not recommended. Maximum read length does not usually apply, since Controller cannot read from a Group Address.                                                                                                                                                                                                                                 |
| <b>SETDASA</b><br><b>SETNEWDA</b>                                | <i>Not supported</i>                    | CCCs that assign or change a Dynamic Address cannot be sent to any Group Address.                                                                                                                                                                                                                                                                                       |
| <b>SETBRTGTT</b>                                                 | <i>Not supported</i>                    | Group Addressing is not defined for a Bridge Device.                                                                                                                                                                                                                                                                                                                    |
| <b>SETROUTE</b>                                                  | <i>Not supported</i>                    | Group Addressing is not defined for a Routing Device.                                                                                                                                                                                                                                                                                                                   |
| <b>SETXTIME</b>                                                  | May use as multicast                    | Timing Control settings apply to the Device as a whole. Note that any Timing Control settings sent to a Group Address should be used for multicast configuration as an alternative to the Broadcast SETXTIME CCC. Controllers should first confirm that all Targets in a Group support the same Timing Control Mode before using the SETXTIME CCC with a Group Address. |
| <b>ENDXFER</b>                                                   | May use as multicast                    | Controller should confirm that applied settings are accepted, using Direct GET CCC to each Target's Dynamic Address; see <b>Section 5.2.2.3.4</b> .                                                                                                                                                                                                                     |
| <b>D2DXFER</b>                                                   | <i>Not supported</i>                    | <i>This CCC is not included in the I3C Basic Specification.</i>                                                                                                                                                                                                                                                                                                         |
| <b>RSTACT</b>                                                    | Limited support, for defined uses only. | Target Reset Actions are not defined for a Group Address. Specific Defining Bytes might be used with Group Addresses, for some special use cases. Recommend using Dynamic Addresses, unless specific situations require Group Addresses.                                                                                                                                |
| <b>SETGRPA</b>                                                   | <i>Not supported</i>                    | SETGRPA CCC may only be sent to a Target's Dynamic Address.                                                                                                                                                                                                                                                                                                             |
| <b>RSTGRPA</b>                                                   | Limited support, for defined uses only. | In one form, removes all Targets from this Group Address; see <b>Section 5.1.9.3.28</b> .                                                                                                                                                                                                                                                                               |
| <b>MLANE</b>                                                     | Limited support, for defined uses only. | Sets the ML Frame format for subsequent transfers addressed to the Group Address for an I3C Mode. May only be sent if all Targets in the Group support separate ML configurations (per <b>Section 5.3.1.1</b> ).                                                                                                                                                        |
| MIPI WG Reserved                                                 | Not yet defined                         | Reserved for use by other MIPI Alliance Working Groups. Support for Group Addressing might be defined in another MIPI specification.                                                                                                                                                                                                                                    |
| Vendor / Standards Extension                                     | For Vendor or Standards use             | Generally available for use (see <b>Table 16</b> ), but MIPI Alliance recommends careful consideration based on the intended use case. Contact MIPI Alliance I3C Working Group for guidance and specific recommendations.                                                                                                                                               |

3806

**Note:**

3807 For any Direct CCCs listed in **Table 58** with either full or partial support for a Group Address, such  
 3808 CCC definitions in the respective sub-sections of **Section 5.1.9.3** that only have a Direct SET or Direct  
 3809 Write CCC form using "Target Addr" in the Direct CCC framing (i.e., after the Repeated START, or  
 3810 "Sr") should also be interpreted as supporting a valid Group Address with that particular form, where a  
 3811 Group Address may be used in place of the "Target Addr" in the framing (see **Section 5.1.2.1.3**).

3812 However, any CCCs that are listed as 'Limited support' or 'Not recommended' should generally not be  
 3813 interpreted as supporting a Group Address in place of the "Target Addr" (per notes and limitations).

3814 Additionally, any CCCs that are listed as 'Not supported' do not support a Group Address in place of  
 3815 the "Target Addr".

3816

The Controller shall not send any Direct GET or Direct Read CCCs to a Group Address, and Targets shall  
 3817 not ACK any Direct CCCs that would attempt to read from an assigned Group Address.

### 5.1.10 Error Detection and Recovery Methods for SDR

The error detection and recovery methods specified in this Section are provided in order to avoid fatal conditions when errors occur. A set of required methods is specified for I3C Target Devices, and a separate set of required methods is specified for I3C Controller Devices. Origins for all of these SDR Error Types are shown in *Figure 164* through *Figure 167*.

#### 5.1.10.1 SDR Error Detection and Recovery Methods for I3C Target Devices

The Error Types summarized in *Table 59* shall be supported for all I3C Target Devices. Each Error Type is further explained in a sub-section below the table.

**Note:**

*In previous versions of the I3C Specification, these Error Types for I3C Target Devices were named “S0”, “S1”, etc. The purpose, detection methods, and recovery methods for these Error Types are unchanged.*

**Table 59 SDR Target Error Types**

| Error Type                                                                    | Description                                                                                              | Error Detection Method                                                                                                                                     | Error Recovery Method                                                                                                                                                                                                           |
|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TE0                                                                           | <b>Invalid Broadcast Address/W<br/>(7'h7E/W)</b><br>or<br><b>Dynamic Address/RnW after DA assignment</b> | Detect any of the following:<br>7'h3E / W<br>7'h5E / W<br>7'h6E / W<br>7'h76 / W<br>7'h7A / W<br>7'h7C / W<br>7'h7F / W<br>7'h7E / R <sup>1</sup>          | a. Enable HDR Exit Detector and ignore all other patterns<br>b. (Optional) If both SCL and SDA stay at High level for a period greater than 60 µs, then enable STOP or START detector to exit from the TE0/TE1 error situation. |
| TE1                                                                           | <b>CCC Code</b>                                                                                          | Parity Check, using T-Bit                                                                                                                                  | a. Enable HDR Exit Detector and neglect other patterns.<br>b. (Optional) If both SCL/SDA stay at High level for a period greater than 60 µs, then enable STOP or START detector to exit from the TE0/TE1 error situation.       |
| TE2                                                                           | <b>Write Data</b>                                                                                        | Parity Check, using T-Bit                                                                                                                                  | Enable STOP or Repeated START detector and neglect other patterns.                                                                                                                                                              |
| TE3                                                                           | <b>Assigned Address during Dynamic Address Arbitration</b>                                               | Parity Check, using PAR Bit                                                                                                                                | Generate NACK (after PAR), then wait for another Repeated START and 7E/R to re-transmit the Provisioned ID.                                                                                                                     |
| TE4                                                                           | <b>7'h7E/R missing after Sr during Dynamic Address Arbitration</b>                                       | Detect 7'h7E/R missing after Sr during Dynamic Address Arbitration                                                                                         | Generate NACK (after 7'h7E/R), then enable STOP or Repeated START Detector and ignore all other patterns                                                                                                                        |
| TE5                                                                           | <b>Transaction after detecting CCC</b>                                                                   | Detect illegally formatted CCC                                                                                                                             | Generate NACK (after Target Address), then enable STOP or Repeated START Detector and ignore all other patterns                                                                                                                 |
| TE6<br>(optional)                                                             | <b>Monitoring Error</b>                                                                                  | Target detects (through monitoring) that transmitted Data differs from what it intended to transmit<br>(Does not apply during Dynamic Address Arbitration) | Stop the transmission, then enable STOP or Repeated START Detector (per Read type) and ignore all other patterns                                                                                                                |
| DBR<br>(optional)                                                             | <b>Dead Bus Recovery</b>                                                                                 | Controller acting as Target detects that the I3C Bus is no longer being driven by a Controller                                                             | Controller acting as Target retakes control of the I3C Bus, becoming Active Controller                                                                                                                                          |
| <b>Note:</b>                                                                  |                                                                                                          |                                                                                                                                                            |                                                                                                                                                                                                                                 |
| 1. In the ENTDAA mode, “7'h7E / R” is excluded from the TE0 error definition. |                                                                                                          |                                                                                                                                                            |                                                                                                                                                                                                                                 |

### 5.1.10.1.1 Error Type TE0

If an error occurs during Broadcast Address/W or Dynamic Address/RnW after a Dynamic Address is assigned, then the Target will be unable to distinguish whether the transfer is a CCC transfer or a Private RnW transfer. For example, in the case of an ENTHDR CCC transfer the Target is not able to know that the I3C Bus has changed to HDR Mode. A potentially fatal situation could ensue if this case is not detected and handled, because the Target might become confused by seeing many STARTs and STOPs as illustrated in *Figure 88*, and might attempt to interpret the HDR transfer as though the I3C Bus were still in SDR Mode.



**Figure 88 Example Waveform for Error Type TE0**

In order to avoid this situation, the Controller shall not use any of the possible error case Addresses: 7'h7F, 7'h7C, 7'h7A, 7'h76, 7'h6E, 7'h5E and 7'h3E.

- The Controller shall not assign any of these Addresses to any Target as a Dynamic Address (or a Group Address, if supported) per the I3C Target Address restrictions in *Table 8* (see *Section 5.1.2.2.5*).
- The Controller shall not use any of these Addresses in an I3C Address Header with the RnW bit of 1'b0, because the Target cannot distinguish such an I3C Address Header from a write to the Broadcast Address (i.e., 7'h7E/W) that has a single bit error.

Except during a Dynamic Address Arbitration procedure, the Target shall consider receipt of any of these restricted Addresses (i.e., 7'h7F/W, 7'h7C/W, 7'h7A/W, 7'h76/W, 7'h6E/W, 7'h5E/W and 7'h3E/W), or the receipt of 7'h7E/R, as an error per the following conditions:

- The Target shall always use its Error Type TE0 detector after a Dynamic Address has been assigned, to monitor the I3C Address Header for SDR Mode transfers.
  - This generally applies to any I3C Address Header that follows either a START or a Repeated START (see *Figure 164*, *Figure 165*, and *Figure 166*).
  - However, this shall not apply during the Dynamic Address Assignment procedure if the Controller uses the ENTDAA CCC (per *Section 5.1.4.2*). If this occurs, then the Target shall use its Error Type TE4 detector instead (per *Section 5.1.10.1.5*) until the end of the Dynamic Address Assignment procedure (see *Figure 167*).

If the Target's Error Type TE0 detector detects such a single bit error in an I3C Address Header, then the Target shall ignore the rest of the signal until either:

- The Target detects the HDR Exit Pattern; or
- Optional: The Target detects that both SCL and SDA stay High for a period greater than 60 µs (see *Section 5.1.10.1.9*).

**Note:**

*The second method is optional, i.e., Target Devices are not required to support it. If this method is supported, then the Target shall enable its STOP or START detector to exit from the Error Type TE0 state. If supported, then this method may also be used for Error Type TE1.*

#### 5.1.10.1.2 Error Type TE1

If the Target detects a parity error during a CCC code, then the Target will not be able to know that the I3C Bus has changed to HDR Mode if the CCC is ENTHDR. This is similar to the situation in Error Type TE0. In order to avoid this situation, if the Target detects a parity error during a CCC code, then the Target shall ignore the rest of the signal, until:

**Either:**

- The Target detects the HDR Exit Pattern,

**Or:**

- Optional: The Target detects that both SCL and SDA stay High for a period greater than 60 µs (see *Section 5.1.10.1.9*).

**Note:**

*The second method is optional, i.e., Target Devices are not required to support it. If this method is supported, then the Target shall enable its STOP or START detector to exit from the Error Type TE1 state. If supported, then this method may also be used for Error Type TE0.*

#### 5.1.10.1.3 Error Type TE2

If the Target detects a parity error during Write Data, then the Target shall wait for STOP or Repeated START.

If the Target detects this error after receiving a CCC, then the Target shall:

**Either:**

1. Retain the CCC state until the Target detects the end of CCC command (i.e., when the Target is recovered by the Repeated START),

**Or:**

2. Disregard everything until the STOP.

#### 5.1.10.1.4 Error Type TE3

If the Target detects a parity error in the PAR Bit of the Assigned Address during a Dynamic Address Arbitration procedure, then the Target shall generate NACK (after PAR) and then wait for another Repeated START and 7E/R to re-transmit the Provisioned ID.

#### 5.1.10.1.5 Error Type TE4

During a Dynamic Address Arbitration procedure, if the Target detects any value other than 7'h7E/R following Repeated START, then the Target shall generate NACK (after 7'h7E/R) and then wait for STOP to exit the ENTDAA mode.

### 5.1.10.1.6 Error Type TE5

If the Target detects an illegally formatted CCC, then the Target shall generate NACK (after the Dynamic Address) and then wait for STOP or Repeated START.

Examples of an illegally formatted CCC include:

- If the Target receives a matching Dynamic Address with Write during a Direct CCC that only has a Direct Read or Direct GET form (e.g., the GETBCR CCC)
- If the Target receives a matching Dynamic Address with Read during a Direct CCC that only has a Direct Write or Direct SET form (e.g., the SETGRPA CCC)

If the Target detects this error after receiving a CCC, then the Target shall either:

1. Retain the CCC state until the Target detects the end of CCC command (i.e., when the Target is recovered by the Repeated START), or else
2. Stop the CCC when the Target is recovered by the STOP.

**Note:**

*This section does not provide all examples of illegally formatted CCCs.*

**Note:**

*If the Target detects a Direct CCC that is formatted correctly, but that is not supported, then the Target shall handle such CCCs, or unsupported Defining Bytes, as described in Section 5.1.9.2.2.*

*In an HDR Mode CCC, the Target would wait for the CCC to end as described in Section 5.2.1.2.1, Figure 98.*

### 5.1.10.1.7 Error Type TE6 (Optional)

If an error occurs in the RnW Bit of the Address Header, then the Target might believe that it is responding to a Read, when what the Controller actually intends to initiate is a Write. If this happens, then the Write Data from the Controller might conflict with the Read Data from the Target.

The Target should always monitor the Data it transmits for Read transactions. If the Target does so, then if the monitored Data differs from the Data the Target intended to transmit, the Target shall consider this condition to be an error.

**Note:**

*The Controller should also monitor the Data it transmits. If this condition happens due to a Target's misinterpretation of the RnW bit during an intended Write transfer, then the Controller should also detect this condition as Error Type CE1 (see Section 5.1.10.2.2).*

*The Target shall not consider this condition to be an example of Error Type TE6 during the Arbitration round of a Dynamic Address Assignment procedure (i.e., when the Controller has sent the ENTDAAC CCC while the Target is attempting to drive its Provisioned ID, BCR and DCR (see Section 5.1.4.2).*

If the Target detects such an error during an intended Private Write transfer (i.e., when the Target believes it is responding to a Private Read transfer), then it shall stop the transmission, allow the Controller to finish, and then wait for STOP or Repeated START.

If the Target detects such an error during an intended Direct SET or Direct Write CCC (i.e., when the Target believes that it is responding to a Direct GET or Direct Read CCC), then the Target shall stop the transmission, allow the Controller to finish, and then either:

1. Retain the CCC state until the Target detects the end of CCC command (i.e., when the Target is recovered by the Repeated START), or else
2. Stop the CCC when the Target is recovered by the STOP.

### 5.1.10.1.8 Error Type DBR (Optional)

This error allows a Controller-capable Device that is acting as a Target (i.e., a Secondary Controller) to regain control of a dead Bus (i.e., where the Active Controller has stopped working for whatever reason). This works both for a Primary Controller acting as Target (i.e., while a Device that initialized as a Secondary Controller is acting as Active Controller), and for a Secondary Controller acting as a Target.

The general model is that when the Controller acting as Target pulls SDA Low to request an IBI or CRR, it may measure the time before SCL goes Low (i.e., in response to this START Request). If SCL does not go Low in 50 ms ( $t_{CAS}$  maximum for Activity State 3), then the Controller acting as a Target may take action to take over control of the Bus and become the new Active Controller.

The steps are as follows:

1. The Controller acting as Target pulls SDA Low to initiate an IBI or CRR.
  - a. It starts a timer.
2. If 50 ms has elapsed without SCL going Low, then the Controller acting as a Target assumes that the former Active Controller is not operational.
  - a. If SCL is pulled Low before 50 ms, then all is well and Error Type DBR shall not apply.
  - b. Otherwise, Error Type DBR applies and as a result the Target acting as Controller may start a transition to Controller mode.
3. Once in Controller mode, the Device shall verify that SCL is still High, and if so, pull SCL Low to complete a START.
  - a. If SCL is not High by the time the Device is a Controller, then the Device must switch back to Target mode, as Error Type DBR no longer applies. This might occur due to another Controller-capable Device (i.e., a Secondary Controller) having taken control of the Bus first.
4. After the START, the Controller may wish to check the status of the Targets.
  - a. It may also initiate an ENTDA sequence to see whether any Devices need a Dynamic Address to be assigned (see [Section 5.1.4.2](#)).
  - b. If available, the last DEFTGTS information that might have been sent by a previous Active Controller (i.e., as a Broadcast CCC) should be used for proper Dynamic Address assignment.

**Note:**

A Controller-capable Device acting as Target may choose to monitor the Bus at all times. In the event that SDA is pulled Low by any Target, the Device may then measure the time waiting for SCL to be pulled Low. If 50 ms elapses without SCL being pulled Low, then it may start the Dead Bus Recovery process above at step 3.

If the former Active Controller eventually resumes operation and senses activity on SCL and/or SDA, then it must assume that it has lost the Controller Role to the new Active Controller.

Per [Section 5.1.11.4.1](#), the Primary Controller shall use a similar procedure after a Full/Chip reset, to determine whether it should be the Active Controller of the Bus.

### 5.1.10.1.9 Optional Recovery Method for Error Types TE0 and TE1

An I3C Target can recover from an Error Type TE0 or Error Type TE1 situation not only by detecting the HDR Exit Pattern, but also by monitoring the SCL and SDA lines. If the Target detects that both lines stay at High level for a period exceeding 60  $\mu$ s, then the I3C Target can regard the Bus as operating in non-HDR mode. The I3C Target can then recover from the TE0 or TE1 situation, and wait for a STOP or a START to resume normal operation.

**Note:**

*Regarding timing, HDR's slowest clock rate is 10 kHz (100  $\mu$ s total cycle). The period 60  $\mu$ s is derived by assuming that HDR (i.e., HDR-DDR Mode) will always keep an approximately even duty cycle, especially at very slow clock rates (since the only reason to go so slow is for long lines and/or large capacitive load on Bus lines). 60  $\mu$ s represents 60% of the duty cycle, and therefore is a safe duration to wait when seeing both lines High.*

*The Target can start measuring the period whenever it detects that both SCL and SDA are at High level. There is no need to start timing this period at any particular signal pattern (for example, at the STOP).*

### 5.1.10.2 SDR Error Detection and Recovery Methods for I3C Controller Devices

Table 60 summarizes the defined Error Types for I3C Controller Devices. All I3C Controller Devices shall support Error Types CE0, CE2, and CE3, and should support Error Type CE1. Each Error Type is further explained in a sub-section below the table. Escalation and recovery is explained in *Section 5.1.10.2.5* and *Section 5.1.10.2.6*.

**Note:**

*In previous versions of the I3C Specification, these Error Types for I3C Controller / Controller Devices were named “M0”, “M1”, etc. The purpose, detection methods, and recovery methods for these Error Types are unchanged.*

**Table 60 SDR Controller Error Types**

| Error Type        | Description                                     | Error Detection Method                                                                                                                                   | Error Recovery Method                                                                      |
|-------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| CE0               | <b>Transaction after sending CCC</b>            | Detect illegally formatted CCC                                                                                                                           | Stop the transmission, then send STOP and retry the transmission.                          |
| CE1<br>(optional) | <b>Monitoring Error</b>                         | Controller detects (through monitoring) transmitted Data different from what it intended to transmit (Does not apply during Dynamic Address Arbitration) | Stop the transmission, then send STOP and retry the transmission.                          |
| CE2               | <b>No response to Broadcast Address (7'h7E)</b> | Controller detects NACK after Broadcast Address (7'h7E) transmission                                                                                     | Upon detection of NACK, Controller transmits HDR Exit Pattern followed by STOP             |
| CE3               | <b>Failed Controller Handoff</b>                | Active Controller detects New Controller does not drive Bus after handoff                                                                                | Active Controller regains the Controller Role and drives Bus to assert its Controller Role |

#### 5.1.10.2.1 Error Type CE0

If the Controller detects an illegally formatted CCC, then the Controller shall stop the transmission, send STOP, and retry the transmission. An example of an illegally formatted CCC would be the Controller receiving just one byte from the Target in a GETMWL CCC code, since the Controller expects two bytes.

#### 5.1.10.2.2 Error Type CE1 (Optional)

Error Type CE1 occurs when the I3C Controller detects that the transmitted data differs from what the Controller intended to transmit. This might happen when the I3C Controller or I3C Targets misinterpret the RnW bit or the ACK/NACK during transactions (including IBI) defined by the I3C specification. This Section describes only two kinds of occurrence conditions for Error Type CE1, and the recovery method for each kind. Note that Type CE1 errors are not an expected behavior.

If an error occurs in a RnW Bit in a Private Write transfer, then the Write Data from the Controller might conflict with the Read Data from the Target. For example, the Target could misinterpret a Private Write transfer as a Read transfer if there is an error in the RnW Bit, and as a result Write Data from the Controller would conflict with Read Data from the Target.

The Controller should always monitor the Data it transmits. If the Controller does so, then if the monitored Data differs from the Data the Controller intended to transmit (except for Data transferred during a Dynamic Address Arbitration procedure), the Controller shall consider that to be an error. If the Controller detects this error, then it shall stop the transmission, then send STOP and retry the transmission.

### 5.1.10.2.3 Error Type CE2

If the Controller does not receive an ACK of a transmitted Broadcast Address (7'h7E), then it shall transmit the HDR Exit Pattern followed by STOP in order to recover any Target after TE0, TE1, TE2, TE5, and TE6 errors.

### 5.1.10.2.4 Error Type CE3

After the Controller to Controller Handoff procedure (see *Section 5.1.6.3*), the former Active Controller shall release SCL to High-Z and disable its Open Drain class Pull-Up on SDA, setting SDA to High-Z. However, the former Active Controller shall monitor the Bus to ensure that the new Controller has successfully asserted its Controller Role.

If the former Active Controller does not detect a START within a specified Handoff period, then it shall test the New Controller to determine whether it actually controls the Bus, and it shall regain control of the Bus if the New Controller has not asserted its Controller Role. The specified Handoff period shall be at least 100 µs, but may be longer if the new Controller indicates that it requires a longer Handoff period.

Before initiating the Controller to Controller Handoff procedure, the Active Controller shall first determine whether the Secondary Controller that is about to receive the Controller Role supports the GETMXDS CCC with Defining Byte value CRHDLY (see *Section 5.1.9.3.18*). If the Secondary Controller needs a longer Handoff period to assert the Controller Role, then it shall do so by indicating an Activity State. The Active Controller shall wait for the time period associated with the indicated Activity State, or 100 µs (whichever is greater) before attempting to test the new Controller.

Once the Handoff period has elapsed, if the former Active Controller has not detected a START, then it should use the following steps to test the new Controller:

1. The former Active Controller shall pull SDA Low. This may be unnecessary if another I3C Target also pulls SDA Low (since the Handoff period is longer than the Bus Available Condition), but the effect is the same.
2. After SDA is pulled Low, the former Active Controller shall wait for another 100 µs, or the time indicated by the new Controller's indicated Activity State (as above, read with the GETMXDS CCC with Defining Byte value CRHDLY, if supported), whichever is greater.
  - a. If the new Controller responds by pulling SCL Low within that period, then all is well: the new Controller has successfully asserted its Controller Role of the Bus. This is equivalent to a START, so this flow has a successful outcome. The former Active Controller shall release SDA and allow the new Controller to proceed.
  - b. If the new Controller does not respond by pulling SCL Low within that period, then the former Active Controller shall pull SCL Low to regain the Bus Controller Role. This is equivalent to a START, but initiated in this case by the former Active Controller.

**Note:**

*This outcome is an error condition on the part of the new Controller, which has not responded per its obligations. As a result, the new Controller shall return to being a Target, or remain as a Target.*

In either case, the Controller that eventually ‘wins’ shall become the Active Controller, and shall drive a valid Bus action to assert its Bus Controller Role. Since the START has been driven, the next step is the I3C Address Header (see *Section 5.1.2.2*). The Active Controller shall attempt to drive its own Address (7'h7E). If another I3C Target drives its own Address and wins Arbitration, then that Target may attempt to issue a Target Interrupt Request. However, if the Active Controller wins Address Arbitration but does not have any actions to take at that time, then it may follow with a STOP. Either is sufficient for the Active Controller to assert its Bus Controller Role.

If the former Active Controller regains the Bus Controller Role due to inactivity by the new Controller, then it is responsible for taking any necessary actions to determine the reason why the handoff failed. It may use the GETSTATUS CCC or other commands to test for the presence of the new Controller, or to attempt to read its current status.

### 5.1.10.2.5 Controller Error Detection and Escalation Handling

If SDA is stuck Low, then see **Section 5.1.10.2.6**. This section addresses situations in which the Target is not responding.

If the Controller does not receive an ACK of a transmitted private Message to a Target, and if the following conditions are all true:

- Activity State is 0
- Either the Target Device has not indicated read-turnaround delays via GETMXDS, or the Target Device has indicated a GETMXDS period and a period longer than GETMXDS has elapsed
- The Target Device has not notified the Controller that it will be going into a lower Activity State via a private contract In-Band Interrupt (and either GETSTATUS or a private activity state status),

then the Controller has the following escalation options to recover the system:

1. If the Controller is aware that the Target might sometimes need extra time, then the Controller can choose to try again after a short delay.
2. If that fails, then the Controller shall check whether the Target is responsive by issuing GETSTATUS to the Target. The idea here is that the Target might be forced to NACK a private Message due to its inner system being unready, whereas GETSTATUS is a lightweight request that does not necessarily involve the inner system.
3. If that fails, then the Controller shall use CE2 error handling (see **Section 5.1.10.2.3**) to emit the sequence:

S | 7'h7E (W) | ACK/NACK\* | HDR Exit Pattern | STOP

**Note:**

\* The I3C Controller doesn't care whether the I3C Targets' response is ACK vs. NACK.

This ensures that the failure is not due to the Target thinking that the I3C Bus is in HDR Mode.

4. If that fails, and if the Target is still not responsive, then the next step depends on the value of the BCR "Offline Capable" bit (Bit[3]):

- a. If the Target is not Offline Capable, then:
  - i. The Controller can try slowing the SCL clock rate, or try slowing its effective rate by using duty cycle.
  - ii. If that fails, then the Target Reset mechanism can be used. A first attempt can be tried to recover via the Peripheral, and if that fails, then a second attempt will cause a chip reset. The Target Reset mechanism is explained in **Section 5.1.11**.
  - iii. If that fails, then any further escalation is outside the scope of the I3C Specification.
- b. If the Target is Offline Capable, then:
  - i. If the Target goes offline and is to be awoken via Target Reset, then the Target Reset approach should be used (see **Section 5.1.11**).
  - ii. If the Target is known (i.e., via a private contract) to have a long wake period, and also known to monitor the I3C Bus during that wake period, then the Controller simply delays and tries later, after a delay based on the known or expected wake up time. Escalation and the GETSTATUS ensure that the Target's Dynamic Address was issued; that should serve as the wake trigger. Either the Target may issue an In-Band Interrupt at a later time to notify the Controller that it is ready, or else the Controller may initiate the retry.
  - iii. If Target is not known to have a long wake period and to always monitor the I3C Bus, then the Controller marks the Target as offline. The Controller may then either retain the Target's Dynamic Address for re-use, or else discard it. The next action will be for the Target to issue a Hot-Join Request, in order to be re-joined to the I3C Bus. In the Hot-Join operation the Controller will assign the Target a Dynamic Address; the new Address may be either the same Address that the Target used before being marked as offline, or a different Address.

### 5.1.10.2.6 Controller Stuck SDA Handling

If SDA is not stuck, but the Target is not responding, then see [Section 5.1.10.2.5](#). If the Controller has recovered from a crash or unexpected reset, then see [Section 5.1.10.2.7](#).

The steps to attempt a recovery from a stuck SDA are as follows:

1. If reading from an I<sup>2</sup>C Device, and it is holding SDA Low, then:
  - a. Pulse out nine (9) SCL clocks, to get it to see the NACK on 9th bit to get it to let go.
2. If reading from an I3C Device in SDR Mode, and it is holding SDA Low, then:
  - a. Pulse out one clock at a time (up to 8), as it is required to drive SDA High for the T-Bit (9<sup>th</sup> bit).
  - b. Watch for SDA going High, and abort the read by driving SDA Low when SCL is High.
3. If reading from an I3C Device in SDR Mode, and SDA is being held Low, and the approach in step 2 did not work, then:
  - a. Hold SCL level (High or Low) for 150 µs. The Target might support the 100 µs read-abort approach (per [Section 5.1.2.3](#)), and if so, it will release SDA.
4. If reading from an I3C Device in SDR Mode, and SDA is High, and the Device does not seem to abort when the Controller drove SDA Low on the T bit (i.e., when SCL was High), then:
  - a. First try a 150 µs SCL hold (as explained in step 3).
  - b. If that does not work, then do the same drive SDA Low for each SCL High, for up to 8 more times. If there is a framing misalignment, then this will ensure that the T-Bit is finally caught and the read aborted.

**Note:**

*This risks contrary drive, so Controller could lower its drive strength to reduce current, if wanted.*

5. If reading from an I3C Device in HDR-DDR Mode, and it goes wrong, then see [Section 5.2.2.4](#).

### 5.1.10.2.7 Controller Recovery After a Crash or Unexpected Reset

If the Controller is recovering from a crash or unexpected reset, and it does not know the context of the Bus, then the Controller must determine the state of the Bus. It is assumed that the Controller has tried to put the Bus into Bus Free condition (i.e., SCL High, SDA held High with a Pull-Up), and that enough time has elapsed for the Pull-Up to pull SDA High, if possible.

The status may be one of:

- **SDA is High and controlled by the Controller alone.** This is normal Bus Free Condition. In this case the Controller should emit an HDR Exit Pattern (to be safe), and then work to recover the Bus in the usual manner (e.g., RSTDAA, etc.).
- **SDA is High, but a Target is holding it High from a previous Read.** See below for detection.
- **SDA is Low.** This might be a Target still holding Low from a previous Read, or it might be a Target pulling SDA Low for an In-Band Interrupt, a Controller Role Request, or a Hot-Join.

If **SDA is High**, and the Controller needs to determine whether it is held High, then the Controller may use one of three ways to do so:

1. The Controller uses a weak Pull-Down resistor in its pad for SDA and turns off any active Pull-Up. If the line goes Low (after a reasonable time), then it is controlled by the Controller, and the Controller may proceed normally.
2. The Controller may drive SDA Low, risking contrary drive (e.g., 4 mA current), to determine whether the SDA is held High.
3. The Controller may lower the drive current of the SDA pad and then drive Low, to minimize contrary drive effects.

If the Controller determines SDA to be held High, then follow the instructions in *Section 5.1.10.2.6*, step 4. This method can be used for both an SDR Read and an HDR-DDR Read, however an HDR-DDR Read will need 16 clocks (10 for data preamble, 16 in case last data into CRC).

If **SDA is Low**, then the Controller needs to determine why it is held Low. The Controller can use the following steps to do so:

1. The Controller drives SCL Low. If SDA is released (i.e., strong Pull-Up on SDA causes it to go High), then a Target was trying to perform an In-Band Interrupt, a Controller Role Request, or a Hot-Join. The Controller may pull SDA Low again and continue with a START, or emit a STOP (i.e., drive SCL High, then pull SDA High), and then proceed to restart the Bus by NACKing any In-Band Interrupt, Controller Role Request, or Hot-Join, and then using the RSTDAA CCC.
2. If SDA is not released, then the Controller should emit 19 or more SCL clocks. If SDA goes High at some point, then it should emit more SCL clocks to ensure 19 clocks were used with SDA High (in case it was in HDR-DDR Mode). If SDA is now High, then the Bus is not in HDR-DDR Read and also not in an I<sup>2</sup>C Read. The Controller should test whether SDA is stuck High, as explained above (starting at “If SDA is High”). If SDA is not stuck High, then the Controller should issue an HDR Exit Pattern in case it had been in HDR-DDR Mode.

### 5.1.11 Target Reset

This Section specifies the Target Reset mechanism.

The Target Reset mechanism:

- Allows the Controller to Reset one or more selected Targets, and avoid resetting any others
- Supports different levels of reset, ranging from resetting only the I3C Peripheral within a Target, to resetting the whole Target Device
- Supports I3C's error escalation mechanism (see *Section 5.1.10*), including reset of an errant Target

The Target Reset mechanism is simple, relying on these principles:

- The uniqueness of the HDR Exit Pattern (i.e., cannot be confused with any other I3C Bus traffic)
- Use of an in-band Target Reset Pattern to trigger the actual reset action. (In contrast to a reset/break hold as used in UART, one-wire [R], etc., which would require timing.)
- A defined default reset action that all Targets will use until and unless a different reset action is configured via the RSTACT CCC (Broadcast and Directed formats)
- An error recovery escalation mechanism, for use when needed (e.g., Error Types TE0 and TE1).

The Target Reset mechanism applies these principles to address three distinct reset cases:

1. Recovery from error/hang in the Target I3C Peripheral
2. Recovery from more serious errors in the chip containing the I3C Peripheral
3. Wake from deepest sleep, while minimizing the number of gates used in the always-on domain

#### 5.1.11.1 Theory of Operation

The Target Reset mechanism uses a simple model (*Figure 89*). In normal operation the Controller directs the Targets in their actions, and the Targets take those actions. When the Target is in a deep enough sleep, or is broken, then the Target Reset performs an appropriate action. The Controller uses the RSTACT CCC (Broadcast and/or Directed formats, as needed) to configure which Targets are to be reset, the level(s) of reset to be used, and which Targets are not to be reset.

**Controller:** To trigger the Reset action, the Controller shall emit the following sequence:

- START
- Zero or more Message components, including RSTACT CCCs (Broadcast and/or Directed, as needed) each optionally ending in Repeated START
- At this point in the sequence the Controller may emit a STOP, but it is recommended to instead keep the sequence within a single Frame (See Note below).
- The Target Reset Pattern, including the final Repeated START and STOP that trigger the actual reset action
- At this point in the sequence the Controller shall leave the Bus free for as long as needed (or desired) for the Targets to complete their reset cycles.
- START, with an I3C Address Header (directed to either 7'h7E or any other Address)

**Note:**

*It is preferable to emit the RSTACT CCCs and the Target Reset Pattern together in a single Frame (i.e., before emitting a STOP) for several reasons:*

- *To avoid the risk of the RSTACT getting disconnected from the Target Reset action, which would be dangerous. A properly operating Target will cancel an RSTACT CCC when it sees an SCL falling edge following a START (but not a Repeated START).*
- *Because neither I3C nor I<sup>2</sup>C define the Bus condition of SCL falling from Bus Free, and as a result some Devices might exhibit unknown or unexpected behavior.*
- *Because the Target Reset Pattern includes STOP, in order to preserve a clean Bus state for all Targets (i.e., both Targets that are being reset, and Targets that are not being reset).*
- *A Target could pull SDA Low after a STOP.*

**Target:** A Target shall react to receipt of the Target Reset Pattern based on its state at the time of reception:

- If the Target had been configured via the RSTACT CCC to take a particular reset action (including taking no action) and was able to process that RSTACT CCC (i.e., not broken), then the Target shall perform the reset action as configured.
  - If the Target had been in a deepest-sleep state, then it may Wake up (e.g., power up, etc.). This Wake operation itself may either reset the Device or not, per **Section 5.1.11.5**.
  - If a Target had been unable to recognize a RSTACT CCC (i.e., was broken), or if no RSTACT CCC had been sent to the Target, then the Target shall either:
    - **If this is the first time that the Target has seen the Target Reset Pattern:** Then the Target shall reset the I3C Peripheral. If a processor is in use, then it will notify the application via internal interrupt, so that it can reconfigure the I3C Peripheral).
- or
- **If the Target has previously reset the I3C Peripheral and is seeing a new Target Reset Pattern with no intervening RSTACT or GETSTATUS CCC:** Then the Target shall reset the whole chip, i.e., equivalent to an SRSTn pin being asserted (see **Section 5.1.11.4**).

**Note:**

*Any reset action (including inaction) configured via the RSTACT CCC shall be cleared by the next SCL falling edge following a START (but not by the next Repeated START).*

**Note:**

*This specification is silent regarding what Target internal memory is retained vs. cleared in a Peripheral reset (where 'memory' could be either volatile or non-volatile, and could be implemented in any number of ways). In particular, the Target's Dynamic Address may be either retained or cleared. If the Target clears its Dynamic Address, then it shall participate in an ENTDAA that follows the Target Reset Pattern; if the Target retains its Dynamic Address, then it shall not participate.*



**Figure 89 Target Reset Operations Flow**

### 5.1.11.2 RSTACT CCC

The RSTACT CCC (fully detailed in [Section 5.1.9.3.26](#)) has three formats with different uses:

- **Broadcast** to configure a Target Reset action for all Targets
- **Directed Write** to configure a Target Reset action for one or more specified Targets
- **Directed Read** to read the Reset recovery timing from each Target, including for reset of the Peripheral, Wakeup, and reset of the whole Device.

### 5.1.11.3 Target Reset Pattern

The Target Reset Pattern ([Figure 90](#)) is used to trigger the default or configured reset action. The Target Reset Pattern begins with fourteen SDA transitions while SCL is kept Low, and ends with a Repeated START followed by a STOP which triggers the actual Reset action. The Target Reset Pattern is easily distinguished both from the shorter HDR Exit Pattern on which it is based (see [Section 5.2.1.1.1](#)), and from the HDR Restart Pattern.



**Figure 90 Target Reset Pattern**

#### 5.1.11.4 Full/Chip Reset Behavior

Full/chip reset can be caused by either escalation of default (per *Figure 89*), or by a configured reset action via the RSTACT CCC with Defining Byte value 0x02 (per *Table 53*). This Specification does not strictly define behavior for a full/chip reset, however it is assumed to be similar to the behavior upon assertion of an SRSTn pin:

- Since this is a warm reset (i.e., power was not cut), the chip's precise behavior as it comes back up is the responsibility of the implementation.
- It is assumed that the chip will need to participate in the Dynamic Address Assignment process (ENTDAA CCC) in order to receive a Dynamic Address.
- Any further steps after the DAA process are the responsibility of the driver controlling the Controller and Target. Such steps might be dictated by rules imposed by higher-level standardized protocols (e.g., Camera, Touch, Debug, etc.), and/or by other *a priori* driver knowledge.

#### Examples

- **For a RAM-Based Target:** Determining whether another firmware download is needed
- **For a Sensor:** Determining whether a full calibration or a push of stored calibration data is needed

#### 5.1.11.4.1 Primary Controller Behavior After Full/Chip Reset

There is a special condition where the Primary Controller acting as a Target (i.e., a Secondary Controller) is reset by the Active Controller.

When the Primary Controller wakes up from the reset and it does not know why it was reset, it then needs to determine whether it was the Active Controller before the reset, or was acting as a Target (i.e., a Secondary Controller) and some other Controller-capable Device was the Active Controller.

In order to do this, the Primary Controller shall monitor the Bus for activity on SCL for  $t_{IDLE}$ . If the Bus is active, then the Device assumes it is not the Active Controller. If there is no activity, then the Device shall drive the SDA Low (if it wasn't already Low) and wait for 50 ms (i.e.,  $t_{CAS}$  maximum for Activity State 3), and if an Active Controller that initiated the Reset does not respond by pulling down the SCL line, then the Primary Controller can assume that it is the Active Controller and start driving the SCL line. Then the Primary Controller shall broadcast the RSTDAA CCC and continue with the Bus initialization.

**Note:**

*This procedure is similar to the Dead Bus Recovery procedure for Error Type DBR (see Section 5.1.10.1.8).*

#### 5.1.11.5 Wake from Target Reset Behavior

This Specification does not mandate any particular implementation or behavior for Wake from Target Reset. Wake might or might not involve a reset (in whole or part); this will usually depend upon how the deepest-sleep/standby is implemented.

Common types of Wake from Target Reset behavior include:

- **Wake Performs Reset:** The Target wakes from “power down” state with little or no restoration of saved information. In particular, the Target’s Dynamic Address is not saved. As a result, this case behaves like a normal reset: following the reset operation, the Target will need to participate in the Controller-initiated ENTDAACCC Dynamic Address Assignment process, in order to receive its assigned DA.
- **Wake with State Restoration:** Some amount of critical state information was previously saved somewhere outside the Target (e.g., always-on flops or the RTC domain), and is restored upon Target wake. This case works the same as offline wake model. This usually means saving and restoring the Target’s Dynamic Address, and can also involve additional state data. If the Target’s DA is restored in this manner, then the Controller will not need to take further steps to re-assign it (i.e., no need to then perform the ENTDAACCC Dynamic Address Assignment procedure).
- **Wake with State Preserved:** In this case, Target state information does not need to be explicitly restored because it is preserved in place during the reset-wake interval. This case behaves the same as a wake from light sleep. Data preservation might be achieved via state-retention flops (SRFF), or simply by not actually cutting power during the reset-wake interval.

### 5.1.12 Monitoring Device Early Termination Capability

This capability is not included in the I3C Basic Specification. To gain access to this capability, please contact MIPI Alliance. The following information from the full I3C Specification is retained for the information of I3C Basic implementers.

In complex systems, early termination of large data transactions can be useful in handling urgent situations, for example a lack of memory resources, or an immediate need for some different Receiver-side action. These situations can arise with large data transfers if the Receiver has insufficient memory available at the time of the transaction.

There also exist significant use cases where other Devices resident on the I3C Bus but not directly involved with a given transaction require Bus access. Examples include: Emergency situations, such as overheating; When a Device that monitors a transaction and collects its data runs out of resources; and touch display applications, where minimizing transfer latency is critically important.

This capability enables an I3C Device to optionally request that the Controller prematurely terminate an immediately following Bus transaction that it does not directly participate in. Such Devices are called Monitoring Devices.

### 5.1.13 Device to Device(s) Tunneling

This capability is not included in the I3C Basic Specification. To gain access to this capability, please contact MIPI Alliance. The following information from the full I3C Specification is retained for the information of I3C Basic implementers.

Data transfers on an I3C Bus are usually routed through the Active Controller, and this is suitable for a large majority of applications. However, there are some use cases in which data must flow from one Device to another, and neither the receiver nor the sender is the Active Controller. While it's true that the Active Controller could collect the data and then transfer it to the Target, or one Target could acquire the Controller Role and then perform the data transfer, these procedures add latency and increase energy expenditure.

Device to Device(s) Tunneling (D2DT) exists to support specialized Message transfers between a Target and one or more other Targets, and from a Controller acting as though it were a Target transferring a Message to one or more other Targets.

## 5.2 High Data Rate (HDR) Modes

This Section specifies the communication protocols for the two defined I3C High Data Rate (HDR) Modes that are available in I3C Basic. These HDR Modes are designed to transfer more data at the same Bus frequency:

- **HDR Double Data Rate (HDR-DDR) Mode**
- **HDR Bulk Transport (HDR-BT) Mode**

For information, the full I3C Specification also includes two additional HDR Modes using Ternary encoding:

- *NOT INCLUDED IN I3C BASIC*: HDR Ternary Symbol Pure-bus (HDR-TSP) Mode
- *NOT INCLUDED IN I3C BASIC*: HDR Ternary Symbol Legacy-inclusive-bus (HDR-TSL) Mode

**Note:**

*It is important to note that the I3C Bus is always initialized and configured in SDR Mode, never in any of the HDR Modes. The procedure for entering an HDR Mode from SDR Mode is detailed below. The essential basic I3C specifications are found in **Section 5.1**, including:*

| Subject                                                | Section       |
|--------------------------------------------------------|---------------|
| Bus Configuration                                      | <b>5.1.1</b>  |
| Bus Communication                                      | <b>5.1.2</b>  |
| Bus Conditions                                         | <b>5.1.3</b>  |
| Bus Initialization and Dynamic Address Assignment Mode | <b>5.1.4</b>  |
| Hot-Join Mechanism                                     | <b>5.1.5</b>  |
| In-Band Interrupt                                      | <b>5.1.6</b>  |
| I3C Bus with Multiple Controllers                      | <b>5.1.7</b>  |
| Timing Control                                         | <b>5.1.8</b>  |
| Common Command Codes (CCC)                             | <b>5.1.9</b>  |
| Error Detection and Recovery Methods for SDR           | <b>5.1.10</b> |
| Target Reset                                           | <b>5.1.11</b> |

Details common to all HDR Modes are detailed in this Section and in **Section 5.2.1**.

Details unique to HDR Double Data Rate Mode (HDR-DDR) are specified in **Section 5.2.2**.

Placeholders for the two HDR Ternary Modes that are not included in I3C Basic appear at **Section 5.2.3**.

Details unique to HDR Bulk Transport Mode (HDR-BT) are specified in **Section 5.2.4**.

4328 Each HDR Mode is separate from all other HDR Modes:

- 4329 • I3C Targets may choose to support any desired combination of the HDR Modes included in I3C  
4330 Basic, including no HDR Modes. If the I3C Bus enters an HDR Mode that an I3C Target does not  
4331 support, then that Target can simply wait and watch for the common HDR Exit Pattern.
- 4332 • I3C Controllers may choose to support any desired combination of the HDR Modes included in  
4333 I3C Basic, including no HDR Modes. However, manufacturers are generally encouraged to  
4334 support all of these HDR Modes.
- 4335 • I3C Devices that support HDR-BT may choose to support DUAL Lane or QUAD Lane  
4336 configurations, in addition to SINGLE Lane configuration.

4337 HDR Modes have Bus-wide effect. That is, the whole I3C Bus can be put into a given HDR Mode, and once  
4338 entered that HDR Mode shall remain in effect until the end of that transaction.

4339 HDR Modes may support CCCs as indicated by **Table 61**. Generally, CCCs that assign Dynamic Addresses,  
4340 alter I3C Bus Modes, or transfer the I3C Bus Controller Role are not allowed within HDR Modes.

4341 An HDR Mode period on the I3C Bus involves five steps:

- 4342 1. The Controller Broadcasts an Enter HDR Mode CCC, indicating which particular HDR Mode to  
4343 enter. (See the Command Codes **Enter HDR Mode 0** through **Enter HDR Mode 7** [**ENTHDR0–**  
**ENTHDR7**] in **Section 5.1.9.3.9**).
- 4345 2. The I3C Bus switches from SDR Mode to the requested HDR Mode (see **Section 5.2.1.3.1**).
- 4346 3. The Controller issues the first structured protocol element per the HDR Mode framing.  
4347 Typically this is either a Command or Header, followed by optional Data sent by the Controller or  
4348 Target Device, etc.
- 4349 4. An HDR Restart Pattern or HDR Exit Pattern (see **Section 5.2.1**) is sent.
  - 4350 • If an HDR Restart Pattern, then the Controller issues the first structured protocol element for  
4351 the new HDR Mode transfer (i.e., another Command or Header, followed by optional Data,  
4352 etc.; see **Section 5.2.1.3.2**).

4353 The Controller may repeat this process to remain in the HDR Mode, or send an HDR Exit Pattern  
4354 to exit the HDR Mode.

- 4355 5. If the Controller sends an HDR Exit Pattern, then it is always followed by I3C STOP, which ends  
4356 with the Bus Free Condition.

## 5.2.1 HDR Common Flows and Framing

4357 This Section describes the flows and framings that are common to all HDR Modes.

### 5.2.1.1 HDR Exit Pattern and HDR Restart Pattern

4358 Once an HDR Mode is entered, the HDR Exit Pattern is used to leave it, always exiting back to SDR Mode.  
 4359 The same HDR Exit Pattern is used to exit all HDR Protocols; that Pattern does not appear in any HDR  
 4360 Protocol's normal data or command flow. All I3C Targets shall detect and respond to the HDR Exit Pattern,  
 4361 irrespective of whether the Target supports any particular HDR Mode. The HDR Exit Pattern Detector is  
 4362 specified in *Section 5.2.1.1.3*.

4363 As an alternative to the HDR Exit Pattern, the HDR Restart Pattern is also available. The HDR Restart Pattern  
 4364 allows multiple Messages to be sent while in HDR Mode, without forcing intervening exits to SDR Mode.  
 4365 That is: While the I3C Bus is in a given HDR Mode, an HDR Command can be sent to or from a Target, and  
 4366 then the HDR Restart Pattern can be used to immediately send another HDR Command to or from the Target  
 4367 (or a different Target), without needing to exit the current HDR Mode between the HDR Commands. All I3C  
 4368 Targets shall detect and respond to the HDR Restart Pattern while operating in any HDR Mode that the Target  
 4369 supports. The HDR Restart Pattern Detector is specified in *Section 5.2.1.1.4*. Note that unlike the HDR Exit  
 4370 Pattern, the HDR Restart Pattern is only detected by I3C Targets that support the current HDR Mode.

#### 5.2.1.1.1 HDR Exit Pattern

4371 The HDR Exit Pattern is defined thus:

- SDA starts High, SCL starts Low
- SDA falls (from High to Low) 4 times, while SCL remains Low for the whole time
- Each SDA transition is separated by a time interval of at least  $t_{DIG\_H}$  (see *Section 6.2*)

4375 If necessary, then the HDR Exit Pattern shall be preceded by one additional edge on SCL and/or SDA to set  
 4376 each line up into the correct state (i.e., "Set Up SDA / Set Up SCL").

4377 A normal I3C STOP (i.e., SCL being High while SDA rises) always follows the HDR Exit Pattern, as shown  
 4378 in *Figure 91*.



4379  
4380 **Figure 91 HDR Exit Pattern Followed by STOP**

#### 4381 Note:

4382 After the fourth SDA falling edge, the Controller shall drive SCL High in order to set up SCL to  
 4383 prepare for the I3C STOP.

### 5.2.1.1.2 HDR Restart Pattern

The HDR Restart Pattern is based on a subset of the HDR Exit Pattern. It is defined thus:

- SDA starts High, SCL starts Low (same as HDR Exit Pattern)
- SDA toggles 4 times (fall, rise, fall, rise)
- The next edge is SCL rising. SDA may change with SCL rising, but SCL shall rise.

**Figure 92** illustrates an HDR Restart Pattern (with edges to set SCL and SDA up into correct state) along with the necessary SCL ending edge.



**Figure 92 HDR Restart with Next Edge**

**Note:**

After the necessary SCL ending edge, the I3C Bus remains in that HDR Mode, and the Controller typically follows by driving SCL Low to complete the SCL pulse, which signals the start of the next HDR Mode transfer. This begins the first structured protocol element (i.e., a Command or Header) for the HDR Mode framing, per **Section 5.2.1.3.2**.

### 5.2.1.1.3 HDR Exit Pattern Detector

All I3C Targets shall include an HDR Exit Pattern Detector. The HDR Exit Pattern Detector shall be enabled only after an HDR Mode is entered, and shall be disabled after an HDR Exit pattern is detected. The HDR Exit Pattern Detector may be implemented either in digital logic, or in software (Bit Banged).

The remainder of this Section presents an example digital logic implementation in both schematic view and in RTL code.

The basic logic model is that SCL is held Low (0), and so SCL High (1) will reset the detector. It also only uses falling edges of SDA, hence treats SDA as a clock. The HDR Exit Pattern Detector schematic is shown in *Figure 93*.



**Figure 93 Example HDR Exit Pattern Detector (Schematic)**

The Detector uses an inverted version of SDA as a clock (so positive edge logic, but can use negative edge logic), and is reset when SCL is High (1), or when the block is not in HDR Mode. The asynchronous nature of the reset makes this safe. This is shown in *Figure 94*. If the HDR Exit Pattern Detector were only using clocking logic, then it would not see any change at all (SDA posedge would always see SCL Low in this example). Because the Detector uses an asynchronous reset on SCL, a change in SCL will impact the counter, even in case (b) above. Note that SCL and SDA will still be approximately 50 ns between changes. So, as shown, if SCL rises at any time, then the HDR Exit Pattern Detector shall be reset, and therefore will not mistakenly signal a false Exit.



**Figure 94 Metastable Changes on SCL and SDA Do Not Break the Exit Pattern Detector**

4417 An example RTL implementation of the *Figure 93* schematic is shown in *Listing 1*.

4418 **Listing 1 Example RTL Code for HDR Exit Pattern Generator**

```
4419     wire          scl_rst_n;
4420     wire          SDA_clk_n;      // ~SDA as clock
4421     reg[3:0]      stp_cnt;       // HDR STOP counter (shift chain)
4422
4423     assign scl_rst_n = ~iSCL & iIsInHDR; // SCL=1 resets
4424     // next uses glitch free XOR for SDA clock. Only inverts
4425     // SDA as clock if not in scan. Could add a clock mux
4426     // so uses one common clock in scan.
4427     SAFE_CLK_XOR sda_neg_clk(iSDA, ~scan_mode, SDA_clk_n);
4428
4429     // counter for 3 and 4 rising SDA when SCL is High
4430     // (else SCL resets). Whole thing held in reset if
4431     // not in HDR Mode
4432     always @ (posedge SDA_clk_n or negedge scl_rst_n)
4433         if (~scl_rst_n)
4434             stp_cnt <= 4'd0;           // SCL High or not HDR
4435         else
4436             stp_cnt <= {stp_cnt[2:0], 1'b1}; // shift chain counter
4437
4438     assign oHDR_STOP = stp_cnt[3]; // detects Exit (STOP)
```

### 5.2.1.1.4 HDR Restart and Exit Pattern Detector

Any I3C Target that supports at least one HDR Mode shall include HDR Restart Pattern detection. While this function is easily incorporated into the required HDR Exit Pattern Detector, or may be part of HDR Mode support, the particular design is not mandated by this Specification (i.e., is up to the manufacturer). The HDR Restart Pattern Detector may be implemented either in digital logic or in software (Bit Banged).

The remainder of this Section presents an example digital logic implementation in both schematic view and in RTL code, building upon the HDR Exit Pattern Detector presented in [Section 5.2.1.1.3](#).

The basic logic model is that SCL is held Low (0) and so SCL High (1) will reset the main detector. It also uses falling edges of SDA primarily, hence treats SDA as a clock. The HDR Restart is then detected only when two falling edges have been seen, and verifies the rising edge and then SCL change that is required for an HDR Restart.

The combined HDR Restart and Exit Pattern Detector schematic is shown in [Figure 95](#).



**Figure 95 Combined HDR Restart and Exit Pattern Detector (Schematic)**

This Detector design builds on the HDR Exit Pattern Detector. After exactly two SDA falling edges are seen, followed by a rising edge, the HDR Restart Pattern Detector checks for the rising edge of SCL. It does not matter whether SDA also falls at the same time; the rising SCL is the key. This works because even if SDA were falling (and therefore triggering the next flop in the HDR Exit Pattern Detector), the upper-left flop will still hold 1 because it has not yet seen a rising edge on SDA.

An example RTL implementation of the [Figure 95](#) schematic is shown in [Listing 2](#).

**Listing 2 Example RTL Code for Combined HDR Pattern Detector: Exit and Reset**

```

4458      wire      scl_rst_n;
4459      wire      restart_rst_n;
4460      wire      SDA_clk_n;      // ~SDA as clock
4461      reg[3:0]    stp_cnt;      // HDR STOP counter (shift chain)
4462      reg        poss_restart; // possible restart
4463      reg        is_restart;
4464
4465
4466      assign scl_rst_n      = ~iSCL & iIsInHDR; // SCL=1 resets
4467      assign restart_rst_n = ~iRestartDone & iIsInHDR;
4468
4469      // next uses glitch free XOR for SDA clock. Only inverts
4470      // SDA as clock if not in scan. Could add a clock mux
4471      // so uses one common clock in scan.
4472      SAFE_CLK_XOR sda_neg_clk(iSDA, ~scan_mode, SDA_clk_n);
4473
4474      // counter for 3 and 4 rising SDA when SCL is High
4475      // (else SCL resets). Whole thing held in reset if
4476      // not in HDR Mode
4477      always @ (posedge SDA_clk_n or negedge scl_rst_n)
4478          if (~scl_rst_n)
4479              stp_cnt <= 4'd0;           // SCL High or not HDR
4480          else
4481              stp_cnt <= {stp_cnt[2:0], 1'b1}; // shift chain counter
4482
4483      assign oHDR_STOP = stp_cnt[3];// detects Exit (STOP)
4484
4485      // Possible Restart means exactly 2 falling edges
4486      // of SDA and then rising edge of SDA. Actual
4487      // Restart is from SCL then rising
4488      always @ (posedge iSDA or negedge restart_rst_n)
4489          if (~restart_rst_n)
4490              poss_restart <= 1'b0;     // Restart ACK or not HDR
4491          else if (stp_cnt[1] & ~stp_cnt[2]) // after 2nd fall only
4492              poss_restart <= 1'b1;     // SDA rise after 2 falls
4493          else
4494              poss_restart <= 1'b0;     // else not possible restart
4495
4496      always @ (posedge SCL or negedge restart_rst_n)
4497          if (~restart_rst_n)
4498              is_restart <= 1'b0;       // Restart ACK or not HDR
4499          else if (poss_restart)
4500              is_restart <= 1'b1;       // SCL rises after SDA does
4501          else
4502              is_restart <= 1'b0;       // else not restart

```

**5.2.1.1.5 Compatibility of HDR Pattern Detection and Ternary Modes**

4503 This section is not included in the I3C Basic Specification because I3C Basic does not support the HDR  
 4504 Ternary Modes. To gain access to this capability, please contact MIPI Alliance.

### 5.2.1.2 CCC Framing in HDR Modes

Special framings are used for transmitting Common Command Codes in HDR Modes. CCCs that are supported in any HDR Modes may be sent by an Active Controller, so long as it has entered the HDR Mode using the Enter HDR Mode CCC (see CCCs **Enter HDR Mode 0** through **7**, *Section 5.1.9.3.9*). Both Broadcast and Direct CCCs are supported, with framing details specific to each HDR Mode. As noted in **Table 61**, not all CCCs may be used in HDR Modes. Additionally, support for any CCCs in any particular HDR Mode for a Target is optional. Target Devices may implement support for some or all of the Command Codes that per **Table 61** may be used in HDR Modes, as well as other Command Codes reserved for use by a particular MIPI Alliance Working Group or set aside for Vendor Extensions. Generally, Target Devices may implement support in HDR Modes for a subset of all permitted Command Codes that they might support in SDR Mode.

The Controller shall authoritatively know which Targets are active and support a particular HDR Mode, in order to determine whether a given Target will understand any Broadcast or Direct CCCs sent within an active HDR Mode. The Controller shall also determine which Targets support I3C v1.1 or I3C Basic v1.1.1 or later, and if so, which of them support a CCC within that HDR Mode. The Controller should have *a priori* knowledge, otherwise it may determine this by attempting to receive an acknowledgement of a Direct CCC in a manner specific to the HDR Mode (see *Section 5.2.1.2.3*). For any Targets that do not support a given CCC in that HDR Mode, the Controller may need to re-send that CCC in another supported HDR Mode, or in SDR Mode.

**Table 61** summarizes which CCCs are permitted in HDR Modes, noting any per-HDR-Mode limitations and other advisory information.

4525

**Table 61 CCCs Permitted in HDR Modes, with Notes and Limitations**

| CCC Type  |        | Command Name                                                     | Notes and Limitations                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|--------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Broadcast | Direct |                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| X         | X      | <b>ENECDISEC</b>                                                 | May not generally be useful in HDR Modes, as the Controller would need to exit HDR and return to SDR Mode for the Target to be able to raise any of the request types that are affected by these CCCs; see <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                             |
| X         | X      | <b>ENTAS0</b><br><b>ENTAS1</b><br><b>ENTAS2</b><br><b>ENTAS3</b> | See <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                                                                                                                                                                                                                                    |
| X         | -      | <b>DEFTGTS</b>                                                   | Not recommended for use in HDR Modes; generally only used for Secondary Controllers, to announce lists of known Targets, following changes to Target Dynamic Addresses or Hot-Join events, neither of which are permitted within HDR Modes                                                                                                                                                                                        |
| X         | X      | <b>SETMWL</b><br><b>SETMRL</b>                                   | See <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | <b>GETMWL</b><br><b>GETMRL</b>                                   | No limitations                                                                                                                                                                                                                                                                                                                                                                                                                    |
| X         | -      | <b>SETBUSCON</b>                                                 | Not recommended for use in HDR Modes                                                                                                                                                                                                                                                                                                                                                                                              |
| X         | X      | <b>ENDXFER</b>                                                   | Not recommended for use in HDR Modes                                                                                                                                                                                                                                                                                                                                                                                              |
| X         | X      | <b>SETXTIME</b>                                                  | No limitations                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | <b>GETXTIME</b>                                                  | No limitations                                                                                                                                                                                                                                                                                                                                                                                                                    |
| X         | X      | <b>RSTACT</b>                                                    | Not recommended for use in HDR Modes                                                                                                                                                                                                                                                                                                                                                                                              |
| -         | X      | <b>SETGRPA</b>                                                   | Target support for Group Addresses may vary; Target support for receiving HDR CCCs directed to Group Addresses may vary; see <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                                                                                                           |
| X         | -      | <b>DEFGRPA</b>                                                   | Generally only used for Secondary Controllers, to announce lists of Targets assigned to a known Group Address after prior use of <b>SETGRPA</b> and <b>RSTGRPA</b> CCCs                                                                                                                                                                                                                                                           |
| X         | X      | <b>RSTGRPA</b>                                                   | See <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                                                                                                                                                                                                                                    |
| X         | X      | <b>MLANE</b>                                                     | Broadcast or Direct SET versions of this CCC are generally not recommended for use in HDR Modes; Targets that support Direct GET versions of this CCC shall respond according to the HDR Mode framing for the active HDR Mode, instead of the "test mode" which returns the same data on any Additional Data Lanes (as defined in SDR Mode, see <b>Figure 86</b> ); see <b>Section 5.2.1.2.4</b> . and <b>Section 5.2.1.2.5</b> . |
| -         | X      | <b>GETBCR</b><br><b>GETDCR</b>                                   | Not recommended for use in HDR Modes; usually only used once per Target, during Bus Initialization                                                                                                                                                                                                                                                                                                                                |
| -         | X      | <b>GETSTATUS</b>                                                 | No limitations                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | <b>SETBRGTGT</b>                                                 | See <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | <b>GETMXDS</b>                                                   | No limitations                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | <b>GETCAPS</b>                                                   | No limitations                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | <b>SETROUTE</b>                                                  | See <b>Section 5.2.1.2.4</b> .                                                                                                                                                                                                                                                                                                                                                                                                    |
| -         | X      | D2DXFER                                                          | This CCC is not included in I3C Basic (see <b>Table 16</b> )                                                                                                                                                                                                                                                                                                                                                                      |

4526 **Table 62** summarizes which CCCs are not permitted in any HDR Mode, with the reason for each CCC.

4527

**Table 62 CCCs Not Permitted in HDR Modes**

| CCC Type  |        | Command Name                          | Reason                                                                                                                                                                                                                                          |
|-----------|--------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Broadcast | Direct |                                       |                                                                                                                                                                                                                                                 |
| X         | X      | <b>RSTDAA</b>                         | Target Dynamic Address changes are a fundamental configuration change, which should be done in SDR Mode only.                                                                                                                                   |
| X         | —      | <b>ENTDAA</b>                         | Dynamic Address Assignment can only be performed in SDR Mode.                                                                                                                                                                                   |
| X         | —      | <b>ENTTM</b>                          | Test Mode can only be performed in SDR Mode. Test Mode is generally only used for manufacturing or Device test.                                                                                                                                 |
| X         | —      | <b>ENTHDR0</b> through <b>ENTHDR7</b> | HDR Modes can only be entered from SDR Mode. There is no provision for switching directly to a different HDR Mode, it is necessary to exit to SDR Mode first.                                                                                   |
| X         | —      | <b>SETAASA</b>                        | Dynamic Address Assignment can be done in SDR Mode only. In addition, SETAASA (if supported) is typically used only once per Bus, during Bus Initialization which always takes place in SDR Mode.                                               |
| —         | X      | <b>SETDASA</b>                        | Dynamic Address Assignment can be done in SDR Mode only. In addition, SETDASA (if supported) is typically used only once per Target, during Bus Initialization which always takes place in SDR Mode.                                            |
| —         | X      | <b>SETNEWDA</b>                       | Target Dynamic Address changes are a fundamental configuration change, which should be done in SDR Mode only.                                                                                                                                   |
| —         | X      | <b>GETPID</b>                         | Usually only associated with the <b>ENTDAA</b> CCC, or when a Secondary Controller that was not present during Bus Initialization becomes Active Controller (pursuant to a <b>GETACCCR</b> CCC) and requests information about a Target Device. |
| —         | X      | <b>GETACCCR</b>                       | The Controller Handoff procedure is only supported in SDR Mode.                                                                                                                                                                                 |

### 5.2.1.2.1 Elements, Framing and Modality

Within each HDR Mode, the framing for CCC flows differs from other HDR read/write transactions, providing a modality similar to the way CCCs are framed in SDR Mode.

This Specification defines a number of common Flow Elements (such as Word and Blocks) that together provide a generic framing model that can be used to describe the CCC flows for each individual HDR Mode.

The following Flow Elements are defined, where 'x' represents an HDR Mode:

- **HDR-x CCC Header Block**

This Block has two variants:

- Type Indicator
- Type Selector

- **HDR-x Header Block**

This Block signals the end of a CCC Frame for the particular HDR Mode. It is neither an Indicator nor a Selector.

- **HDR-x CCC Data Block**

This Block has three variants:

- When sent by the Controller as part of a Broadcast CCC flow
- When sent by the Controller as part of a Direct Write or Direct SET CCC flow (i.e., in a Write Segment)
- When sent by an addressed Target as part of a Direct Read or Direct GET CCC flow (i.e., in a Read Segment)

- **HDR-x CCC Termination Marker**

This marker is sent only as needed, i.e., is optional per the particular HDR Mode and per the position in a type of CCC flow.

All of the above Flow Elements are common CCC Flow Elements, except the Write Segment and Read Segment variants of HDR-x CCC Data Block, and specific variants of the termination marker (optional). All Target Devices that support CCCs in an HDR Mode must be able to successfully receive and understand these common CCC Flow Elements, in order to track their place within the CCC flows, to know when to enter the modality (and to know when it has been ended), and to understand when they are being specifically addressed in a Direct CCC flow.

The beginning of a CCC in an HDR Mode is indicated by use of an HDR-x CCC Header Block of type Indicator. This is an HDR-x Header Block containing a special byte value (i.e., the Broadcast Address, 7'h7E) instead of a Target Address. This is different from the beginning of other HDR transactions.

The format of the Indicator HDR-x CCC Header Block is specified separately for each HDR Mode, but generally includes the Indicator, the Command Code, and the optional Defining Byte. If the HDR-x CCC Header Block includes a bitfield for the Defining Byte that is always present, then for CCCs that support an optional Defining Byte, a Defining Byte value of 8'h0 shall be equivalent to omitting the Defining Byte. This shall have the same effect as omitting the optional Defining Byte in SDR Mode for the same CCC.

**For Broadcast CCCs**, the Controller shall send the HDR-x CCC Header Block of type 'Indicator', containing the Command Code and optional Defining Byte, followed by one or more HDR-x CCC Data Blocks, containing the data bytes to be Broadcast to all supported Target Devices.

4567     **For Direct CCCs**, the Controller shall send the HDR-x CCC Header Block of type ‘Indicator’, containing the  
4568     Command Code and optional Defining Byte. The Controller shall then send the HDR Restart Pattern, and  
4569     then start a new Segment by sending another HDR-x CCC Header Block, but of Selector type: it includes a  
4570     Target Address and indicates whether the Direct CCC Segment is a Write Segment vs. a Read Segment.

- 4571     • For a Direct Write or Direct SET CCC with data, the Controller generally sends one or more  
4572        HDR-x CCC Data Blocks if the selected CCC’s defined format so indicates. However, if the  
4573        CCC’s defined format includes no data to be sent to the Target (i.e., if a zero-byte ‘Write’ to the  
4574        Target for a given Command Code and optional Defining Byte is sufficient to instruct the Target to  
4575        take some action), then the Controller would send the minimum number of HDR-x CCC Data  
4576        Blocks for the HDR Mode’s framing. In some cases, this might be zero Data Blocks, if the HDR  
4577        Mode permits.
  - 4578            • If the Direct Write or Direct SET CCC requires a Sub-Command Byte, then the Controller  
4579                shall send this Sub-Command Byte as the first byte in the Write Segment’s data message,  
4580                which is the first HDR-x CCC Data Block.
- 4581     • For a Direct Read or Direct GET CCC, the Controller shall allow the addressed Target to control  
4582        the Bus, and the Target may send one or more HDR-x CCC Data Blocks if the selected CCC’s  
4583        defined format so indicates. After the end of the Segment, the Controller shall resume control.

4584     **For either Broadcast or Direct CCCs**, the Controller and the Targets shall observe all HDR Mode specific  
4585     framing requirements:

- 4586     • For zero-byte CCCs or very short CCCs, if a minimum number of HDR-x CCC Data Blocks must  
4587        be sent for the HDR Mode’s framing, then the sender shall provide dummy byte values of 0x00 in  
4588        these Data Blocks, and the receiver shall correctly ignore these values, per the specific CCC  
4589        definition.
- 4590     • If the length of a CCC’s data message is not evenly aligned to the size of the HDR-x CCC Data  
4591        Block, then the sender shall pad the end of the data message with dummy byte values of 0x00, and  
4592        the receiver shall correctly ignore any dummy byte values, per the specific CCC definition.

4593     To end either a Broadcast CCC or a Direct CCC, the Controller shall use any HDR-x CCC End Procedure  
4594     that is valid for that HDR Mode.

4595     As part of the data message that is either sent by the Controller (i.e., as part of a Broadcast CCC or a Write  
4596     Segment for a Direct CCC), or sent by a Target (i.e., as part of a Read Segment for a Direct CCC), the sender  
4597     shall denote the end of the data message by including an appropriately-constructed HDR-x CCC Termination  
4598     Marker, in a format specific for the particular HDR Mode and transaction type. The Controller shall also  
4599     include a Termination Marker at the end of the Selector type HDR-x CCC Header Block that begins the  
4600     framing for a Direct CCC, before starting any Read or Write Segments. In both cases, this Termination Marker  
4601     is required to allow the receiver to properly understand the end of the header block or data message and take  
4602     the appropriate action to fit within the signaling for that HDR Mode.

4603     Because a Termination Marker can also serve as the transition before the next common CCC Flow Element,  
4604     it may include signaling acknowledging the preceding Flow Element, or signaling that includes Bus  
4605     Turnaround or other forms of Handoff between the Controller and an addressed Target.

4606 Depending on the specific HDR Mode and transaction type, this Termination Marker will take one of three  
4607 possible forms:

4608 1. **CRC Block**

4609 This Block includes valid CRC (checksum) data for the preceding HDR-x CCC Data Block(s) or  
4610 HDR-x CCC Header Block. The receiver shall use the CRC data to verify that the data received  
4611 from the sender is valid.

- 4612 • For HDR-DDR Mode: The CRC Block is the HDR-DDR CRC Word (see *Section 5.2.2.1, Table 66*).
- 4613 • For HDR-BT Mode: The CRC Block is the HDR-BT CRC Block (see *Section 5.2.4.3.3*).

4615 2. **Turnaround or Handoff Pattern**

4616 This form of Termination Marker is a specific pattern indicating Bus Turnaround or Handoff back  
4617 to the Controller, if so indicated by the direction of transfer.

4618 3. **No Termination Marker**

4619 Under particular conditions, no Termination Marker *per se* will be sent.

4620 After this optional Termination Marker, the Controller shall reassert its control of the Bus (if necessary) and  
4621 then send (or complete) the HDR Restart Pattern, or else continue on to any valid HDR-x CCC End Procedure  
4622 that is appropriate for that framing.

4623 Because the Termination Marker may take different forms, or may not exist on the I3C Bus at all depending  
4624 on the particular HDR Mode or type of transaction, it is indicated generically in the following flow diagrams,  
4625 using the label 'TM'.

4626 At several points in the CCC flows it might be necessary for the Target to acknowledge receipt of a given  
4627 Flow Element. In the following flow diagrams, such an acknowledgement may also serve as a Termination  
4628 Marker; the label 'ACK' indicates such cases.

4629 **Note:**

4630 *The exact location of an acknowledgement may vary, depending on the particular HDR Mode and the*  
4631 *flow control method used to indicate acknowledgement.*

4632 The framing for Direct CCCs also allows for multiple Target Addresses to be addressed, in a manner similar  
4633 to the SDR Direct CCC framing model which addresses multiple Target Addresses as combinations of Read  
4634 Segments (for Direct Read or Direct GET CCCs) and/or Write Segments (for Direct Write or Direct SET  
4635 CCCs). The Controller may use this framing to address one or more Target Addresses by using multiple  
4636 Segments, separated by the HDR Restart Pattern. When used in this manner the HDR Restart Pattern acts not  
4637 as the end of the CCC (as it does with other, HDR traffic), but as the end of one Segment addressed to the  
4638 indicated Target Address.

4639 **Note:**

4640 *In this framing the HDR Restart Pattern serves as an equivalent of SDR Mode's Repeated START in*  
4641 *Direct CCC framing (see **Section 5.1.9.2.2**).*

4642 Target Devices shall store the Command Code and its optional Defining Byte (as the Controller sent in the  
4643 Indicator type HDR-x CCC Header Block) and act on them as individually addressed in this framing. The  
4644 Command Code and optional Defining Byte values shall be stored for later use, if a Target matches its Target  
4645 Address in a subsequent Selector type HDR-x CCC Header Block, until the end of the current modality is  
4646 indicated via any HDR-x CCC End Procedure valid for the particular HDR Mode.

4647 The generic Broadcast CCC flow for the framings described above is shown in **Figure 96**; the generic Direct CCC flow for the framings described above is shown in **Figure 97**.

4648



**Figure 96 Begin Broadcast CCC Per HDR Mode**

4649

4650



Figure 97 Begin Direct CCC Per HDR Mode

The ending of the CCC modality shall be indicated by any HDR-x CCC End Procedure valid for the particular HDR Mode. The HDR Restart Pattern alone shall not indicate the end of the CCC flow, as it would end a normal HDR read/write command flow. All Target Devices that support CCCs in the particular HDR Mode shall detect the beginning of the CCC and interpret the HDR Restart Pattern appropriately for the CCC framing until they receive an HDR-x CCC End Procedure valid for that HDR Mode. Each HDR Mode may define several HDR-x CCC End Procedures, depending on the HDR Mode's use cases and Frame formats.

Upon receiving a valid HDR-x CCC End Procedure, the Target shall either end the CCC modality and expect normal HDR traffic, or else immediately re-enter the CCC modality (depending on the type of procedure) by capturing a new Command Code and optional Defining Byte. Typically, a valid HDR-x CCC End Procedure starts with a common Flow Element, such as an Indicator type HDR-x CCC Header Block (or equivalent) to start a new CCC, or an HDR-x Header Block to end the CCC Frame. Such a Block shall be addressed to the Broadcast Address (7'h7E) and shall also indicate whether the modality is ended vs. re-entered for a new CCC. In this manner the Controller can use normal HDR traffic, Broadcast CCCs, and Direct CCCs in a continuous flow within a given HDR Mode, arranged in any sequential order, without needing to exit the HDR Mode to separate these commands or traffic flows.

**Note:**

A valid HDR-x CCC End Procedure for a particular HDR Mode that indicates the end of the CCC modality might use the dummy command code 0x1F (see [Table 16](#)) instead of a valid CCC, if the framing for that HDR Mode requires the Controller to use an additional Flow Element that would otherwise contain the CCC in order to comply with valid transfers in that HDR Mode. This dummy command code 0x1F is defined for this specific purpose. When using the dummy command code 0x1F, a dummy Defining Byte value 0x00 should also be used, if the additional Flow Element also has a field that would otherwise contain a valid Defining Byte.

The following HDR-x CCC End Procedures are recommended, but this is not an exhaustive list of End Procedures for any given HDR Mode:

- **HDR Restart Pattern followed by Indicator type HDR-x CCC Header Block** (or equivalent), indicating that the CCC modality is still active, but providing a new CCC and optional Defining Byte. Flow then proceeds as a new Broadcast or Direct CCC (see [Figure 96](#) and [Figure 97](#)).
- **HDR Restart Pattern followed by HDR-x Header Block** (or equivalent) indicating that the CCC modality is ended or no longer in ‘continuation’, followed by an optional Termination Marker to indicate the end of a transfer, followed by another HDR Restart Pattern (see [Figure 101](#)). Flow then proceeds as standard HDR read/write transactions.
  - Any End Procedure that indicates that the CCC modality is ended must be distinct from the previous End Procedure, in order that all Target Devices may clearly recognize it and interpret subsequent HDR transactions as standard HDR read/write transactions. Typically, this requires its first Flow Element (i.e., the HDR-x Header Block) to be clearly recognized as neither an Indicator nor a Selector.
- An **optional variant** of the above, which ends with the HDR Exit Pattern instead of the HDR Restart Pattern. HDR Mode is then exited, and the Bus returns to SDR Mode.
- **HDR Exit Pattern**

The recommended HDR-x CCC End Procedures are shown in [Figure 98](#).

**Figure 98 End of CCC Procedures Per HDR Mode**

4696 In the figures above, the labels HDR-x CCC Header Block, HDR-x CCC Data Block, and Termination  
4697 Marker (if supported) represent generic, higher-level elements of the flow for sending CCCs in all of the  
4698 HDR Modes. In actual practice the specific sizes of the Blocks, their bitfield formats, and data encodings on  
4699 the Bus vary depending on the particular HDR Mode being used. **Table 63** shows, for each HDR Mode that  
4700 supports CCCs, where to find the CCC coding details for each Flow Element when using that HDR Mode.

4701

**Table 63 HDR CCC Details Per HDR Mode**

| HDR Mode | See Section  | CCC Coding Details Section | Begin Broadcast CCC | Begin Direct CCC  | CCC End Procedures |
|----------|--------------|----------------------------|---------------------|-------------------|--------------------|
| HDR-DDR  | <b>5.2.2</b> | <b>5.2.2.2.1</b>           | <b>Figure 108</b>   | <b>Figure 109</b> | <b>Figure 110</b>  |
| HDR-BT   | <b>5.2.4</b> | <b>5.2.4.4</b>             | <b>Figure 124</b>   | <b>Figure 125</b> | <b>Figure 126</b>  |

### 5.2.1.2.2 Broadcast Address ACK

When addressing all Targets using Broadcast CCCs, or when starting the Direct CCC flow, the Controller shall send an Indicator type HDR-x CCC Header Block to signal that it is trying to write to all Targets. This Indicator block shall include the Broadcast Address (7'h7E) and will generally take the form of a Write command for that HDR Mode.

Each Target Device that supports CCC flows in that HDR Mode and receives an Indicator block shall use a valid HDR Flow Control method for that HDR Mode to acknowledge the Indicator block. This acknowledgement indicates that it has received the Indicator block, has acknowledged the beginning of the Broadcast CCC or Direct CCC (i.e., has entered the modality), and is ready to participate. The Target shall acknowledge even if it decides not to act on (or even if it does not support) the particular CCC or its optional Defining Byte.

**Note:**

*Acknowledging the Indicator block is equivalent to SDR Mode CCC Framing, where all Targets must acknowledge the Broadcast Address at the beginning of a CCC.*

*For Direct CCC flows, acknowledgement of the Indicator block serves the important function of ensuring that the Target Device agrees to capture the Command Code and optional Defining Byte, and is ready to be addressed by any subsequent Selector blocks in this Direct CCC flow. By acknowledging the Indicator block, the Target signals that will capture these values into its internal state and use them to decide whether to respond to that particular Command Code and optional Defining Byte, if it matches its Target Address in a subsequent Selector block that begins a Read or Write Segment. In this case, the Target is considered to be ‘primed’ with the captured values, and capable of making a rapid ACK/NACK decision at the correct point in the flow.*

*If one such Target on the Bus is unable to respond and does not acknowledge the Indicator block, then this is equivalent to a NACK of the Broadcast Address in the Indicator block, for that HDR Mode. However, if other Targets on the Bus are present and are able to acknowledge the Indicator block, then one Target’s failure to acknowledge the Indicator block must not block the CCC flow from continuing. This typically requires the HDR Mode to define a common flow control method that can be used by multiple Targets (e.g., passive NACK, active ACK) for a Write command. If this flow control method is not enabled by default, then the Controller must enable it for the Bus, as appropriate for the HDR Mode, before sending any CCCs in that HDR Mode.*

The Controller shall use this acknowledgement to ensure that the CCC flow is being received by at least one Target in that HDR Mode. If the Controller does not receive acknowledgement from at least one Target, then it should initiate an error recovery procedure, which might include exiting HDR Mode and attempting to re-send the CCC in SDR Mode.

**Note:**

*If a Bus has multiple Target Devices that support CCC flows in that HDR Mode, then they shall all acknowledge the Indicator block together.*

In **Figure 96** and **Figure 97**, the location for acknowledgement is shown after the Indicator type HDR-x CCC Header Block. The specific location and method for the Target to indicate its acknowledgment of the Indicator block is specific to the particular HDR Mode, but generally includes some active state change that is driven by the Target, and that can be measured by the Controller.

### 5.2.1.2.3 Direct CCC ACK/NACK and Retry

When addressing specific Targets using Direct CCCs in HDR Modes, the Controller shall indicate whether it is trying to read from the Target (i.e., a Direct Read or Direct GET) or write to the Target (i.e., a Direct Write or Direct SET). The Target Device may use a valid HDR Flow Control method to indicate that it cannot respond to a read request, or decline a write request at any point, in a manner equivalent to SDR Mode CCC Framing where it would NACK its own Target Address for a Direct CCC (see [Section 5.1.9.2.2](#)).

In [Figure 97](#), the acknowledgement is shown after the Selector type HDR-x CCC Header Block for a Read Segment and a Write Segment. The specific location and method for the Target to indicate its part in the acknowledgment of the Selector block and agreement to respond to the Direct CCC with optional Defining Byte is specific to the particular HDR Mode, but generally includes some active state change that is driven by the Target, and that can be measured by the Controller.

Note that [Figure 97](#) illustrates an example HDR Direct SET/GET CCC. However, this flow can also be applied to a Direct SET or a Direct GET, as the Read Segments and Write Segments are optional and can appear in any order as defined for the particular CCC. Some CCCs might not have any Write or Read Segments, and in some cases the HDR-x CCC Data Block might be omitted if the CCC doesn't define any data to write to or read from a Target. Multiple Segments may address the same Target, or different Targets.

If a Target is not able to respond to a Direct GET CCC immediately on the first attempt by the Controller, then it may use a method specific to the chosen HDR Mode to decline to respond, similar to a NACK of its own Target Address in SDR Mode. The Controller shall follow the same Direct GET CCC Retry model used in SDR Mode (see [Section 5.1.9.2.3](#)), and the Target should generally respond on the second attempt.

A Target indicating a delayed response on the first attempt is not the same as a Target choosing to NACK its own Target Address to indicate that it does not support a given CCC and Defining Byte. As with SDR Mode, in this case the Controller would make a second attempt, and the Target would also decline to respond on the second attempt.

However, if a Target declines to respond to another type of Direct CCC (i.e., not a Direct GET CCC) on the first attempt, then it might not support the given CCC and Defining Byte, in which case the Retry model would not necessarily apply.

The Controller may also address Groups using Direct Write or Direct SET CCCs, if supported by the particular Direct CCC; other special conditions shall apply, per [Section 5.2.1.2.6](#).

#### 5.2.1.2.4 Implications for Device and Bus Configuration

While it is not always recommended to use CCCs in HDR Modes that might change Bus configuration or Device configuration, this might be permitted if the Active Controller follows certain safety recommendations, and if the Target Devices obey a set of conventions per their optional support for these CCCs in HDR Modes.

- **For Direct SET CCCs that change a Device's configuration**, a Target receiving that CCC shall verify such configuration changes after successfully receiving all data sent by the Controller (as indicated by a Termination Marker or other command coding elements specific to that HDR Mode) and then apply the configuration change immediately, at the end of the Frame for that Target.
- **For Broadcast CCCs that change Bus Configuration or Device Configuration for all valid Devices**, all Targets receiving that CCC shall verify such configuration changes after successfully receiving all data sent by the Controller (as indicated by a Termination Marker or other command coding elements specific to that HDR Mode) and then apply the configuration change immediately.

It should also be clear that any Broadcast CCCs that announce updated Bus configuration data (e.g., DEFTGTS and DEFGRPA) while in HDR Mode will not be received by Target Devices that do not support that particular HDR Mode. In most circumstances, a Controller-capable Device should generally expect to use these CCCs in SDR Mode, unless it knows with certainty that all other Devices that need to receive this Bus configuration data (i.e., all Secondary Controllers) also support the same HDR Mode and support receiving these Broadcast CCCs in that HDR Mode. It is the Active Controller's responsibility to ensure that all Secondary Controllers support the same HDR Mode before using these Broadcast CCCs in HDR Mode.

Since custom CCCs can be defined by various MIPI Alliance WGs or Vendors for special purposes, some of these CCCs may also change additional aspects of Bus configuration or Device configuration, in order to enable as-yet-undefined use cases or features not yet covered by this Specification.

**Note:**

*Groups that create their own CCCs (including MIPI Alliance WGs, outside standards groups, and Vendors) may choose to define custom CCCs in any supported HDR Mode, and so should be aware of the recommendations above when choosing whether to do so, and how to apply any configuration changes based on data received from the Active Controller in HDR Mode.*

#### 5.2.1.2.5 Implications for Multi-Lane

For I3C Buses that support Multi-Lane (ML) functionality (see [Section 5.3](#)), the Controller may configure any ML-compatible Target Devices to use additional data Lanes to increase data transfer rates, in a supported HDR Mode that supports multiple ML Frame formats using these additional data Lanes.

**Note:**

*For I3C Basic, HDR-BT is the only HDR Mode that supports Multi-Lane (ML) functionality.*

However, if some Target Devices that support this HDR Mode do not support the same ML Frame formats (i.e., if there is varying support for the number of additional data Lanes, or for alternate Data Transfer Codings with different ML Frame formatting), then compatibility issues can arise as these Target Devices would not be able to correctly receive and understand all the common CCC Flow Elements the Controller transmits. The same issues can arise if any of the Target Devices are configured to use ML Frame formats that are not mutually interoperable with the rest of the Target Devices, even if all Target Devices support such ML Frame formats.

If a Controller chooses to use any ML Frame formats that use additional data Lanes and change the formatting of common CCC Flow Elements, then the Controller must ensure that all Target Devices can support (and are configured to use) mutually interoperable ML Frame formats before attempting to drive any CCC flows using such an ML Frame format.

In general, all supported HDR Modes include a 1-Lane compatibility mode that is supported by all Multi-Lane capable Target Devices in their default configuration for that HDR Mode, as well as all Target Devices

4816 that only connect to one Lane. To ensure maximum compatibility, a Controller should generally use 1-Lane  
4817 compatible ML Frame formats for the common CCC Flow Elements, so that all Target Devices can properly  
4818 receive and understand the CCC flows. This includes all HDR-x CCC Header Blocks, and any HDR-x CCC  
4819 Data Blocks that are part of Broadcast CCC flows.

4820 For such a Bus, if a Controller has previously configured some Target Devices to use an ML Frame format  
4821 that uses additional data Lanes or different formatting, then the Controller must use a “compatibility mode”  
4822 ML Frame format that uses the 1-Lane compatible Frame formatting to transmit all common CCC Flow  
4823 Elements, and such Target Devices shall use the 1-Lane compatible Frame formatting to receive the common  
4824 CCC Flow Elements. However, different formatting that uses additional data Lanes shall be used for per-  
4825 Target transactions involving such Target Devices (if previously configured to do so) for the HDR-x CCC  
4826 Data Blocks within the Read Segments or Write Segments of Direct CCC flows.

4827 Alternately, a Controller may configure all Target Devices to use an “alternate mode” Coding that uses  
4828 additional data Lanes or different formatting, in order to increase the performance or efficiency of HDR CCC  
4829 flows. Such an “alternate mode” Coding might intentionally be incompatible with the “compatibility mode”  
4830 Coding for this HDR Mode, but it should not be used unless all Target Devices support it. The Controller  
4831 must ensure that all Target Devices are configured to use a mutually interoperable “alternate mode” Coding,  
4832 and the rules for the “alternate mode” Coding shall apply.

4833 The specifics of Multi-Lane support for each HDR Mode are listed in the Framing details (see **Table 63**).  
4834 Each section describing a specific HDR Mode lists the Flow Elements that may utilize Multi-Lane Frame  
4835 formatting, while maintaining compatibility with all other Target Devices that might not be configured to use  
4836 ML Frame formats. The ML Frame formats that are mutually interoperable are also defined in this  
4837 specification.

4838 Since the Controller has the responsibility for configuring Multi-Lane for the Bus and all compatible Target  
4839 Devices as well as initiating the CCC flow, it shall conform to these requirements, and shall ensure that all  
4840 configuration is successfully completed. Likewise, the Controller must ensure that any core CCC Flow  
4841 Elements that must be received and understood by all Target Devices supporting that HDR Mode are sent in  
4842 an appropriate ML Frame format, as defined in the ML Frame formats that have been configured for all Target  
4843 Devices, and that all Target Devices are configured to be mutually interoperable with respect to these core  
4844 CCC Flow Elements. Likewise, all Target Devices shall also correctly receive and understand the Indicator  
4845 and Selector blocks of the CCC flow in that ML Frame format, even if they have been otherwise configured  
4846 to use an ML Frame format that uses additional Lanes or a different ML Frame format for standard (i.e., non-  
4847 CCC) HDR transactions.

4848 Use of the MLANE CCC within an HDR Mode should be managed carefully, since the Direct SET forms of  
4849 this CCC provide the unique ability to change a Target Device’s ML Frame format, and that directly impacts  
4850 a Target’s ability to receive and understand an HDR-x CCC Data Block sent by a Controller, and also impacts  
4851 a Target’s ability to respond on the data Lanes in a format that the Controller expects it to utilize for a given  
4852 ML Frame format. As such, any misunderstanding or mismatch of expectations between a Controller and a  
4853 Target may result in communication errors, which would require the Controller to catch any resulting errors  
4854 and initiate a recovery procedure to restore communications.

4855 In some situations, this may require temporarily resetting a Target’s ML Frame format using the MLANE  
4856 CCC (see **Section 5.1.9.3.30**) with Defining Byte value 0x7F (see **Table 56**). The forthcoming Application  
4857 Notes for I3C v1.1.1 /MIPI07/ is expected to include a more detailed recovery procedure which might require  
4858 exiting HDR Mode if the Target fails to respond to this CCC with Defining Byte value 0x7F while in HDR  
4859 Mode. To avoid these issues, it is strongly recommended to not use the Direct SET forms of this CCC within  
4860 any HDR Mode, unless the Controller is able to ensure that all possible communication errors can be reliably  
4861 detected and resolved.

### 5.2.1.2.6 Implications for Group Addressing

For I3C Target Devices that support Group Addresses, the Controller may choose to configure a Group Address and address multiple Targets in a Direct Write or Direct SET CCC form of any supported CCC within the HDR CCC flows, in a manner similar to Group Address support in Direct CCC flows within SDR Mode. In this manner, Group Addresses may be used in place of Dynamic (Target) Addresses in the common CCC Flow Elements (i.e., the Selector type HDR-x CCC Header Blocks for Direct CCC Write Segments), as long as the following conditions are met:

- The Selector Block must indicate a Direct CCC Write Segment, since per *Section 5.1.4.4* a Group Address shall only be used for Write transfers in HDR Modes.
- All Targets that have been assigned to that Group Address using the SETGRPA CCC (see *Section 5.1.9.3.27*) must support CCC flows within that HDR Mode.
- All Targets in that Group shall ACK the Group Address when addressed by the Selector block for the Write Segment.
- If any Target in that Group is not able to respond to the Write Segment directed to the Group Address, then its failure to ACK the Group Address must not block the Write Segment from continuing, if the Controller detects that at least one other Target in that Group responds with an ACK.

This typically requires the HDR Mode to define a common flow control method that must be enabled by the Controller before sending any CCCs to a Group Address (see *Section 5.2.1.2.2* and *Section 5.2.1.2.3*).

For Bus configurations where Group Addressing is used in conjunction with Multi-Lane, the Controller shall ensure that all Targets that have been assigned to the same Group Address are configured to use mutually interoperable Data Transfer Codings, and have been configured to use the same ML Frame format (i.e., the same Data Transfer Coding and number of additional Lanes) for transfers addressed to that Group Address. The Controller must verify this before attempting to send a Direct Write or Direct SET CCC to a Group Address in a Bus configured for Multi-Lane with HDR CCC flows.

- If not all Targets in a Group are configured to use the same ML Frame format in a particular HDR Mode, then the Controller must configure such Targets to use a common ML Frame format that they all support. In some cases, this might mean using a 1-Lane compatible ML Frame format to send a Direct Write or Direct SET CCC to a Group Address.

If a Target Device supports multiple current ML configurations for its assigned Group Addresses (per *Section 5.3.1.1.1*), then:

- Within the CCC flows in HDR Modes, such a Target shall use the Address in the Selector Block to determine which ML configuration to use, as it prepares to send or receive data in that Direct CCC Segment. If the Address matches a currently assigned Group Address, then it shall use the correct ML configuration for that Group Address instead of the ML configuration for its Dynamic Address.
- After assigning such a Target Device to any Group Address, that Target shall have an independent ML configuration associated with that Group Address, and the Controller might need to re-configure the Target's ML configuration for CCCs directed to that Group Address (as a specific example of ML configuration requirements listed in *Section 5.3.1.1.1*).
  - Such configuration changes shall not affect the ML configuration for the Target's Dynamic Address(es), and the Controller may continue sending Direct CCCs to a Target's Dynamic Address(es) using the previously configured ML Frame format for that Dynamic Address.

**Note:**

The Target shall use the ML configuration (i.e., the currently configured ML Frame format) for its Dynamic Address in order to properly receive all common CCC Flow Elements as defined in **Section 5.2.1.2.1**. This includes any HDR-x transfers that are addressed to the Broadcast Address, which generally include the Indicator type HDR-x CCC Header Block as well as various HDR-x CCC End Procedures that are defined for that HDR Mode. Such common CCC Flow Elements must be sent by the Controller in a form that all Target Devices supporting that HDR Mode are configured to understand and properly receive, in a mutually interoperable manner; and each such Target Device shall respond according to such configuration, according to the current ML Frame format for that HDR Mode.

The requirements in this section are a specific application of other normative requirements in this Specification (e.g., **Section 5.1.4.4**, **Section 5.1.9.3.30**, and **Section 5.3.1.1.1**). Such other sections also include other requirements, restrictions, and recommendations for Target Devices, as well as the Active Controller of the Bus. As the requirements in this section are intended for a specific use case of HDR transfers as applied to CCC flows in HDR Modes, readers are warned not to interpret this section as contradictory to any such requirements or restrictions in such other sections that govern all Multi-Lane configuration and all HDR transfers (including HDR transfers sent to Group Addresses).

### 5.2.1.2.7 Bus Efficiency

It should be expected that remaining within a given HDR Mode is more efficient for specific, traffic-intensive use cases, and that using CCCs while in HDR Mode will help maintain this efficiency by avoiding the need for the Controller to exit HDR Mode in order to send a CCC (as with SDR Mode). It is also likely that CCC data can be sent more quickly, by taking advantage of the increased data rates of the HDR Modes and Multi-Lane functionality (if supported and configured).

However, depending on the Bus Configuration and its application and use cases, the Controller might occasionally need to exit HDR Mode, in order to provide a window for Target Devices to request In-Band Interrupts, the Controller Role, or Hot-Joins as may be required per the Bus Configuration and its application and use cases.

### 5.2.1.3 Transition to HDR Mode Transfer

The Controller is responsible for starting the HDR Mode transfer, which consists of sending the first structured protocol element, per the HDR Mode framing. The Controller shall do this after entering the HDR Mode for the first transfer in that HDR Mode (see *Section 5.2.1.3.1*), or after the HDR Restart Pattern for subsequent transfers in that same HDR Mode (see *Section 5.2.1.3.2*).

In both cases, the specific timing of when the Controller drives SDA in relation to SCL depends on the HDR Mode signaling. In this section and its sub-sections, a possible example signaling method is provided:

- For HDR Modes that use SCL as an edge-triggering clock (i.e., like SDR Mode), the first bit starts on the next SCL rising edge, and the Controller shall drive SDA when SCL is Low (i.e., before the rising edge). This ensures that the Target samples SDA on the SCL rising edge.

**Note:**

*The signaling method described in this section is intended to be used as a template for the HDR Modes defined in the I3C Basic Specification. Since other signaling methods are possible, this section does not provide an exhaustive list of possible signaling methods that might be defined for future HDR Modes, or other HDR Modes that are not included in the I3C Basic Specification.*

### 5.2.1.3.1 Entering the HDR Mode After ENTHDRx CCC

To enter an HDR Mode, the Controller sends the Broadcast CCC for a particular HDR Mode and then drives SDA after the completion of the T-Bit (i.e., on or after the falling edge of the SCL pulse for C9) to begin the first structured protocol element in that HDR Mode, according to the HDR Mode framing.

From that point, the Controller follows the common timing rules for starting a transfer in that HDR Mode per [Section 5.2.1.3](#). Note that the I3C Bus transitions from SDR Mode to that HDR Mode after the falling edge of the SCL pulse for C9.

[Figure 99](#) illustrates the signaling for entering a generic HDR Mode (shown as “HDR-x”) after the ENTHDRx CCC. In this example, this HDR Mode uses SCL as a dedicated, edge-triggering clock, so the Controller sets up SDA before the next SCL rising edge, to start sending the first structured protocol element (i.e., a Command or Header) for the first HDR Mode transfer.



**Figure 99 Entering HDR Mode After ENTHDRx CCC (Dedicated Edge Clock)**

**Note:**

In [Figure 99](#), the I3C Bus enters the HDR Mode after the T-Bit, since the ENTHDRx Broadcast CCCs do not support Defining Bytes.

### 5.2.1.3.2 Next HDR Mode Transfer After HDR Restart Pattern

To remain in an HDR Mode after the completion of an HDR Mode transfer that ends with the HDR Restart Pattern (see *Figure 92*), the Controller completes the SCL pulse by driving SCL Low, and then drives SDA to begin the first structured protocol element in that HDR Mode, according to the HDR Mode framing.

From that point, the Controller follows the common timing rules for starting a transfer in that HDR Mode per *Section 5.2.1.3*. Note that the I3C Bus remains in the same HDR Mode through the HDR Restart Pattern.

*Figure 100* illustrates the signaling for an HDR Restart Pattern followed by starting the next HDR Mode transfer, in a generic HDR Mode (shown as “HDR-x”) that uses SCL as a dedicated, edge-triggering clock. This diagram might be a continuation of the signaling shown in *Figure 99*: if so, then the I3C Bus remains in the same HDR Mode through the HDR Restart Pattern and the next HDR Mode transfer. After the completion of the SCL pulse that validates the HDR Restart Pattern, the Controller sets up SDA before the next SCL rising edge, to start sending the first structured protocol element for the next HDR Mode transfer (similar to *Figure 99*).



4972  
4973 **Figure 100 Next HDR Mode Transfer After HDR Restart Pattern (Dedicated Edge Clock)**

### 5.2.2 HDR Double Data Rate Mode (HDR-DDR)

Like SDR Mode, HDR-DDR Mode uses SCL as a clock; however unlike SDR, Data and Commands change SDA on both SCL edges (when High and when Low), effectively doubling the data rate. By contrast, in SDR Mode SDA is changed only when SCL is Low. Since SDR Mode defines it as a START or a STOP for SDA to change while SCL remains High, HDR-DDR Mode is classified as an HDR Mode in order to prevent confusion.

HDR-DDR moves data by Words. A Word generally contains 16 payload bits, as two bytes in a byte stream, and two parity bits. Four HDR-DDR Word Types are defined: Command Word, Data Word, CRC Word, and Reserved Word.

The HDR-DDR Protocol precedes each 18-bit Word with a 2-bit Preamble, for a total of 20 bits per Word.

The Preamble:

- Indicates the type of data that follows: either Command, Data, or CRC
- Allows the Controller to terminate a Read, and to determine whether the Target is willing to respond to a Read
- Allows the Target to request a Write termination

The related procedures are described in *Section 5.2.2.3*.

**HDR-DDR Command Word****HDR-DDR Data Word****HDR-DDR CRC Word****Figure 101 HDR-DDR Word Formats**

4991 Preamble bit interpretation depends on the context, as shown in **Table 64**. The context controls the roles of  
 4992 Controller and Target, such that for Data, the Target or Controller drives the second Preamble bit after the  
 4993 other I3C Device has Parked High. The Preamble value of 2'b00 is reserved for special use, as indicated  
 4994 when such use is defined.

4995

**Table 64 HDR-DDR Preamble Values**

| Context                 | Preamble Value and Interpretation |                      |                                                                            |                                                               |
|-------------------------|-----------------------------------|----------------------|----------------------------------------------------------------------------|---------------------------------------------------------------|
|                         | 2'b00                             | 2'b01                | 2'b10                                                                      | 2'b11                                                         |
| <b>After Enter HDR</b>  | Reserved for special use cases    | Command Word follows | –                                                                          | –                                                             |
| <b>After Read CMD</b>   |                                   | –                    | Target ACK,<br>Data follows                                                | Target NACK,<br>Aborted                                       |
| <b>After Read DATA</b>  |                                   | CRC Word follows     | Controller Aborts,<br>Target yields.<br><i>Controller drives second 0.</i> | Data follows.<br><i>Controller does not drive second bit.</i> |
| <b>After Write CMD</b>  |                                   | –                    | Target ACK,<br>Data follows                                                | Target NACK,<br>Aborted                                       |
| <b>After Write DATA</b> |                                   | CRC Word follows     | Target requests END<br>Controller complies                                 | Data follows                                                  |

4996 HDR-DDR Mode defines four Word Types (see **Figure 101**):

4997 • **Command Word:**

- 4998 • The Preamble before a Command Word shall have the value 2'b01.  
 4999 • The length of a Command Word shall be 18 bits (16 value bits, 2 parity bits).

5000 HDR-DDR Mode Command Codes allow up to 128 Write or Read Commands,  
 5001 respectively (see **Section 5.2.2.2**).

5002 • **Data Word:**

- 5003 • The Preamble before a Data Word shall contain the value 2'b10 or 2'b11 (see **Table 64**).  
 5004 • The length of a normal Data Word shall be 18 bits (16 value bits as two bytes, 2 parity bits).

5005 • **CRC Word:**

- 5006 • The Preamble before a CRC Word shall have the value 2'b01.  
 5007 • The length of a CRC Word shall be 10 clocked bits (4 bit 4'hC token, 5 bits of CRC-5  
 5008 checksum, 1 bit of 1'b1 setup to prepare the Bus for the following HDR Exit Pattern or HDR  
 5009 Restart Pattern).  
 5010 • The value of the upper nibble (first 4 bits after the Preamble) of a CRC Word shall be 4'hC.  
 5011 • There is no parity checking for a CRC Word.  
 5012 • Following the falling edge of the last SCL pulse, the SDA shall be kept High (i.e., Open Drain  
 5013 class Pull-Up from Controller, while Target is in High-Z), for a time at least equal to  $t_{DIG\_H}$ .  
 5014 • Following transmission of a CRC Word, an I3C Device shall set up SCL and SDA to allow for  
 5015 an HDR Restart Pattern or HDR Exit Pattern.

5016 The CRC-5 algorithm is specified in **Section 5.2.2.5**.

5017 • **Reserved Word** (For special use only):

- 5018 • The Preamble before a Reserved Word (i.e., not a CRC Word) shall have the value 2'b01.  
 5019 • The length of a Reserved Word shall be 18 bits (4-bit token 4'hD / 4'hE / 4'hF, 12 reserved  
 5020 bits, and 2 parity bits).

5021  
5022  
5023

**Note:**

*HDR-DDR Mode also allows for special use cases to be defined in the future, via Preamble value 2'b00.*



**Figure 102 HDR-DDR Preamble Bits State Diagram**

### 5.2.2.1 HDR-DDR Overview

The HDR-DDR Protocol uses the same signaling as SDR, but operates with SDA changing after each SCL edge.

- A normal HDR-DDR Read Request shall be composed of a Command Word from the Controller, followed by one or more Data Words from the Target, followed by one CRC Word from the Target as shown in *Figure 103*.
- An HDR-DDR Write Request shall be composed of a Command Word, followed by one or more Data Words, and one CRC, all from the Controller, as shown in *Figure 106*.
- A NACKed HDR-DDR Read Request shall be composed of a Command Word, followed by the Target not ACKing (driving Low SDA) in the second pre-amble bit, before what would be the first Data Word.

Each Command Word and each Data Word is 20 bits in length (i.e., 20 clock edges) including a two-bit Preamble. At 10MHz the raw bit rate is 20 Mbps; at 12.5 MHz the raw bit rate is 25 Mbps. Because each Word includes two Preamble bits and two Parity bits, the real data rate (considering only the two bytes in the 16 payload bits per Word) is the raw rate times 16/20, or 16 Mbps at 10 MHz (20 Mbps at 12.5 MHz), which is a measure of the 16-bit data rate.

HDR-DDR Command Words indicate the direction of data movement: either Write (Controller to Target), or Read (Target to Controller). After the Command Word, one or more Data Words are sent by the Controller or by the Target (unless NACKed) until done, followed by the CRC Word (unless NACKed). Finally, the Controller issues either an HDR Restart Pattern or an HDR Exit Pattern. The Controller may also terminate a Read prematurely, per *Section 5.2.2.3.3*, however this is not a normal end for a Read, and should be used sparingly. The Target may request the termination of a Write, per *Section 5.2.2.3.6*.

In HDR-DDR Mode, just as in SDR Mode, only the I3C Bus Controller drives the SCL line. For Commands, the SDA line is driven by the Controller. For Data, the SDA line is driven either by the Target or by the Controller, depending on the Command direction. Bus Turnaround behavior is specified in *Section 5.2.2.3*.

The common format used by HDR-DDR Command Words, Data Words, and Reserved Words is illustrated in *Table 65*. The Command details are explained in *Section 5.2.2.2*. The format used by HDR-DDR CRC Words is a subset of the Command Word and the Data Word (see *Section 5.2.2.5*).

**Table 65 HDR-DDR Word Format: Command, Data, Reserved**

| Preamble                                                                                     | Payload                        | Parity<br>(not the CRC)             |                                            |
|----------------------------------------------------------------------------------------------|--------------------------------|-------------------------------------|--------------------------------------------|
| <b>2 bits</b>                                                                                | <b>16 bits</b>                 | <b>1 bit</b>                        | <b>1 bit</b>                               |
| <b>2'b00: Not used</b><br><b>2'b01: Command or CRC</b><br><b>2'b10, 2'b11: Data or Abort</b> | Command Code or<br>Data Values | XOR of<br>Odd index Payload<br>bits | XOR of<br>1 and Even index<br>Payload bits |

The two parity bits are formed from the payload bits, using an XOR function:

- **PA1** = Parity of the odd index Payload bits:

$$D[15] \wedge D[13] \wedge D[11] \wedge D[9] \wedge D[7] \wedge D[5] \wedge D[3] \wedge D[1]$$

- **PA0** = Parity of the even index Payload bits and 1:

$$D[14] \wedge D[12] \wedge D[10] \wedge D[8] \wedge D[6] \wedge D[4] \wedge D[2] \wedge D[0] \wedge 1$$

5059 **Table 66** summarizes the format of all four HDR-DDR Word Types.

5060

**Table 66 HDR-DDR Word Formats**

| Word Type | Preamble       | Payload                        |                                                                                                                                  | Parity   |     | Notes                                                                                                                                                 |
|-----------|----------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 2 bits         | 16 bits                        |                                                                                                                                  | 1b       | 1b  |                                                                                                                                                       |
| Command   | 2'b01          | 15:8                           | Command Code (8 bits)                                                                                                            | PA1      | PA0 | Command may follow only Enter HDR or HDR Restart.                                                                                                     |
|           |                | 7:1                            | Target Address (7 bits)                                                                                                          |          |     | <b>Command Codes:</b><br><b>Write:</b> 8'h00 to 8'h7F<br><b>Read:</b> 8'h80 to 8'hFF                                                                  |
|           |                | 0                              | Reserved (1 bit)                                                                                                                 |          |     |                                                                                                                                                       |
| Data      | 2'b10<br>2'b11 | 15:8                           | First Data Byte (8 bits)                                                                                                         | PA1      | PA0 | One or more Data Words shall follow Command, unless NACKed. Only CRC may follow Data.                                                                 |
|           |                | 7:0                            | Second Data Byte (8 bits)                                                                                                        |          |     |                                                                                                                                                       |
| CRC       | 2'b01          | 15:12                          | 4'hC (token value) (4 bits)                                                                                                      | Not Used |     | CRC value ends at bit 6, followed by either HDR Restart Pattern or HDR Exit Pattern. See signal diagrams in <b>Figure 104</b> and <b>Figure 105</b> . |
|           |                | 11:7                           | CRC-5 checksum (5 bits)                                                                                                          |          |     |                                                                                                                                                       |
|           |                | 6                              | 1'b1 setup bit, followed by High level for a time of at least tDIG_H, starting from the falling edge of the last SCL clock pulse |          |     |                                                                                                                                                       |
|           |                | 5:0                            | Reserved (6 bits), No clocks                                                                                                     |          |     |                                                                                                                                                       |
| Reserved  | 2'b01          | 15:12                          | 4'hD to 4'hF (4 bits)                                                                                                            | PA1      | PA0 | Reserved for future use                                                                                                                               |
|           |                | 11:0                           | Reserved (12 bits)                                                                                                               |          |     |                                                                                                                                                       |
| –         | 2'b00          | Reserved for special use cases |                                                                                                                                  |          |     |                                                                                                                                                       |

5061  
5062  
5063  
5064  
5065

HDR-DDR Mode is entered in the standard way, using the Enter HDR CCC (see **Section 5.1.9.3.8**). After the Enter HDR CCC and its ninth bit (the T-Bit), the SCL falling edge begins the HDR Mode. The first HDR-DDR bit starts on the next SCL rising edge; that is, the Controller drives SDA when SCL is Low, and the Target samples SDA on the SCL rising edge. This allows the entry to HDR-DDR Mode, as shown in **Figure 106**.

5066  
5067  
5068  
5069

Once in HDR-DDR Mode the Controller issues a Command Word to start every transfer (unless NACKed). In HDR-DDR Mode, Commands shall be issued only by a Controller. Data Words may be issued by a Controller or by a Target, depending on the particular Command (Write or Read). At least one Data Word shall be issued, unless the Target does not accept (ACK) the Command per **Section 5.2.2.3**.

5070 **Figure 103** illustrates a typical HDR-DDR Mode Frame with two HDR Commands and their associated data:

- 5071 • I3C START or Repeated START  
 5072 • I3C CCC to Enter HDR-DDR Mode  
 5073 • After entering HDR-DDR Mode, there is one HDR-DDR Command Word, followed by one or  
 5074 more HDR-DDR Data Words, and then an HDR-DDR CRC Word  
 5075 • Then an HDR Restart Pattern  
 5076 • Then another HDR-DDR Command Word, HDR-DDR Data Word, and HDR-DDR CRC Word  
 5077 • Finally, HDR Mode is ended via the HDR Exit Pattern followed by I3C STOP

5078 **Note:**

5079 *An HDR-DDR CRC Word might also be emitted after an abort, per **Section 5.2.2.3**.*



5080 **Figure 103 Typical HDR-DDR Mode Frame**

5081 Following the HDR-DDR CRC Word, the Controller provides either the HDR Restart Pattern or the HDR Exit Pattern.

5082 On a WRITE transaction, the Controller controls the whole transfer; as a result, the transition from the CRC  
 5083 Word to either the HDR Restart Pattern or the HDR Exit Pattern is done with only the Controller driving the  
 5084 SDA, while the Target's SDA IO is on High-Z (see **Figure 104**).



Figure 104 HDR-DDR CRC and HDR Restart Pattern or HDR Exit Pattern in Write Transaction

5089 On a Read transaction, the Target drives the CRC and the Controller takes over generation of the HDR Restart  
5090 Pattern or HDR Exit Pattern. See **Figure 105** for the signal diagram for this SDA handoff.

5091 This procedure has the following steps:

- 5092 1. The Target actively transfers the data, while the Controller is in High-Z.
- 5093 2. The Target actively drives the CRC Word, including pulling the setup bit (bit[6]) High.
- 5094 3. After a time of  $t_{SCO}$  elapses after the falling edge of CRC\_CLK6, the Target releases SDA on  
5095 High-Z (**Figure 105**, point 3)
- 5096 4. The Controller keeps its SDA output on High-Z until the start of rising edge of CRC\_CLK6, when  
5097 it enables the Open Drain class Pull-Up (**Figure 105**, point 1). The SDA line remains driven by the  
5098 Target.
- 5099 5. The Controller starts driving SDA High when it starts the falling edge of CRC\_CLK6 (point 2 in  
5100 the diagram). Since the Target was driving the setup bit (bit[6]) High, the two Devices are now  
5101 driving in parallel.
- 5102 6. After a time of at least  $t_{DIG\_H}$  elapses after the falling edge of CRC\_CLK6, the Controller may start  
5103 the first falling edge of the SDA, commencing either the HDR Restart Pattern or the HDR Exit  
5104 Patterns (**Figure 105**, point 4).
- 5105 7. The result of this procedure is a safe handoff of the SDA line from the Target to the Controller.



Figure 105 HDR-DDR CRC and HDR Restart Pattern or HDR Exit Pattern in Read Transaction

5106  
5107

### 5.2.2.2 HDR-DDR Command Coding

In HDR-DDR Mode a Command Word follows the initial Enter HDR CCC (and any HDR Restart). This Command Word uses the normal 18-bit model. **Table 67** illustrates the Command Word format for HDR-DDR Mode.

**Table 67 HDR-DDR Command Word Format**

| Bits | Field                    | Size (bits) | Notes                                                                               |
|------|--------------------------|-------------|-------------------------------------------------------------------------------------|
| 15   | <b>Read/Write</b>        | 1           | <b>1:</b> Read (Target to Controller)<br><b>0:</b> Write (Controller to Target)     |
| 14:8 | <b>Command Code</b>      | 7           | 128 possible Write commands<br>128 possible Read commands                           |
| 7:1  | <b>Target Address</b>    | 7           | Same Dynamic Address as used in I3C SDR Protocol                                    |
| 0    | <b>Parity Adjustment</b> | 1           | Ensures that PA0 contains 1'b1, which allows for easier Bus Turnaround <sup>1</sup> |

**Note:**

1) Because PA0 is the XOR of the even index Payload bits and 1, it is equal to:  
 $\text{XOR\_outer}( 1, \text{this bit}, \text{XOR\_inner}( 2, 4, 6, 8, 10, 12, 14 ) )$   
As a result, this bit should be set to the result of `XOR_inner()`.

Regarding bits 15:8 together, the possible Command Code spaces for Read Commands and Write Commands in HDR-DDR Mode are illustrated in **Table 68**.

**Table 68 Read and Write Command Spaces for HDR-DDR Mode**

| Command Codes      | Command Functions                |
|--------------------|----------------------------------|
| <b>0x00 – 0x7F</b> | Available for any use for writes |
| <b>0x80 – 0xFF</b> | Available for any use for reads  |

5115 Signal diagrams for starting the HDR-DDR Command Codes are shown in **Figure 106** and **Figure 107**.  
 5116 **Figure 106** shows the HDR-DDR Command Code after ENTHDR0, and **Figure 107** shows the HDR-DDR  
 5117 Command Code after HDR Restart Pattern.



**Figure 106 HDR-DDR Command Code After ENTHDR0**

5120 As **Figure 106** shows:

- 5121 1. First the SCL pulse is ended by its falling edge (as is necessary for the Targets' logic design).  
 5122 2. Then on the SCL Low that follows, the Controller positions the SDA (i.e., sets SDA either High or  
 5123 Low) as necessary to be read on the first SCL rising edge, using Push-Pull timing.



**Figure 107 HDR-DDR Command Code After HDR Restart Pattern**

5124 As *Figure 107* shows:

- 5125 1. After the SCL rising edge for validating the HDR Restart pattern, an SCL falling edge is provided.  
5126 The result is an SCL pulse, identical to the SCL pulse of T-Bit (see *Figure 106*).  
5127 2. Any possible changes on SDA are ignored until the SCL rising edge that follows (labeled “First  
5128 DDR edge”).  
5129 3. On the SCL Low following the SCL pulse falling edge, the Controller positions the SDA (i.e., sets  
5130 SDA either High or Low) as necessary to be read on the first SCL rising edge, using Push-Pull  
5131 timing.  
5132 4. The waveform that follows is identical to the same segment in *Figure 106*.  
5133

### 5.2.2.2.1 CCC Transmission in HDR-DDR Mode

5135 A special HDR-DDR syntax is used for transmitting Common Command Codes in the HDR-DDR protocol. The following formats are defined, as specific  
 5136 instantiations of the generic HDR CCC flows (see *Section 5.2.1.2*). The Broadcast CCC flow is shown in *Figure 108*, and the Direct CCC flow is shown in  
 5137 *Figure 109*.



**Figure 108** HDR-DDR Broadcast CCC Format



Figure 109 HDR-DDR Direct CCC Format

### HDR-DDR CCC Header Block

The HDR-DDR CCC Header Block has several different formats that are used in the framing of CCC flows in HDR-DDR Mode. Two of these formats are commonly used: an ‘Indicator’ type, used at the start of every CCC, and a ‘Selector’ type, used at the start of a Write Segment or Read Segment for Direct CCCs. A generic Header Block (which is neither an ‘Indicator’ type nor a ‘Selector’ type) may also be used for other purposes, such as CCC End Procedures.

The HDR-DDR CCC Header Block always begins with an HDR-DDR Command Word, which shall take its structure (see *Table 66* and *Table 67*). All Targets that support CCC flows in HDR-DDR Mode must acknowledge the HDR-DDR Header Block’s Command Word if addressed, unless defined otherwise for a particular usage in CCC flows. If an acknowledgement is required, then Bit[0] shall contain a value chosen to ensure that the PA0 field (Parity bit 0, see *Table 68*) contains the value 1'b1, per *Section 5.2.2.3.1*.

**Start of CCC:** An HDR-DDR CCC Header Block that begins the framing for a Broadcast CCC or a Direct CCC shall consist of one HDR-DDR CCC Indicator Word, followed by one HDR-DDR CCC Command Word:

- The HDR-DDR CCC Indicator Word shall take the structure of the HDR-DDR Command Word Format (see *Table 66* and *Table 67*):
  - **Bit[15]** shall contain 1'b0, indicating a WRITE command (Controller to Target).
  - **Bits[14:8]** are reserved, and shall be ignored by the Target Devices.
  - **Bits[7:1]** shall contain the Broadcast Address (7'h7E).
  - Acknowledgement is always required, so Bit[0] shall contain a value chosen to ensure that all Targets supporting CCC flows in HDR-DDR Mode will acknowledge this Indicator Word.
- The HDR-DDR CCC Command Word shall take the structure of the HDR-DDR Data Word Format (see *Table 67*).
  - **Bits[15:8]** shall contain the Command Code, which may be a Broadcast CCC or a Direct CCC.
  - **Bits[7:0]** shall contain the optional Defining Byte for the Command Code. If the CCC does not support an optional Defining Byte, then this field shall contain the value 8'h00.

**Start of Segment:** An HDR-DDR CCC Header Block that begins a Read Segment or Write Segment in Direct CCC framing shall consist of one HDR-DDR CCC Selector Word.

- The HDR-DDR CCC Selector Word shall take the structure of the HDR-DDR Command Word Format:
  - **Bit[15]** distinguishes a Read Segment vs. a Write Segment:
    - **For the start of a Write Segment** (i.e., a Direct Write or Direct SET CCC) this field shall contain 1'b0 to indicate a Write (Controller to Target).
    - **For the start of a Read Segment** (i.e., a Direct Read or Direct GET CCC) this field shall contain 1'b1 to indicate a Read (Target to Controller).
  - **Bits[14:8]** are reserved, and shall be ignored by the Target Devices.
  - **Bits[7:1]** shall contain the Dynamic Address of the Target to be addressed for Write or Read in this Segment. For Write Segments, Bits[7:1] might also contain a valid Group Address (per *Section 5.2.1.2.6*).
  - Acknowledgement is always required, so Bit[0] shall contain a value chosen to ensure that the addressed Target (or all Targets in the addressed Group) will acknowledge this Selector Word. This facilitates ACK/NACK for a Target (or Group) addressed by a Direct Write or Direct SET CCC (per *Section 5.2.2.3.1*), and facilitates both ACK/NACK and Bus Turnaround for a Target addressed by a Direct Read or Direct GET CCC (per *Section 5.2.2.3.2*).

### HDR-DDR CCC Data Block

An HDR-DDR CCC Data Block may follow an HDR-DDR CCC Header Block, in the appropriate location for either a Broadcast CCC flow (see *Figure 108*) or a Direct CCC flow (see *Figure 109*).

- **Broadcast:** The HDR-DDR CCC Data Block in a Broadcast CCC flow shall take the structure of the HDR-DDR Data Word Format (see *Table 66*) and shall contain 16 bits (2 bytes) of data in its payload.
  - Per *Section 5.2.1.2*, all HDR-DDR CCC Data Blocks shall be transmitted using SDA[0] (i.e., 1-Lane mode) in order to ensure that all Target Devices that support HDR-DDR are always able to receive and understand the Broadcast CCC data, regardless of their currently configured ML Frame format, or the number of additional Lanes they might support.
- **Direct:** The HDR-DDR CCC Data Block in a Direct CCC flow shall have the same structure as that of a Broadcast CCC flow (i.e., an HDR-DDR Data Word using SDA[0] in 1-Lane mode).
  - If the total data length is an odd number of bytes, then the sender shall pad the Data Block with an extra byte with value 8'd0, and the receiver shall discard the extra padding byte.

**Note:**

*Multi-Lane support for HDR-DDR Mode is not included in I3C Basic. The above configuration advisory is provided in order to maintain full compatibility with I3C Target Devices that might support Multi-Lane for HDR-DDR Mode, as defined in version 1.1 or higher of the full I3C Specification.*

### HDR-DDR CRC Block

An HDR-DDR CRC Block serves as the Termination Marker, as described in the HDR-x generic CCC flows. To conform to the HDR-DDR Mode Framing model (see *Figure 103*), this Termination Marker uses the same structure as the standard HDR-DDR CRC Word.

- For the end of Broadcast data sent in a Broadcast CCC flow, the HDR-DDR CRC Block shall be a single HDR-DDR CRC Word transmitted by the Controller in 1-Lane mode (see *Table 66* and *Figure 104*), sent as a common CCC flow element, to ensure that all Targets will receive it.
- For the end of the HDR-DDR CCC Command Word sent in a Direct CCC flow, the HDR-DDR CRC Block shall be a single HDR-DDR CRC Word transmitted by the Controller in 1-Lane mode as described above.
- For the end of a Read Segment or Write Segment in a Direct CCC flow, the HDR-DDR CRC Block shall be a single HDR-DDR CRC Word (i.e., the same as both flows above).

The HDR-DDR CRC Block shall be included with all common CCC Flow Elements, as it must be received and understood by all HDR-DDR Targets, including those that only support 1-Lane mode.

**Note:**

*Both Broadcast and Direct CCC flows are special types of standard HDR-DDR transfers, so the HDR-DDR CRC Block is used, per standard HDR-DDR transfer requirements. As noted above (i.e., for the HDR-DDR CCC Data Block definition) Multi-Lane support for HDR-DDR Mode is not included in I3C Basic, so the HDR-DDR CRC Block must always use the same format (i.e., Data Transfer Coding) as the HDR-DDR Data Block that precedes it.*

### HDR-DDR CCC Indicator Word and Header ACK

Per *Section 5.2.1.2.2*, a Target that supports CCCs in HDR-DDR Mode shall indicate acknowledgement of the receipt of the HDR-DDR CCC Indicator Word, as well as the HDR-DDR CCC Header Block's Command Word when used for other purposes, using the standard method of acknowledging an HDR-DDR write, per *Section 5.2.2.3.1* and *Figure 111*. Such a Target shall detect matching Command Words in CCC flows (including Indicator Words) that are addressed to the Broadcast Address (i.e., 7'h7E) and have a correctly calculated PA0 field (i.e., Parity bit 0, see *Table 66*) that contains the value 1'b1.

- This applies to the Indicator Word when used with both Broadcast CCC flows and Direct CCC flows, since the same HDR-DDR CCC Indicator Word format is used to signal the beginning of both flows.

- 5230 • This also applies to the Command Word when used appropriately for other purposes in CCC  
5231 flows, such as CCC End Procedures.

5232 If the Controller does not receive acknowledgement from at least one Target, then it shall use any valid  
5233 HDR-DDR CCC End Procedure. Additionally, it may initiate an error recovery procedure, which might  
5234 include exiting HDR-DDR Mode and attempting to re-send the CCC in SDR Mode.

#### **HDR-DDR Direct CCC Write Segment**

5235 An HDR-DDR CCC Write Segment for a Direct Write or Direct SET CCC shall start with an HDR-DDR  
5236 CCC Selector Word to indicate the Address of the Target (or Group) to receive the data, followed by one or  
5237 more HDR-DDR CCC Data Blocks of the appropriate structure, as required by the CCC definition.

5238 After the Controller sends the HDR-DDR CCC Selector Word, the Target shall then either indicate acceptance  
5239 of the Direct CCC by acknowledging the WRITE Command, or else reject the Direct CCC by not responding  
5240 to the Controller. The Target shall use the cached Command Code and optional Defining Byte from the  
5241 previously received HDR-DDR CCC Command Word, and shall decide whether to accept or reject the Direct  
5242 CCC immediately after receiving the HDR-DDR CCC Selector Word and matching its own Dynamic Address  
5243 (or Group Address, if assigned and applicable).

5244 **Note:**

5245 *If the CCC definition does not require data to be written to the Target or Group, then the Controller  
5246 shall send a single HDR-DDR CCC Data Block that contains padding bytes (i.e., values of 8'd0). The  
5247 Target shall discard the extra padding bytes, based on the cached Command Code and optional  
5248 Defining Byte that were sent previously, as part of the CCC Framing in HDR-DDR Mode.*

5249 The Target shall use the standard HDR-DDR Flow Control methods to either accept or reject an HDR-DDR  
5250 WRITE Command, as defined in **Section 5.2.2.3.1** and as illustrated in **Figure 111** (accept) or **Figure 112**  
5251 (reject).

5252 **If the Target rejects the Direct CCC**, then the Controller shall either send the HDR Restart Pattern and attempt  
5253 another Read or Write Segment for this CCC, or else use any valid HDR-DDR CCC End Procedure. For  
5254 Direct Write or Direct SET CCCs to a Group Address, the Controller only sees this rejection if no Targets  
5255 accept the Direct CCC.

5256 **If the Target accepts the Direct CCC**, then the Controller shall send one or more HDR-DDR CCC Data Blocks  
5257 of the appropriate structure, if required by the CCC definition. Then the Controller shall send an HDR-DDR  
5258 CRC Word to terminate the data and end the Write Segment.

5259 At the end of a Write Segment, the Controller shall either send the HDR Restart Pattern and attempt another  
5260 Read or Write Segment for this CCC, or else use any valid HDR-DDR CCC End Procedure.

#### **HDR-DDR Direct CCC Read Segment**

5261 An HDR-DDR CCC Read Segment for a Direct Read or Direct GET CCC shall start with an HDR-DDR  
5262 CCC Selector Word to indicate the Address of the Target to provide data for the CCC, followed by a Bus  
5263 Turnaround. In response, the indicated Target will either accept the Direct CCC by transmitting one or more  
5264 HDR-DDR CCC Data Blocks of the appropriate structure, or else reject the Direct CCC by not responding  
5265 to the Bus Turnaround condition.

5266 The Target shall use the standard HDR-DDR Flow Control methods to either accept or reject an HDR-DDR  
5267 READ Command, as defined in **Section 5.2.2.3.2** and as illustrated in **Figure 113** (accept) or **Figure 114**  
5268 (reject).

5269 **If the Target accepts the Direct CCC**, then the Controller shall yield control of the Bus to the Target so that it  
5270 can control the Bus to send the Data Blocks. After sending the last Data Block, the Target shall send an  
5271 HDR-DDR CRC Word, indicating the end of the read transfer. Upon receiving the HDR-DDR CRC Word  
5272 the Target shall yield control of the Bus, and the Controller shall resume control.

5273 At the end of a Read Segment, the Controller shall either send the HDR Restart Pattern and attempt another  
5274 Read or Write Segment for this CCC, or else use any valid HDR-DDR CCC End Procedure.

### HDR-DDR CCC End Procedures

As illustrated in *Figure 110*, the HDR-DDR CCC ends using one of three possible CCC End Procedures.

#### Option 1: END HDR-DDR CCC Followed by New HDR-DDR CCC

This End Procedure indicates the end of a Broadcast or Direct CCC in HDR-DDR Mode, and the beginning of a new Broadcast or Direct CCC in HDR-DDR Mode.

This End Procedure begins with an HDR Restart Pattern, followed by an HDR-DDR CCC Header Block containing a new CCC and optional Defining Byte. This starts either a Broadcast CCC flow (*Figure 108*) or a Direct CCC flow (see *Figure 109*) while remaining in the CCC modality.

The Controller starts a new CCC by sending one HDR-DDR Command Word, acting as the HDR-DDR CCC Indicator Word and containing the Broadcast Address; followed by one HDR-DDR Data Word, acting as the HDR-DDR CCC Command Word and containing the Command Code and optional Defining Byte for the new CCC.

Additional HDR-DDR Words shall follow, per the CCC flow type.

The flow steps are:

1. Controller sends HDR Restart Pattern.
2. Controller sends HDR-DDR CCC Indicator Word, using the same format as described above.
3. Targets acknowledge receipt of Indicator Word, as defined above.
4. Controller sends HDR-DDR CCC Command Word, including the Command Code and optional Defining Byte.
5. Flow continues as Broadcast CCC or Direct CCC, as shown above.

#### Option 2: END HDR-DDR CCC Followed by Another HDR-DDR Generic Transaction (+ Optional HDR Exit)

This End Procedure indicates the end of CCCs in HDR-DDR, and either a return to standard HDR-DDR transactions or a subsequent exit from HDR-DDR Mode.

This End Procedure begins with an HDR Restart Pattern, followed by an HDR-DDR Command Word which ends the CCC flow, but is neither an Indicator nor a Selector. This Command Word is a common flow element that is sent to all Targets and must be acknowledged (i.e., like the Indicator Word).

This is followed by an HDR-DDR Data Word, a common flow element that is required for HDR-DDR WRITE transfers (per *Section 5.2.2.1*). This Data Word contains the dummy command code value (i.e., 0x1F, see *Table 16*) to indicate the end of the CCC modality in HDR-DDR Mode, per *Section 5.2.1.2.1*.

#### Note:

*This HDR-DDR Data Word is not an HDR-DDR CCC Command Word.*

This is followed by an HDR-DDR CRC Word as a common flow element. This CRC Word's checksum is computed from the contents of the preceding HDR-DDR Data Word.

After this, the HDR Restart Pattern signals the end of CCC modality, and that the next HDR-DDR Command Word must be treated as a standard HDR-DDR transaction (not as a CCC flow). Alternatively, the HDR Exit Pattern signals the end of HDR-DDR Mode and a subsequent return to SDR Mode.

In either case, the HDR-DDR Command Word that indicates a write to the Broadcast Address followed by an HDR-DDR Data Word that contains the dummy command code value (i.e., 0x1F) is distinct from any other valid CCC flow in HDR-DDR Mode. Target Devices shall interpret this flow as the ending of the CCC modality.

5314 The flow steps are:

- 5315 1. Controller sends HDR Restart Pattern.
- 5316 2. Controller sends HDR-DDR Command Word (i.e., not Indicator or Selector), using the following values:
  - 5317 • **Bit[15]** shall contain the value 1'b0, indicating a WRITE command (Controller to Target).
  - 5318 • **Bits[14:8]** are reserved, and shall be ignored by the Target Devices.
  - 5319 • **Bits[7:1]** shall contain the Broadcast Address (7'h7E).
  - 5320 • **Bit[0]** shall follow the general rule for all Command Words in HDR-DDR CCC Header Blocks, to facilitate ACK/NACK by all Targets.
- 5321 3. Targets acknowledge receipt of the HDR-DDR Command Word, as above.
- 5322 4. Controller sends HDR-DDR Data Word, using the following values:
  - 5323 • **Bits[15:8]** shall contain the dummy command code (0x1F) to end the CCC modality.
  - 5324 • **Bits[7:0]** are reserved, and shall contain zeros.
- 5325 5. Controller sends HDR-DDR CRC Word.  
5326 Targets detect this flow (i.e., Command Word, one Data Word with dummy Command Code, and  
5327 CRC Word) and end CCC modality.
- 5328 6. Controller either sends HDR Restart Pattern, or HDR Exit Pattern.  
5329 If HDR Exit Pattern, then the Controller exits HDR-DDR Mode and returns the Bus to SDR  
5330 Mode.

#### 5331 **Option 3: END HDR-DDR CCC and Return to SDR Mode**

5332 This is the simplest End Procedure. It indicates the end of CCCs in HDR-DDR Mode and an immediate exit  
5333 from HDR-DDR Mode.

5334 The flow steps are:

- 5335 1. Controller sends HDR Exit Pattern.
- 5336 2. Controller exits HDR-DDR Mode and returns the Bus to SDR Mode.



Figure 110 HDR-DDR CCC End Procedures

### 5.2.2.3 HDR-DDR Flow Control Elements

The I3C HDR-DDR protocol provides several procedures that allow either the Controller or the Target to control the progress of data transfers. This Section describes these flow control elements.

#### 5.2.2.3.1 Command to Write Data to Target

In response to a Write Command in HDR-DDR Mode, a Target shall either accept one or more Data Words, or else ignore the Write Command.

**Note:**

*Per Table 64, the Target's decision to accept or ignore the Write Command shall determine the Preamble Value of the first HDR-DDR Data Word. See Figure 111 and Figure 112.*

##### Accepting the Write Command

To accept the DDR WRITE from the Controller, the Target actively drives SDA Low before the C1 falling edge (i.e., while SCL is High) for the first HDR-DDR Data Word.

**Figure 111** illustrates Target acceptance (ACK) signaling for the Controller's DDR WRITE command, using numbered blue dots that correspond to the numbered steps below.

The significant steps are:

1. The Controller:

- a. Has selected bit 0 of the Command Word (the Parity Adjustment bit) to ensure that parity bit PA0 (the last bit in the Word) is High (1'b1)
  - b. Disables the active drive of SDA
  - c. Enables the Open Drain class Pull-Up structure on SDA, keeping SDA High
2. The first Preamble bit, PRE1, is found to be High (1'b1)
  3. Once  $t_{SCO}$  elapses after the C1 rising edge, the Target actively drives SDA Low
4. The Controller then:
    - a. Finds that the second Preamble bit, PRE0, is Low (1'b0), and that therefore the Target has accepted the DDR WRITE command, and
    - b. Disables the Open Drain class Pull-Up, and
    - c. Drives actively SDA Low, in parallel with the Target
  5. Once  $t_{SCO}$  elapses after the C1 falling edge, the Target releases the SDA on High-Z
  6. After a suitable delay, the Controller then starts actively driving SDA High or Low, as required by the value of the first data bit (D0.7)

The Controller continues transmitting the data, eventually ending the transfer with the CRC Word. The procedure for the Controller ending the data stream is specified in **Section 5.2.2.3.2**.



5371  
5372

**Figure 111 Target Accepts DDR WRITE Command from Controller**

5373   **Ignoring the Write Command**

5374   To ignore the DDR WRITE from the Controller, the Target allows SDA to remain High through the C1 falling  
5375   edge (i.e., while SCL goes from High to Low) for the first HDR-DDR Data Word.

5376   **Note:**

5377   *Reasons for the lack of a response could include that the Target might not be present on the Bus, or  
5378   that the Target might not want to accept the DDR WRITE command.*

5379   **Figure 112** illustrates signaling when the Target does not respond to the Controller's DDR WRITE command,  
5380   using numbered blue dots that correspond to the numbered steps below.

5381   The significant steps are:

5382   1. The Controller:

- 5383      a. Has selected bit 0 of the Command Word (the Parity Adjustment bit) to ensure that parity bit  
5384         PA0 (last bit of the Word) has the value High (1'b1)

- 5385      b. Enables the Open Drain class Pull-Up structure on SDA, keeping SDA High

5386   2. The Controller finds the first Preamble bit, PRE1, to be High (1'b1)

5387   3. Because the Target does not control SDA, the second Preamble bit, PRE0, is also found to be High  
5388         (1'b1)

5389         As a result, the Controller can consider the Target to be non-responsive to the DDR WRITE  
5390         Command

5391   4. The Controller concludes by starting either an HDR Restart, or an HDR Exit Pattern, respectively.



5392

5393

**Figure 112 Target Does Not Respond to DDR WRITE Command from Controller**

### 5.2.2.3.2 Command to Read Data from Target

In response to a Read Command in HDR-DDR Mode, a Target shall either return one or more Data Words, or else ignore the Read Command. If the Command asks the Target to return one or more Data Words, then the I3C Bus Turnaround occurs on the Preamble value 2'b10 immediately preceding the Data.

**Note:**

*Per Table 64, the Target's decision to accept or ignore the Read Command shall determine the Preamble Value of the first HDR-DDR Data Word. See Figure 113 and Figure 114 below.*

#### Accepting the Read Command

To accept the DDR READ from the Controller, the Target actively drives SDA Low before the C1 falling edge (i.e., while SCL is High) for the first HDR-DDR Data Word.

**Figure 113** illustrates Target acceptance (ACK) signaling for the Controller's DDR READ command, using numbered blue dots that correspond to the numbered steps below.

The significant steps are:

1. The Controller:

- a. Has selected bit 0 of the Command Word (the Parity Adjustment bit) to ensure that parity bit PA0 (the last bit in the Word) is High (1'b1)
  - b. Disable the active drive of SDA
  - c. Enables the Open Drain class Pull-Up structure on SDA, keeping SDA High
2. The first Preamble bit, PRE1, is found to be High (1'b1)
  3. Once  $t_{SCO}$  elapses after the C1 rising edge, the Target actively drives SDA Low
  4. The Controller then:
    - a. Finds that the second Preamble bit, PRE0, is Low (1'b0), and that therefore the Target has accepted the DDR READ command, and
    - b. Disables the Open Drain class Pull-Up and releases SDA on High-Z
  5. Once  $t_{SCO}$  elapses after the C1 falling edge, the Target actively drives SDA either High or Low, as required by the value of the first data bit (D0.7)

The Target continues transmitting the data, eventually ending the transfer with the CRC Word. The procedure for the Target ending the data stream is specified in **Section 5.2.2.3.3**.

**NOTE:**

The Target SDA change starts after the  $t_{SCO}$ , as shown by the vertical timing lines

The Controller drives SDA with a suitable delay, so as to achieve the set-up timing

— = Active Drive by Controller or Target

- - - - - = Open-Drain class Pull-Up by Controller

— - - - = High-Z by Controller

— . . . = High-Z by Target

**Figure 113 Target Accepts DDR READ Command from Controller**

**5423 Ignoring the Read Command**

5424 To ignore the DDR READ from the Controller, the Target allows SDA to remain High through the C1 falling  
5425 edge (i.e., while SCL goes from High to Low) when the Controller tries to drive the first HDR-DDR Data  
5426 Word.

**5427 Note:**

5428 *Reasons for the lack of a response could include that the Target might not be present on the Bus, or*  
5429 *that the Target might not want to accept the DDR READ command.*

5430 **Figure 114** illustrates signaling when the Target does not respond to the Controller's DDR READ command,  
5431 using numbered blue dots that correspond to the numbered steps below.

5432 The significant steps are:

- 5433 1. The Controller:  
5434     a. Has selected bit 0 of the Command Word (the Parity Adjustment bit) to ensure that parity bit  
5435         PA0 (last bit of the Word) has the value High (1'b1)  
5436     b. Enables the Open Drain class Pull-Up structure on SDA, keeping SDA High  
5437 2. The Controller finds the first Preamble bit, PRE1, to be High (1'b1)  
5438 3. Because the Target does not control SDA, the second Preamble bit, PRE0, is also found to be High  
5439         (1'b1)  
5440     a. As a result, the Controller can consider the Target to be non-responsive to the DDR READ  
5441 4. The Controller concludes by starting either an HDR Restart, or an HDR Exit Pattern, respectively.



5442

5443

**Figure 114 Target Does Not Respond to DDR READ Command from Controller**

### 5.2.2.3.3 End of a Complete Data Frame Transfer

The number of Data Words associated with a Command is in many cases a contract between the Controller and Target; that is, it depends on the particular Command Code. However, the HDR-DDR Protocol supports the transmission of variable length Data by the Controller (for a Write) by the Target (for a Read). Additionally, a Controller may terminate a Read (see [Section 5.2.2.3.4](#)) or a Target can request a termination of a WRITE (see [Section 5.2.2.3.5](#)).

For a Write (Controller to Target), the Target shall know that Data transmission is done when a CRC Word followed by the HDR Restart Pattern or HDR Exit Pattern is detected.

For a Read (Target to Controller), the Target shall issue a CRC Word upon conclusion of the data transmission, and then shall Park the SDA line High on the first bit after the CRC 5-bit value, followed by tri-stating the SDA line. The Controller shall see the CRC Word, and then expect to see the 1 (Parked). The Controller shall then make sure that the SCL line is Low, and then transmit an HDR Restart Pattern or HDR Exit Pattern, after the Target has High-Z'ed the SDA line.

### 5.2.2.3.4 HDR-DDR Early Transfer Termination Set-Up

The Controller usually ends a Write Message with a CRC Word, and then continues with either an HDR Restart Pattern or an HDR Exit Pattern. For HDR-DDR Mode, the normal model is that the Target ends a Read with a CRC Word, and then hands control of the I3C Bus back to the Controller. Both these cases are described in [Section 5.2.2.3.3](#).

However, HDR-DDR Mode also allows the Controller to terminate a Read early if necessary, for example if there is an unexpected need to regain the Bus. HDR-DDR Mode also allows the Target to request early termination of a Write data transfer if necessary, for example if the Target's internal storage overflows.

Early termination signaling is accomplished using the two Preamble bits that the Controller or Target transmit before every Data Word. As [Table 66](#) illustrates, the first Preamble bit (PRE1) is always High (1'b1) and is read on the rising edge of SCL. The second Preamble bit (PRE0) is read on the falling edge of the same SCL pulse. If PRE0 is Low (1'b0), then this indicates termination of the data transfer; if PRE0 is High (1'b1), then the data transfer continues.

There are two possibilities for the sender to end the transmission: either providing the corresponding CRC Word, or ending the data string without it. Since the CRC is computed on the complete Message, there are implementations where CRC could not be calculated in time. In order to accommodate both types of design, the HDR-DDR early Message termination offers the option of either providing the CRC Word, or not providing it.

To avoid any possible collision between active drivers in the Target and Controller, the choice of whether to provide the CRC is controlled by a set-up procedure which is acknowledged by the Devices involved in the particular HDR-DDR data transfer.

The ENDXFER CCC ([Section 5.1.9.3.25](#)) controls the set-up and invocation of the Data Transfer Early Termination Procedure for the HDR-DDR protocol. The related ENDXFER CCC's Defining Byte acts as a sub-command that determines the follow-up actions.

5479 ENDXFER's Broadcast or Direct sub-command 0xF7 shall be used during Data Transfer Protocol  
 5480 configuration. The sub-command byte 0xF7 is followed by one additional data byte (see **Table 69**) containing  
 5481 the parameters for the HDR-DDR Data Transfer Early Termination procedure.

5482 **Table 69 ENDXFER CCC Additional Data Byte for Sub-Command 0xF7 (HDR-DDR Protocol)**

| Bits  | Description                                         | Values                                                                                                                                                                                   |
|-------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | <b>CRC Word Indicator</b>                           | <b>2'b11:</b> No CRC Word follows Early Termination request<br><b>2'b01:</b> CRC Word follows Early Termination request<br><b>Other:</b> Reserved for future definition by MIPI Alliance |
| [5]   | <b>Enable WRITE Early Termination Request</b>       | <b>1'b0:</b> Enable<br><b>1'b1:</b> Disable                                                                                                                                              |
| [4]   | <b>Enable ACK/NACK Capability for WRITE Command</b> | <b>1'b0:</b> Enable<br><b>1'b1:</b> Disable                                                                                                                                              |
| [3:0] | Reserved for future use.                            | —                                                                                                                                                                                        |

5483 The Controller starts the set-up procedure by sending the ENDXFER CCC with sub-command 0xF7 and the  
 5484 additional data byte, indicating the desired set of parameters. If the Controller uses the Direct version of  
 5485 ENDXFER, then the RnW bit shall be 1'b0 (WRITE) for the directly addressed Devices.

5486 Then the Controller sends the Direct ENDXFER CCC with sub-command 0xF7. It addresses each distinct  
 5487 recipient of the previous ENDXFER with the RnW bit set to 1'b1 (READ). Note that a READ command  
 5488 cannot be sent to a Group Address. Each addressed Device shall respond with its active additional data byte;  
 5489 if the value is identical to what was sent, then the Controller receives confirmation that the set-up is correct.  
 5490 If the value is different, then the Controller can repeat the ENDXFER CCC with the 0xF7 sub-command,  
 5491 using either the Broadcast version or the Direct version, with RnW set to 1'b0 (WRITE) for the directly  
 5492 addressed Devices.

5493 If the Controller determines that the set-up was successful, then it shall then send the ENDXFER CCC with  
 5494 sub-command 0xAA. If the Direct version of ENDXFER is used, then RnW is set to 1'b0 (WRITE) for the  
 5495 directly addressed Devices and the data is set to 0xAA (i.e., the sub-command value is reused for the data  
 5496 byte value, to facilitate error detection).

5497 The Controller then checks for correct receipt of the command by using the Direct ENDXFER CCC with  
 5498 sub-command 0xAA, and with RnW set to 1'b1 (READ), for each directly addressed Device (not for a Group  
 5499 Address). Each addressed Device shall respond with a data byte containing the additional data byte pertaining  
 5500 to ENDXFER sub-command 0xF7 that is currently active in its system. If this value is correct, then the  
 5501 Controller shall begin communications using the agreed-upon Data Transfer Early Termination procedure. If  
 5502 the value is not correct, then the Controller shall either abort the Data Transfer Early Termination procedure,  
 5503 or else repeat the set-up process.

5504 The Controller may start a new set-up at any time during the configuration process, or during the running  
 5505 stage, by sending an ENDXFER CCC with sub-command 0xF7 and a new additional data byte. The new set-  
 5506 up overwrites the old set-up.

### 5.2.2.3.5 Controller Ends or Continues the Read Transfer

The Controller has the option to either end, or continue, a Read transfer from the Target. The early ending can be done either with or without the CRC Word, as described in this Section.

**Note:**

*Per Table 64, the Controller's decision to continue the Read Transfer shall determine the Preamble Value of the next HDR-DDR Data Word, whereas the Controller's decision to end the Read Transfer is effectively a Preamble Value of 2'b10 followed by an HDR Restart Pattern or HDR Exit Pattern. See Figure 115, Figure 116, and Figure 117.*

*The procedures for ending the Read Transfer without the CRC Word and with the CRC Word are identical for the first 7 steps, as shown below. The Target shall determine whether to emit the CRC Word based on prior configuration using the ENDXFER CCC, per Section 5.2.2.3.4.*

#### 5517 Ending the Read Transfer without CRC Word

To end the DDR Read transfer, the Controller actively drives SDA Low before the C1 falling edge (i.e., while SCL is High), to signal the Target to stop returning data.

5520 **Figure 115** illustrates the ending of the Read transfer without the CRC Word, using numbered blue dots that 5521 correspond to the numbered steps below.

5522 The significant steps are:

- 5523 1. After the last parity bit (PAR0), the Target drives SDA High for the next Preamble bit (PRE1) 5524 which has the value 1'b1
- 5525 2. The Controller then:
  - 5526 a. On SCL, starts the Rising edge of clock pulse C1, and
  - 5527 b. Enables the Open Drain class Pull-Up structure on SDA
- 5528 3. Once t<sub>SCO</sub> elapses after C1's rising edge, the Target then:
  - 5529 a. Stops actively driving SDA, and
  - 5530 b. Releases SDA on High-Z
- 5531 4. After a time period longer than the Target's t<sub>SCO</sub>, the Controller starts driving SDA Low.

5532 One of the simplest ways to determine the necessary delay is to use a half cycle of the SCL clock. 5533 It could be even the full cycle, which would preserve the phase on the driver's logic block. The 5534 resultant SCL pulse is longer than the 50 ns that is required for coexistence on the Bus with 5535 Legacy I<sup>2</sup>C Devices. The signal waveform is a typical Repeated START; this is acceptable, since 5536 in the case of a Mixed Bus it is required to be followed by the HDR Exit Pattern and a STOP.

- 5537 5. After another delay similar to the one described in step 4, the Controller starts driving SCL Low, 5538 starting C1's falling edge
- 5539 6. The Target finds SDA being driven Low by the Controller, setting the second Preamble bit (PRE0) 5540 to 1'b0. Since this means the end of the Read transaction, the Target keeps SDA on High-Z.
- 5541 7. After another delay similar to the one described in step 4, the Controller starts driving SDA High 5542 in order to prepare for either the HDR Restart Pattern or the HDR Exit Pattern.

5543 At this point, SCL is Low and SDA becomes High (actively driven by the Controller), while the 5544 Target has both lines on High-Z

5545 At this point the Target-to-Controller Read data transfer has concluded.

**NOTE:**

The Target SDA change starts after the  $t_{SCO}$ , as shown by the vertical timing lines

The Controller drives SDA with a suitable delay, so as to achieve the set-up timing

— = Active Drive by Controller or Target

- - - - - = Open-Drain class Pull-Up by Controller

- - - - - = High-Z by Controller

- - - - - = High-Z by Target

5546

5547

5548

**Figure 115 Controller Ends DDR Read and Provides Either HDR Restart Pattern or HDR Exit Pattern**

**5549 Ending the Read Transfer with CRC Word**

5550 To end the DDR Read transfer, the Controller actively drives SDA Low before the C1 falling edge (i.e., while  
5551 SCL is High), to signal the Target to stop returning data and return the CRC Word.

5552 **Figure 116** shows the signal diagram for the case where the READ transfer ends with the Target providing  
5553 the CRC Word, with the 4'hC token. The figure uses numbered blue and red dots that correspond to the  
5554 numbered steps below.

5555 The significant steps are:

- 5556 1. After the last parity bit (PAR0), the Target drives SDA High for the next Preamble bit (PRE1),  
5557 which must be 1'b1
- 5558 2. The Controller:
  - 5559 a. Starts the SCL Rising edge of C1 clock pulse, and
  - 5560 b. Enables the Open Drain class pull-up structure on SDA
- 5561 3. Once tSCO elapses after the rising edge of C1, the Target then:
  - 5562 a. Stops the active drive of SDA, and
  - 5563 b. Releases SDA on High-Z
- 5564 4. After a period of time longer than the Target's tSCO, the Controller then starts driving SDA Low.  
One of the simplest ways to determine the necessary delay is to use a half cycle of the SCL clock.  
It could be even the full cycle, which would preserve the phase on the driver's logic block. The  
resultant SCL pulse is longer than the 50 ns required for coexistence with Legacy I<sup>2</sup>C Devices.  
The signal waveform is a typical Repeated START; this is acceptable, since in the case of a Mixed  
Bus it is required to be followed by the HDR Exit Pattern and a STOP.
- 5570 5. After another delay similar to that described in step 4, the Controller Starts driving SCL Low,  
5571 starting the falling edge of C1
- 5572 6. The Target then:
  - 5573 a. Finds SDA being driven Low by the Controller, setting the second Preamble bit (PRE0) to 1'b0
  - 5574 b. Since this condition means the end of the Read transaction, the Target preserves the SDA on  
5575 High-Z
- 5576 7. From this point on, the red bordered dots apply. After another delay similar to that described in step  
5577 4, the Controller starts driving SDA High. This can be done even immediately after the falling  
5578 edge of the C1, since it is under the Controller's control.
- 5579 8. The Controller has provided the rising edge of the first SCL of the CRC Word, CLK\_CRC1. Since  
5580 SDA was HIGH, the Target assesses the first bit of the CRC token as 1'b1.
- 5581 9. At the falling edge of CLK\_CRC1, the Target reads the second bit of the CRC token as 1'b1, since  
5582 the Controller was still driving SDA High.
- 5583 10. The Controller then drives SDA Low
- 5584 11. At the rising edge of CLK\_CRC2, the Target read the third bit of the CRC token as 1'b0, since the  
5585 Controller was driving SDA Low.
- 5586 12. After its tSCO the Target starts driving SDA Low, in parallel with the Controller (there is no  
5587 conflict, both lines are driven Low by the Devices).
- 5588 13. The Controller then:
  - 5589 a. Starts driving the falling edge of the CLK\_CRC2 Low, and
  - 5590 b. Releases SDA on High-Z
- 5591 14. The Target (and the Controller) reads the fourth bit of the CRC token as 1'b0, since the Target was  
5592 driving SDA Low
- 5593 15. After a period of time longer than the Target's tSCO, the Target starts driving SDA per the  
5594 calculated CRC. The Target has had enough time to switch its output to the calculated CRC  
5595 (almost two SCL clocks).

5596 At this point, the Read data transfer from the Target to the Controller has entered the CRC-based Ending Procedure.

5598 **Note:**

5599 Up until dot 7, the steps are identical to **Figure 115**. The numbered blue dots (steps 1–7) are the  
5600 same as ending the Read Transfer without the CRC Word, and the numbered red dots (steps 8–15)  
5601 show the additional steps for ending the Read Transfer with the CRC Word.



5602 **Figure 116 Controller Ends DDR Read and Target Provides CRC**

5603

**5604 Continuing the Read Transfer**

5605 To continue the DDR Read data transfer from the Target, the Controller allows SDA to remain High through  
5606 the C1 falling edge (i.e., while SCL goes from High to Low) at the start of the next HDR-DDR Data Word.

5607 **Figure 117** illustrates continuation of the Read data transfer, using numbered blue dots that correspond to the  
5608 numbered steps below.

5609 The significant steps are:

- 5610 1. After the last parity bit (PAR0), the Target drives SDA High for the next Preamble bit (PRE1)  
5611 which must have the value 1'b1
- 5612 2. The Controller then:
  - 5613 a. On SCL, starts the Rising edge of clock pulse C1, and
  - 5614 b. Enables the Open Drain class Pull-Up structure on SDA
- 5615 3. Once the Target's **tsco** elapses after C1's rising edge, the Target then:
  - 5616 a. Stops actively driving SDA, and
  - 5617 b. Releases SDA on High-Z
- 5618 4. At clock pulse C2's falling edge, the Target finds that SDA is High
- 5619 5. After the Target's **tsco** elapses, the Target then starts actively driving SDA for the payload's first  
5620 data bit (D0.7)
- 5621 6. After a suitable delay, the Controller then:
  - 5622 a. Disables the Open Drain class Pull-Up structure on SDA, and
  - 5623 b. Sets SDA on High-Z

5624 This delay shall be greater than or equal to Target's **tsco**. The start of C2's rising edge would be a  
5625 safe moment. Depending upon the Controller's design, a shorter delay could be used.

- 5626 7. After the Target's **tsco**, elapses, the Target starts driving SDA for the payload's second data bit  
5627 (D0.6)

5628 After step 7, the Target-to-Controller data transfer continues.

**NOTE:**

The Target SDA change starts after the  $t_{SCO}$ , as shown by the vertical timing lines

— = Active Drive by Controller or Target

- - - - - = Open-Drain class Pull-Up by Controller

— - - - - = High-Z by Controller

— · · · - = High-Z by Target

**Figure 117 Controller Continues DDR Read from Target**

### 5.2.2.3.6 Target Ends or Continues the Write Transfer

The Target has the option to either end, or continue, a Write transfer from the Controller. The early ending can be done either with or without the CRC Word, as detailed in this Section.

**Note:**

*Per Table 64, the Target's decision to continue or end the Write Transfer shall determine the Preamble Value of the next HDR-DDR Data Word. See Figure 118, Figure 119, and Figure 120.*

*The procedures for ending the Read Transfer without the CRC Word and with the CRC Word are identical for the first 6 steps, as shown below. The Controller shall determine whether to emit the CRC Word based on prior agreement with the Target(s) as configured with the ENDXFER CCC, per Section 5.2.2.3.4.*

#### Ending the Write Transfer without CRC Word

To end the DDR Write transfer, the Target actively drives SDA Low before the C1 falling edge (i.e., while SCL is High), to request the Controller to end the transfer.

**Figure 118** illustrates the ending of the Write transfer without the CRC Word, using numbered blue dots that correspond to the numbered steps below.

The significant steps are:

1. After the last parity bit (PAR0), the Controller drives SDA High for the next Preamble bit (PRE1) which must have the value 1'b1
2. The Controller then:
  - a. On SCL, starts the rising edge of clock pulse C1, and
  - b. Disables the active drive of SDA, and
  - c. Enables the Open Drain class Pull-Up structure on SDA
3. After the Target's t<sub>SCO</sub> elapses, the Target actively drives SDA Low
4. The Controller then:

*a. On SCL, starts the falling edge of clock pulse C1  
The Controller knows that SDA was pulled Low by the Target; therefore, PRE0 is 1'b0  
b. The Controller then starts actively driving SDA Low*

*At this point both the Controller and the Target are actively driving SDA Low, in parallel*

5. Once the Target's t<sub>SCO</sub> elapses, the Target releases SDA on High-Z
6. After a suitable delay, the Controller then starts actively driving SDA High

*One way to determine the necessary delay is to use one half of an SCL clock cycle.*

7. At this point, following another delay similar to the one in step 6:
  - a. SDA is High, actively driven by the Controller
  - b. SCL is Low, actively driven by the Controller
  - c. The Target has both SCL and SDA released on High-Z
  - d. The Controller can start either an HDR Restart Pattern, or an HDR Exit Pattern

At this point, the Controller-to-Target data transfer has concluded.



**NOTE:**

The Target SDA change starts after the  $t_{SCO}$ , as shown by the vertical timing lines  
The Controller drives SDA with a suitable delay, so as to achieve the set-up timing

- = Active Drive by Controller or Target
- - - - = Open-Drain class Pull-Up by Controller
- - - - = High-Z by Controller
- . . - = High-Z by Target

5667  
5668  
5669

**Figure 118 Target Requests DDR Write Termination and Controller Provides HDR Restart Pattern or HDR Exit Pattern**

**5670 Ending the Write Transfer with CRC Word**

5671 To end the DDR Write transfer, the Target actively drives SDA Low before the C1 falling edge (i.e., while  
5672 SCL is High), to request the Controller to end the transfer.

5673 **Figure 119** shows the signal diagram for the case where the WRITE transfer ends with the Controller  
5674 providing the CRC, with 4'hC token. The figure uses numbered blue and red dots that correspond to the  
5675 numbered steps below.

5676 The significant steps are:

- 5677 1. After the last parity bit (PAR0), the Controller drives SDA High for the next Preamble bit (PRE1)  
5678 which must be 1'b1
- 5679 2. The Controller then:
  - 5680 a. Starts the rising edge of C1, and
  - 5681 b. Disables the active drive of SDA, and
  - 5682 c. Enables the Open Drain class pull-up structure on SDA
- 5683 3. After the Target's t<sub>SCO</sub> elapses, the Target actively drives SDA Low
- 5684 4. The Controller then:
  - 5685 a. Starts the falling edge of C1, and
  - 5686 b. Knows that, since the Target pulled SDA Low, the PRE0 bit has value 1'b0; and
  - 5687 c. Starts actively driving SDA Low, in parallel with the Target
- 5688 5. After the Target's t<sub>SCO</sub> elapses, the Target releases SDA on High-Z
- 5689 6. From this point on, the red bordered dots apply. After a suitable delay, the Controller starts  
5690 actively driving SDA High.
- 5691 7. The Controller has provided the rising edge of the first SCL of the CRC Word (CLK\_CRC1).  
5692 Since SDA was HIGH, the Target reads the first bit of the CRC token as 1'b1.
- 5693 8. At the falling edge of CLK\_CRC1, the Target reads the second bit of the CRC token as 1'b1, since  
5694 the Controller was still driving SDA High.
- 5695 9. The Controller then drives SDA Low
- 5696 10. At the rising edge of CLK\_CRC2, the Target reads the third bit of the CRC token as 1'b0, since  
5697 the Controller drove SDA Low.
- 5698 11. At the falling edge of CLK\_CRC2, the Target (and the Controller) reads the fourth bit of the CRC  
5699 token as 1'b0, since the Target drove SDA Low.
- 5700 12. The Controller then starts driving the SDA per the calculated CRC.

5701 At this point, the WRITE data transfer from Controller to Target has entered the CRC-based Ending  
5702 Procedure.

**5703 Note:**

5704 *Up until dot 6, the transactions are identical to **Figure 118**. The numbered blue dots (steps 1–6) are  
5705 the same as ending the Write Transfer without the CRC Word, and the numbered red dots (steps 7–  
5706 12) show the additional steps for ending the Write Transfer with the CRC Word.*



5707

5708

**Figure 119 Target Requests DDR Write Termination and Controller Provides CRC**

**5709 Continuing the Write Transfer**

5710 To continue the DDR Write data transfer, the Target allows SDA to remain High through the C1 falling edge  
5711 (i.e., while SCL goes from High to Low) at the start of the next HDR-DDR Data Word.

5712 **Figure 120** illustrates continuation of the Write data transfer, using numbered blue dots that correspond to  
5713 the numbered steps below.

5714 The significant steps are:

- 5715 1. After the last parity bit (PAR0), the Controller drives SDA High for the next Preamble bit (PRE1)  
5716 which must have the value 1'b1

- 5717 2. The Controller then:

- 5718 a. On SCL, starts the rising edge of clock pulse C1, and
- 5719 b. Disables the active drive of SDA, and
- 5720 c. Enables the Open Drain class Pull-Up structure on SDA

- 5721 3. The Controller then:

- 5722 a. On SCL, starts the falling edge of clock pulse C1

5723 The Controller knows that the Target left SDA High; therefore, PRE0 is 1'b1

- 5724 b. The Controller then starts actively driving SDA High

- 5725 4. After a suitable delay, the Controller then starts actively driving SDA either High or Low, as  
5726 required for the payload's first data bit (D0.7).

5727 One simple way to determine the delay is to use one half of an SCL clock cycle.

- 5728 5. On SCL, the Controller then starts the rising edge of clock pulse C2.

5729 At this point, the Target has both SCL and SDA on High-Z

- 5730 6. The Target then registers the value of the payload's first data bit (D0.7)

- 5731 7. The Target then registers the value of the payload's second data bit (D0.6)

5732 After step 7, the Controller-to-Target data transfer continues.

**Figure 120 Target Continues the DDR Write From Controller**

#### 5.2.2.4 HDR-DDR Error Detection

5735 Four error types are defined for HDR-DDR Mode:

- 5736 1. Framing – the Preamble 2-bits before Command and Data shall be valid values per **Table 64**. This  
5737 supports a positional error detection mechanism:
- 5738     • A Command Word shall always follow the Enter HDR CCC and HDR Restart Pattern, and  
5739         shall never appear in any other position. It is an error condition for a Command Word to  
5740         appear in any other position, or to be missing where expected.
- 5741     • A Data Word shall always follow either a Command Word or another Data Word, and shall  
5742         never appear in any other position. It is an error condition for a Data Word to appear in any  
5743         other position, or to be missing where expected.
- 5744     • A single CRC Word shall always follow the last Data Word for a Command, such that it ends  
5745         the Message. As a result, a CRC Word shall always be followed by either the HDR Restart  
5746         Pattern or the HDR Exit Pattern. It is error condition for a CRC Word to appear in any other  
5747         position, or to be missing where expected.
- 5748     • The first nibble of a valid CRC shall contain the allowed value 4'hC. Any other value in the  
5749         first nibble should be considered a framing error.
- 5750 2. Parity encoding (for transmitters) parity checking (for receivers) shall be performed on all  
5751     Command Words and Data Words. Mismatched parity is an error condition.
- 5752 3. CRC-5 encoding (for transmitters) and CRC-5 checking (for receivers) shall be performed on all  
5753     payload bits for Command Words and Data Words. Mismatched CRC is an Error.
- 5754 4. NACK by the Target on a Read command is not a normal behavior (ACK is normal). The  
5755     Controller may choose to treat a NACK on a Read command as a possible framing error, and take  
5756     the actions detailed below.

5757 Any error detected by the Target should result solely in waiting for HDR Exit Pattern or HDR Restart Pattern  
5758 to be safe.

5759 If the Controller detects an error in a Read, then it shall issue SCL clocks until 19 SCL clocks (38 bits) have  
5760 been seen with SDA High. Because a continuous High run of this length cannot occur in a valid data  
5761 transmission, this ensures that the Target has released the line. The Controller shall emit either an HDR Exit  
5762 Pattern or an HDR Restart Pattern.

5763 **Note:**

5764     *The Controller can choose to treat the NACK of a Read command as a possible line error, and  
5765         therefore use the same approach in order to ensure that the Target is not driving the Bus.*

5766 If an error occurs in the RnW Bit during a Private Read Transfer, then the Write Data from the Controller  
5767 might conflict with the Read Data from the Target. Both the Controller and the Target should always monitor  
5768 the Data that they each transmit. If the Controller or Target performs such monitoring, and if the monitored  
5769 Data differs from the Data that the Controller or Target intended to send (except for Data transferred during  
5770 a Dynamic Address Arbitration procedure), then this shall be considered an error. After detecting this error,  
5771 both the Controller and the Target should stop the transmission; if they do so, then the Target shall wait for  
5772 an HDR Exit Pattern or HDR Restart Pattern. After the Controller sends the HDR Exit Pattern or HDR Restart  
5773 Pattern, then it may retry the transmission.

### 5.2.2.5 HDR-DDR CRC-5 Algorithm

The CRC-5 checksum is computed on a complete Message, including the Command Word and all Data Words.

- For a Command Word, the CRC-5 checksum is computed based on the value of the 16-bit payload, including:
  - The Read vs. Write bit
  - The Command Value
  - The Target Address, and
  - The lowest-order bit (Parity adjustment).
- For Data Words, the CRC-5 checksum is computed based on all Data 16-bit values transmitted for that Command.

The CRC-5 value is initialized to 0x1F. The CRC-5 polynomial is the same as used in [\[USB01\]](#):

$$\text{CRC5} = X^5 + X^2 + X^0$$

The reason why CRC-5 is adequate is that most errors will be caught by the Parity bits, or by incorrect Preamble bits. The Parity bits will detect runs of one, two, three, or more errors in a row. Any Clock errors not detected by the Parity bits would generally be detected as framing errors. That is, the Preamble would not match the allowed patterns, including 2'b01 leading into the CRC. As a result, any error that could be missed by the Parity bits will result in a shift of the CRC polynomial, and therefore will be detected as a CRC error. There would have to be two separated errors in the same Word, with either both errors occurring in even-index bits or with both errors occurring in odd-index bits, to produce correct Parity bits. However these two errors would not correct the CRC, and as a result would still be detected. Even with two such error pairs in two different Words, the probability of producing the same CRC value is very low, even though the CRC-5 checksum has only 32 possible values. Since any higher error density would render the I3C Bus generally unusable, it can be concluded that the protection that CRC-5 provides is sufficient for the use cases addressed by this Specification.

CRC-5 is specified in [\[USB01\]](#). Two versions of the logic for computing the CRC-5 checksum are shown below:

- First, for one bit at a time,
  - Second, for the more practical situation of two bits at a time (i.e., on SCL falling edge).
- ```

5803 // CRC5 builds from each bit as it comes in, using the registered SDA_r.
5804 // The next_CRC5 is registered on each cycle as CRC5[4:0].
5805 // But note that it would have to be on each SCL edge, so two
5806 // alternating buffers would be needed.
5807 assign next_crc0 = SDA_r ^ CRC5[4];
5808 assign next_CRC5[4:0] = {CRC5[3:2], next_crc0^CRC5[1],
5809                               CRC5[0],    next_crc0};

5810 // CRC5 builds from 2 bits at a time (registered d_rise_r and live d_fall),
5811 // on falling edge of SCL (by convention - could be on rising instead).
5812 // The d_fall could be d_fall_r, but then order must match input order
5813 // of the data bits.
5814 // The CRC therefore processes the two bits by combining the 2 bit shifts.
5815 // The next_CRC5 is registered on each cycle as CRC5[4:0]
5817 assign next_CRC5 = {CRC5[2], d_rise_r^CRC5[4]^CRC5[1], d_fall^CRC5[3]^CRC5[0],
5818                               d_rise_r^CRC5[4], d_fall^CRC5[3]};

```

### 5.2.3 HDR Ternary Modes (HDR-TSP / HDR-TSL)

This capability is not included in the I3C Basic Specification. To gain access to this capability, please contact MIPI Alliance. The following summary of information from the full I3C Specification is presented for the information of I3C Basic implementers.

The full version of the I3C Specification defines two HDR Modes that use Ternary Coding:

- **HDR-TSP:** Ternary Symbol for Pure Bus (no I<sup>2</sup>C Devices)
- **HDR-TSL:** Ternary Symbol Legacy-inclusive-Bus

In the full version of the I3C Specification these HDR Ternary Modes are entered in the standard way (see [Section 5.1.9.3.9](#)), followed by a Command and then zero or more Data Words.

In HDR Ternary Modes, Commands shall be issued only by a Controller, and Data Words may be issued by a Controller or by a Target, depending on the particular Command (Write or Read).

**Note:**

*Since an I3C Target Device that supports the I3C Basic Specification does not support these HDR Modes, it shall listen on the I3C Bus to detect whether the Active Controller uses the ENTHDR1 CCC or ENTHDR2 CCC (see [Section 5.1.9.3.9](#)), which indicates that the Bus has been switched into an HDR Mode that this I3C Target does not support. If the Active Controller sends either of these Broadcast CCCs, then such an I3C Target Device must enable its HDR Exit Pattern Detector (see [Section 5.2.1.1.3](#)) so it can detect and respond to the HDR Exit Pattern (see [Section 5.2.1.1.1](#)) which indicates that the Bus has returned to SDR Mode.*

### 5.2.4 HDR Bulk Transport Mode (HDR-BT)

HDR-BT is provided to give the highest possible throughput using a Clock-and-Data transmission model. Based on the number of SDA Lanes (4 for Quad Lane configuration, 2 for Dual Lane, or 1 for Single Lane), HDR-BT provides 8x, 4x, and 2x the raw SDR rate, respectively, at the same clock frequency. Real data rates are about 8.7x, 4.36x, and 2.18x SDR real data rates, and 4.8x, 2.4x, and 1.2x HDR-DDR real data rates. In particular, at 12.5 MHz HDR-BT can move real data at 97 Mbps (12 Mbytes/second) over Quad Lane (SDA[3:0]), and  $\frac{1}{2}$  and  $\frac{1}{4}$  that respectively for the Dual Lane and Single Lane configurations.

HDR-BT is an I3C HDR mode like the others. As a result, it is entered in the standard way (see the CCC ENTHDR3, *Section 5.1.9.3.9*) and exited via the HDR Exit Pattern. As with the other HDR modes, Messages while in the HDR-BT mode are separated using the HDR Restart pattern.

HDR-BT also brings other key features in addition to speed:

- CRC-16 (and optionally CRC-32) for data integrity.

Significantly, HDR-BT also has the receiver verify to the sender whether the transmitted CRC value for each Message Frame actually matched the CRC value calculated from the received data. This allows the transmitter to know with certainty whether it can release the buffer and proceed, or will have to re-send the data (whether immediately or scheduled for a later time).

- Allows the option for the Target to drive the SCL Clock during Read, when the Target supports it. This can be useful with long transmission lines, as there is no Clock-out to Data-in roundtrip time.
- Decouples Command and Control from Data, allowing division of labor between the Peripheral and system:
  - Fully supportive of classical I<sup>2</sup>C and I3C protocol models, including write of Index or Command byte (or bytes) preceding the Data (for write) or the Read request (for read)
  - Also appropriate for writing and reading file equivalents, where the command is the offset, using up to 32-bit offsets
- Uses a wide data block model to facilitate more natural processing for higher rate data.
  - In particular, because of the use of wide data blocks, HDR-BT is well suited to direct mapping to internal SRAM (e.g., 32-bit, 64-bit, etc.), wide internal buses (e.g., AXI, OCP, etc.), and Encryption/decryption cipher modes with inherent block sizes (e.g., 64-bit, 128-bit).
  - Although HDR-BT moves data in 32-byte data blocks, the last data block can “be ragged” and transmit fewer than 32 data bytes (i.e., 2, 4, 6, ... to 32 bytes).
- HDR-BT is consistent no matter how many Data Lanes are used (1, 2, or 4 SDA Lanes).
  - Further, HDR-BT is intended to allow a fully-registered interface on both sides – no combinatorial decisions required

While HDR-BT is primarily aimed at Multi-Lane Buses, it can also be used in a Single-Lane context, providing about 1.2x the real data rate of HDR-DDR. This provides the option of using a single high-rate protocol regardless of the number of data Lanes needed. The rest of this section will focus on Dual Lane and Quad Lane configurations, but HDR-BT protocol in Single Lane configuration works exactly the same – it just takes 2x or 4x more clocks to move the same amount of data.

The transport form of HDR-BT is purely byte-oriented. Unlike other I3C forms, the protocol has no extra bits, just a pure byte stream, even for control and data bytes.

The wire form of HDR-BT is a DDR style, meaning that the 1, 2, or 4 SDA Lanes change on each clock edge and are read on the following edge, using a Setup time model (vs. Hold):

- For the Controller on Write, which Drives the clock and data, this means the SDA(s) change(s) only after the SCL has completely transitioned (as with normal I3C).
- For the Target on Read, when only driving the SDA(s) but not SCL, the SDA(s) change(s) only after the SCL change has been received/detected.
- For the Target on Read, when the Target is driving both clock and data, this means the SDA(s) change(s) only after the SCL has completely transitioned.

Signal diagrams for starting HDR-BT Mode transfers are shown in **Figure 121** and **Figure 122**. **Figure 121** shows the HDR-BT Header Block (see **Section 5.2.4.3.1**) after ENTHDR3, and **Figure 122** shows the HDR-BT Header Block after the HDR Restart Pattern.



**Figure 121 HDR-BT Header Block After ENTHDR3**



**Figure 122 HDR-BT Header Block After HDR Restart Pattern**

**Note:**

Both **Figure 121** and **Figure 122** are derived from the edge-triggering examples shown in **Section 5.2.1.3**. In both cases, the Controller positions SDA[0] (i.e., SDA) after the falling SCL edge, and before the SCL rising edge labeled “C1”. This bit shall be read by the addressed Target (or Group) as Bit[0] of the Target Address, which is the “RnW” bit for the transfer (per **Section 5.2.4.3**). The HDR-BT Header Block is always sent according to the Lane configuration of the currently configured HDR-BT Data Transfer Coding for Multi-Lane (see **Section 5.3.2.4.1**) which is a global setting for the I3C Bus, using the defined Bit Packing for Data Bytes and Transition Bytes.

**Figure 123** illustrates a typical HDR-BT Mode Frame with two HDR-BT transfers and associated data:

- I3C START or Repeated START
- I3C CCC to Enter HDR-BT Mode
- After entering HDR-BT Mode, there is one HDR-BT transfer. It starts with an HDR-BT Header Block, followed by one or more HDR-BT Data Blocks, and then an HDR-BT CRC Block.
- Then an HDR Restart Pattern, followed by another HDR-BT transfer having a similar flow.
- Finally, HDR-BT Mode is ended via the HDR Exit Pattern followed by I3C STOP.



**Figure 123 Typical HDR-BT Mode Frame**

**Note:**

See **Section 5.2.4.3** for more details on the HDR-BT structured protocol elements that comprise transfers in HDR-BT Mode.

### 5.2.4.1 SDA Lane Bit Packing: Data Bytes (Commands, Data, CRC)

5911 On the SDA[x] Lanes, HDR-BT always packs bytes of Data in the same way, based on number of Lanes as  
5912 shown in *Table 70* through *Table 72*.

5913 Note that Transition control packing is different, per *Section 5.2.4.2*.

5914 **Note:**

5915 *Unlike SDR Mode, the bits are transmitted starting with LSb and progressing to MSb.*

5916 **Table 70 Data Byte Bit Packing: Single Lane**

| SDA Lane | Clock 0 |      | Clock 1 |      | Clock 2 |      | Clock 3 |      |
|----------|---------|------|---------|------|---------|------|---------|------|
| SDA[0]   | Bit0    | Bit1 | Bit2    | Bit3 | Bit4    | Bit5 | Bit6    | Bit7 |

5917 **Table 71 Data Byte Bit Packing: Dual Lane**

| SDA Lane | Clock 0 |      | Clock 1 |      |
|----------|---------|------|---------|------|
| SDA[0]   | Bit0    | Bit2 | Bit4    | Bit6 |
| SDA[1]   | Bit1    | Bit3 | Bit5    | Bit7 |

5918 **Table 72 Data Byte Bit Packing: Quad Lane**

| SDA Lane | Clock 0 |      |
|----------|---------|------|
| SDA[0]   | Bit0    | Bit4 |
| SDA[1]   | Bit1    | Bit5 |
| SDA[2]   | Bit2    | Bit6 |
| SDA[3]   | Bit3    | Bit7 |

### 5.2.4.2 SDA Lane Bit Packing: Transition Bytes

HDR-BT always packs bytes of Transition content, whether pure Transition or Transition and Control, in a consistent way. In particular, the SDA[0] Lane always follows the I3C “Park1,High-Z” convention for the first two half-clocks of the byte. As a result, SDA[0] is always 1 (Parked) for the rising SCL edge, and then treated as High-Z for the falling SCL edge, to enable flow control.

To keep things simple, the convention is to treat the “Park1” and “High-Z” as Bit[0] and Bit[1] of the byte, with the low-level logic handling the repositioning based on number of Lanes as shown in **Table 73** through **Table 75**. That is, the byte received will have 2’b11 in Bits[1:0] when the High-Z was not driven Low, with the remaining bits representing the content.

When compared with the bit packing for data bytes, the transition bytes change as follows:

- **For Single Lane:** No changes, since all Bits are sent in order.
- **For Dual Lane:** Bit[2] is sent where Bit[1] would typically be sent for a data byte (i.e., the rising edge of SDA[1] for Clock 0).
- **For Quad Lane:** Bit[4] is sent where Bit[1] would typically be sent for a data byte (i.e., the rising edge of SDA[1] for Clock 0).

**Table 73 Transition Byte Bit Packing: Single Lane**

| SDA Lane                                                                              | Clock 0 |        | Clock 1 |      | Clock 2 |      | Clock 3 |      |
|---------------------------------------------------------------------------------------|---------|--------|---------|------|---------|------|---------|------|
| SDA[0]                                                                                | Park1   | High-Z | Bit2    | Bit3 | Bit4    | Bit5 | Bit6    | Bit7 |
| <b>Note:</b>                                                                          |         |        |         |      |         |      |         |      |
| Compared to a data byte, Bits[7:2] are unchanged. See <b>Table 70</b> for comparison. |         |        |         |      |         |      |         |      |

**Table 74 Transition Byte Bit Packing: Dual Lane with Bit2 Swizzle**

| SDA Lane                                                                                                                                                                                                                           | Clock 0           |        | Clock 1 |      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------|---------|------|
| SDA[0]                                                                                                                                                                                                                             | Park1             | High-Z | Bit4    | Bit6 |
| SDA[1]                                                                                                                                                                                                                             | Bit2 (See Note 1) | Bit3   | Bit5    | Bit7 |
| <b>Note:</b>                                                                                                                                                                                                                       |                   |        |         |      |
| 1. Bit2 takes the typical place for Bit1 (i.e., for a data byte), since the High-Z bit on SDA[0] is always Bit1 for a transition byte.<br>2. Compared to a data byte, Bits[7:3] are unchanged. See <b>Table 71</b> for comparison. |                   |        |         |      |

**Table 75 Transition Byte Bit Packing: Quad Lane with Bit4 Swizzle**

| SDA Lane                                                                                                                                                                                                                                         | Clock 0           |        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------|
| SDA[0]                                                                                                                                                                                                                                           | Park1             | High-Z |
| SDA[1]                                                                                                                                                                                                                                           | Bit4 (See Note 1) | Bit5   |
| SDA[2]                                                                                                                                                                                                                                           | Bit2              | Bit6   |
| SDA[3]                                                                                                                                                                                                                                           | Bit3              | Bit7   |
| <b>Note:</b>                                                                                                                                                                                                                                     |                   |        |
| 1. Bit4 takes the typical place for Bit1 (i.e., for a data byte), since the High-Z bit on SDA[0] is always Bit1 for a transition byte.<br>2. Compared to a data byte, Bits[3:2] and Bits[7:5] are unchanged. See <b>Table 72</b> for comparison. |                   |        |

### 5.2.4.3 HDR-BT Mode Structured Protocol Elements

5936 The main structuring of the HDR-BT mode is broken into 3 top-level units:

| <b>Header Block</b><br>7 bytes | <b>N * Data Blocks</b><br>Each block is 32 bytes data + 1 byte control | <b>CRC-16 or CRC-32</b><br>6 bytes |
|--------------------------------|------------------------------------------------------------------------|------------------------------------|
| Target may emit SCL if Read    |                                                                        |                                    |

5937 Where:

- The **Header** indicates the Target (or Group) and the Direction for the transfer, as well as 4 bytes optionally associated with command/index/offset and/or expected length.

5940 This follows the normal I<sup>2</sup>C and I3C protocol of the first byte(s) on Write being the  
 5941 index/command, and Write preceding Read containing the index/command.

5942 **Note:**

5943 *The actual interpretation is a contract between Controller and Target.*

- **Data** is 0 or more 32-byte Data Blocks. The *processed* length of the last block may be ragged.  
 5945 Data Blocks use 33 bytes for each 32 bytes of real data, with one byte used for transition and  
 5946 control.
- **CRC** shall be either a CRC-16 or a CRC-32 verification at the end of the Message, occupying 6  
 5948 bytes. The selection between CRC-16 and CRC-32 shall be made by the Controller, and shall be  
 5949 indicated in the Header.

### 5.2.4.3.1 Header Block

5950 The Header Block shall be 7 bytes in length, formed as 6 bytes + 1 Transition byte:

| Byte 0  | Byte 1 | Byte 2 | Byte 3 | Byte 4 | Byte 5  | Byte 6     |
|---------|--------|--------|--------|--------|---------|------------|
| Address | Cmd0   | Cmd1   | Cmd2   | Cmd3   | Control | Transition |

5951 Where:

- 5952 • **Address** shall be either:
  - 5953 • The 7-bit I3C Dynamic Address of the Target to be addressed for this transfer, in Bits[7:1], with Bit[0] = 0 for a Write, or = 1 for a Read; **or**
  - 5954 • A valid 7-bit Group Address (if assigned and supported) in Bits[7:1], with Bit[0] set to 0 (as this case is always a Write); **or**
  - 5955 • The I3C Broadcast Address (i.e., 7'h7E), which indicates framing for CCC transmission in HDR-BT Mode (per *Section 5.2.4.4*).
- 5956 • **Cmd0** to **Cmd3** may be used as the indicator to the Target (or Group) as to the meaning/context of the data:
  - 5957 • If **Address** is a Dynamic Address or Group Address (i.e., is not 7'h7E), then this transfer is a generic Write or Read transfer.
  - 5958     For a generic Write or Read transfer, fields **Cmd0** through **Cmd3** would typically be used as with standard I3C SDR protocols, for command/index/offset and length (actual or maximum), but the exact meaning is a contract between the Controller and the Target (or all Targets in an assigned Group).
  - 5959 • If **Address** is 7'h7E (as defined above), then per *Section 5.2.4.4* this is a CCC.
    - 5960 • If this is the first HDR-BT Header Block with Address 7'h7E, then **Cmd0** shall be the CCC Code, and the Controller starts the CCC modality.
    - 5961 • Subsequent HDR-BT Header Blocks shall comprise CCC flows, until the Controller exits the CCC modality by using a valid HDR-BT CCC End Procedure per *Section 5.2.4.4.7*.

5962     **Note:**

5963         *Per Table 16, only some CCCs may be used in HDR-BT Mode.*

- 5964 • **Control** is a byte and shall be formatted thus:
  - 5965 • **Bit[0]** = 0 for a Write, or = 1 for a Read. It shall match **Address** Bit[0].
  - 5966 • **Bit[1]** = 0 if CRC-16 is used, or = 1 if CRC-32 is used.
    - 5967 • The Controller shall not select CRC-32 if the addressed Target (or Group) does not support CRC-32.
    - 5968 • The Target shall not accept a Message indicating CRC-32 if it does not support CRC-32. (If **Address** indicates a Group Address, then all Targets assigned to that Group Address must support CRC-32.)
  - 5969 • **Bit[2]**:
    - 5970 • **For a Read**, Bit[2] = 0 if the Controller transmits SCL, or = 1 if the Target transmits SCL.
 

5971     The Controller shall not select “Target transmits SCL” unless the Target supports it. The Target shall not accept a Message indicating that it supplies SCL if it does not actually support driving SCL.
    - 5972 • **For a Write**, Bit[2] is Reserved and shall be set to 1'b0.
    - 5973 • **Bit[3]** = 0 for a normal Message, or = 1 for a continuation of a Direct CCC (GET or SET).
    - 5974 • **Bits[5:4]** are Reserved and shall be set to 2'b00.

- 5990 • Bits[7:6] = Parity 0 and Parity 1 on the whole Header (up through this **Control** byte), using the  
 5991 even and odd positioned bits respectively. This follows a model similar to HDR-DDR (see  
 5992 *Section 5.2.2.1*), using an XOR function:

5993 Bit[6] = Parity of the even index bits, from Header Bytes 0 through 5, and 1:

$$\begin{aligned} & \mathbf{Address}[0] \wedge \mathbf{Address}[2] \wedge \mathbf{Address}[4] \wedge \mathbf{Address}[6] \wedge \\ & \mathbf{Cmd0}[0] \wedge \mathbf{Cmd0}[2] \wedge \mathbf{Cmd0}[4] \wedge \mathbf{Cmd0}[6] \wedge \\ & \mathbf{Cmd1}[0] \wedge \mathbf{Cmd1}[2] \wedge \mathbf{Cmd1}[4] \wedge \mathbf{Cmd1}[6] \wedge \\ & \mathbf{Cmd2}[0] \wedge \mathbf{Cmd2}[2] \wedge \mathbf{Cmd2}[4] \wedge \mathbf{Cmd2}[6] \wedge \\ & \mathbf{Cmd3}[0] \wedge \mathbf{Cmd3}[2] \wedge \mathbf{Cmd3}[4] \wedge \mathbf{Cmd3}[6] \wedge \\ & \mathbf{Control}[0] \wedge \mathbf{Control}[2] \wedge \mathbf{Control}[4] \wedge 1 \end{aligned}$$

6000 Bit[7] = Parity of the odd index bits, from Header Bytes 0 through 5:

$$\begin{aligned} & \mathbf{Address}[1] \wedge \mathbf{Address}[3] \wedge \mathbf{Address}[5] \wedge \mathbf{Address}[7] \wedge \\ & \mathbf{Cmd0}[1] \wedge \mathbf{Cmd0}[3] \wedge \mathbf{Cmd0}[5] \wedge \mathbf{Cmd0}[7] \wedge \\ & \mathbf{Cmd1}[1] \wedge \mathbf{Cmd1}[3] \wedge \mathbf{Cmd1}[5] \wedge \mathbf{Cmd1}[7] \wedge \\ & \mathbf{Cmd2}[1] \wedge \mathbf{Cmd2}[3] \wedge \mathbf{Cmd2}[5] \wedge \mathbf{Cmd2}[7] \wedge \\ & \mathbf{Cmd3}[1] \wedge \mathbf{Cmd3}[3] \wedge \mathbf{Cmd3}[5] \wedge \mathbf{Cmd3}[7] \wedge \\ & \mathbf{Control}[1] \wedge \mathbf{Control}[3] \wedge \mathbf{Control}[5] \end{aligned}$$

6007 **Note:**

6008     *The Controller shall compute the Parity for all other bits in the Header Block, including any  
 6009 reserved fields; but not for any fields in the following Transition byte, which would not yet  
 6010 have been sent on the SDA Lane(s) by the time the Control byte was sent.*

- 6011 • **Transition** occupies one byte, and shall use the SDA[0] Line for the first 2 half-clocks, and shall  
 6012 follow the I3C “Park1,High-Z” approach for Bus transition and acceptance (see *Section 5.2.4.2*).
  - 6013 • **Bits[1:0]:**
    - 6014 • Bit[0] as SDA[0]’s first half-clock shall be Parked High by the Controller
    - 6015 • Bit[1] as SDA[0]’s second half-clock shall be High-Z by Controller; the Target (or all  
 6016 Targets in the Group) shall either drive it Low in order to accept the Write or Read, or else  
 6017 leave it undriven to not accept (see *Section 5.2.4.7*).

6018 **Note:**

6019     *If there is a Read request, and if the Target sources the Clock, then the Controller shall  
 6020 also release the clock during the second half-clock period if the Target is accepting (i.e.,  
 6021 if SDA[0] is driven to zero), so that the Target drives the next Edge.*

6022     *The SCL handoff follows the convention that if the Target is accepting, then it shall  
 6023 drive/hold the SCL line High (i.e., the same as the Controller) during this half-clock, so  
 6024 that they overlap.*

6025     *If the Target does not drive the clock within  $t_{BT\_HO}$  (i.e., the HDR-BT handoff period)  
 6026 after accepting, then the Controller shall regain control.*

- 6027 • **Bit[2]:**
  - 6028 • **For a Read:**
    - 6029 • Bit[2] = 0 indicates that the Target is permitted to use the Data Block Delay  
 6030 mechanism if it needs extra time to prepare data to return for the Read transfer. See  
 6031 *Section 5.2.4.3.4* for more details.
    - 6032     The Controller may not use Bit[2] = 0 if it already allowed or previously  
 6033 configured another Target to terminate a long transfer (per  
 6034 *Section 5.2.4.3.4*).
    - 6035 • Bit[2] = 1 indicates that the Target may not use Data Block Delay for this read  
 6036 transfer.
    - 6037 • **For a Write**, Bit[2] is Reserved and shall be set to 1’b0
    - 6038 • **Bits[7:3]** are Reserved and shall be set to 5’d0

### 5.2.4.3.2 Data Blocks

6039 Each Data block shall be formed as 33 bytes:

| Transition_Control | Data 0 to 31 |
|--------------------|--------------|
|--------------------|--------------|

6040 Where:

- 6041 • **Transition\_Control** occupies one byte, and shall use the SDA[0] line for the first two half-clocks,  
6042 and follows the I3C “Park1,High-Z” approach for termination by the receiver (see  
6043 [Section 5.2.4.2](#)).
- 6044 • **Bits[1:0]**:
  - 6045 • Bit[0] as SDA[0]’s first half-clock shall be Parked High by the transmitter of the data (i.e., by  
6046 the Controller for a Write, or by the Target for a Read).
  - 6047 • Bit[1] as SDA[0]’s second half-clock shall be High-Z’ed by the transmitter of the data (i.e., by  
6048 the Controller for a Write, or by the Target for a Read). The receiver may drive SDA[0] Low to  
6049 terminate the transmission, otherwise the receiver leaves it undriven to allow the data to  
6050 continue normally.

6051 **Note:**

6052     *If terminated, then the transmitter will emit a CRC Block as the next byte (see*  
6053     *Section 5.2.4.7)*.

- 6054 • **Bit[2]** = 0 if not the Last Data Block, or = 1 if the Last Data Block before the CRC Block.
- 6055 • **Bit[3]** = Odd Parity of this **Transition\_Control** byte bits [2] to [7]. This is not parity of the data.  
6056     The data validity is handled by the CRC at the end (i.e., in the CRC Block; see [Section 5.2.4.3.3](#)).

6057 **Note:**

6058     *If the Transition\_Control parity does not match, or if the “Park1” is not 1, then there is a*  
6059     *framing error. The High-Z may be 0 if the other side has terminated or if a separate*  
6060     *Target was permitted to terminate and has done so. See Section 5.2.4.3.4 for details.*

6061 If this is the Last Data Block before the CRC Block, then:

- 6062 • **Bits[7:4]** = Byte-pairs in Data Block minus 1 (i.e., 0xF if all 32, or 0x0 for 2 bytes)

6063 If this is not the Last Data Block, then:

- 6064 • **Bits[7:5]** are Reserved and shall be set to 3’d0
- 6065 • **Bit[4]**:

6066     • **For a Read:**

- 6067       • Bit[4] = 0 indicates that the Target (as transmitter) is sending a valid Data Block.
- 6068       • Bit[4] = 1 indicates that the Target (as transmitter) is using the Data Block Delay  
6069       mechanism, to delay sending the next Data Block in this transfer. The Target  
6070       may only use the Data Block Delay mechanism if the Controller indicated that  
6071       the Target was permitted to do so (i.e., if it sent the **Transition** byte with Bit[2] =  
6072       0 in the Header Block for this Read transfer; see [Section 5.2.4.3.4](#) for more  
6073       details).

- 6074       • **For a Write:** Bit[4] shall be set to 0.

- 6075 • **Data** shall be transmitted from Byte 0 to Byte 31

6076 **Note:**

6077     *For the Last Data Block, the receiver shall ignore padding Bytes past the ragged length. These extra*  
6078     *bytes should be set to 8’d0, but may contain any value.*

6079 **Note:**

6080     *It is recommended for the Last Data Block length to match the receiver’s natural data width, such as*  
6081     *32 bits or 64 bits to match internal memory or buses. Further, if the data is encrypted, then the*  
6082     *encryption algorithm’s blocking size should be considered (e.g., 128-bit for AES).*

### 5.2.4.3.3 CRC Block

6083 The CRC Block is formed as 6 bytes:

| Byte 0  | Byte 1 | Byte 2 | Byte 3            | Byte 4            | Byte 5            |
|---------|--------|--------|-------------------|-------------------|-------------------|
| Control | CRC0   | CRC1   | CRC2<br>if CRC-32 | CRC3<br>if CRC-32 | Transition_Verify |

6084 Where:

- **Control** is a byte that indicates that this CRC Block is not another Data Block, since Bit[0] is 0 (Low) instead of 1 (i.e., Parked High).

6087 The CRC Block should be expected, since either the previous Data Block indicated it was the Last Data Block, or else the transfer was terminated (i.e., High-Z driven Low by the receiver).

6089 The **Control** byte also verifies the CRC type previously selected in the Header Block, and whether 6090 the previous Data Block was a Last Data Block, or was Terminated.

6091 Therefore, the **Control** byte shall contain:

- **Bits[2:0]** = 3'b0 always.
- **Bit[3]** = Odd Parity of this **Control** byte's Bits[7:2]

6094 **Note:**

6095     *If the parity does not match, or if Bit[0] is not = 0, or if Bit[1] is not = 0, then there is a framing 6096     error.*

- **Bit[4]** = 0 always
- **Bit[5]** = Same value as the Header Block's **Control** byte, Bit[1]: 1'b0 for CRC-16, or 1'b1 for CRC-32.

6100 **Note:**

6101     *If this value does not match the value from the Header bit, then there is an error.*

- **Bit[6]** = 0 if the transaction ended normally, or = 1 if the previous Data Block was terminated (i.e., if its High-Z was driven to 0 by the receiver).

6104 **Note:**

6105     *If this bit does not agree with what the receiver believes actually happened, then there is an 6106     error. That is, if the receiver did not see the last Data Block terminated (either by itself, or by 6107     a separate Device), and the transmitter says it was terminated, then there is an error.*

6108     *Likewise, if the receiver did not see the last Data Block marked as Last, but the transmitter 6109     says it ended normally, then there is an error.*

- **Bit[7]** = Reserved and shall be set to 1'b0.

- Bytes **CRC0** to **CRC3** shall contain the value of the specified CRC algorithm, as computed by the transmitter: either CRC-16, or CRC-32 (if supported).

The transmitter shall calculate the checksum based on the valid contents of all previous Data Blocks that were sent before this CRC Block, using the following requirements:

- For each Data Block except the Last Data Block, this includes the entire 33-byte contents of the Data Block (i.e., the value in the **Transition\_Control** byte, as well as all 32 Data bytes).
- For the Last Data Block, this includes the **Transition\_Control** byte, as well as the number of valid Data bytes in the Last Data Block (i.e., as indicated by the number of byte-pairs, sent in Bits[7:4] of the **Transition\_Control** byte). However, any padding bytes in the Last Data Block shall be ignored.
- In either case, all bits in the **Transition\_Control** byte shall always be included, even if the receiver terminates the transfer during the **Transition\_Control** byte (i.e., by driving SDA[0] to Low).
  - For terminated transfers, the actual values driven on the SDA[0] Lane shall be used, and the transmitter shall include only the **Transition\_Control** byte. Note that the transmitter will start emitting a CRC Block as the next byte after the **Transition\_Control** byte, if the receiver terminates the transfer (see **Section 5.2.4.3.2**).

In this case, for the purposes of checksum calculation, the transmitter shall not include any subsequent data bytes that it intended to send, but would have been skipped due to a terminated transfer.

The following structured protocol elements shall not be included in the checksum calculation:

- The Header Block shall be ignored.
- If this is a Read transfer, and if the Target (as transmitter) was permitted to use the Data Byte Delay mechanism (see **Section 5.2.4.3.4**), then the transmitter shall ignore any Delay bytes that it might send in place of valid Data Blocks. Only valid Data Blocks shall be used in the calculation of the checksum.
- The **Control** byte in the CRC Block shall be ignored.

The receiver shall also calculate the checksum based on the same requirements, as it receives each Data Block during the transfer.

**If Bit[1] in the Header Block's Control byte is 1'b0, then the transmitter shall use CRC-16:**

For CRC-16, the generator polynomial is:

$$X^{16} + X^{15} + X^2 + 1$$

**Note:**

*For shift register implementations, this polynomial is expressed as 0x8005 in big-endian notation, or 0xA001 in little-endian notation.*

- The initial value is all 1s (i.e., 0xFFFF).
- The natural bit order of data in HDR-BT Mode is little endian, so Bytes 1 and 2 (fields **CRC0** and **CRC1**) shall contain the calculated checksum:
  - Byte 1 (**CRC0**) shall contain bits[7:0] of the checksum
  - Byte 2 (**CRC1**) shall contain bits[15:8] of the checksum
- Bytes 3 and 4 (fields **CRC2** and **CRC3**) shall contain all 0s.

6152     **If Bit[1] in the Header Block's Control byte is 1'b1, then the transmitter shall use CRC-32:**

6153     For CRC-32, the generator polynomial is:

6154      $X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$

6155     **Note:**

6156       *For shift register implementations, this polynomial is expressed as 0x04C11DB7 in*  
 6157       *big-endian notation, or 0xEDB88320 in little-endian notation.*

- 6158     • The initial value is all 1s (i.e., 0xFFFFFFFF).
- 6159     • The natural bit order of data in HDR-BT Mode is little-endian, so Bytes 1 through 4 (fields  
 6160       **CRC0** through **CRC3**) shall contain the calculated checksum, as follows:
  - 6161       • Byte 1 (**CRC0**) shall contain bits[7:0] of the checksum
  - 6162       • Byte 2 (**CRC1**) shall contain bits[15:8] of the checksum
  - 6163       • Byte 3 (**CRC2**) shall contain bits[23:16] of the checksum
  - 6164       • Byte 4 (**CRC3**) shall contain bits[31:24] of the checksum

6165     **Example CRC Checksum Calculations**

6166     Table 76 presents example CRC checksum calculations as a reference. All values are presented  
 6167     using big-endian notation, and the CRC-16 and CRC-32 values are based on the initial value of all  
 6168     1s. For each example it is assumed that the CRC checksum is calculated from a data message  
 6169     having a single byte.

6170     **Table 76 Example CRC Checksum Calculations**

| Data Byte | CRC-16 | CRC-32     |
|-----------|--------|------------|
| 0x00      | 0x40BF | 0x2DFD1072 |
| 0x91      | 0xEC7E | 0xAAF5B3A0 |
| 0xF7      | 0xC6FE | 0x0E2477CD |

6171     **Note:**

6172       *In the examples above, the computed checksum after the single data byte could also be viewed*  
 6173       *as the state after processing the first byte of a longer message. The example for data byte 0xF7 is*  
 6174       *relevant, as this matches the expected value of the Transition\_Control byte for a Last Data Block*  
 6175       *that contains 32 valid data bytes (see Section 5.2.4.3.2).*

- 6176 • The **Transition\_Verify** byte serves two purposes:
  - 6177 • For a Read, it is used to hand the SDA[x] lines off, back to the Controller; similarly, if the  
6178 Target is sourcing SCL, then **Transition\_Verify** allows handing the SCL sourcing role back as  
6179 well.
  - 6180 • For a Read or Write, it allows the receiver (which could be either the Controller or the Target)  
6181 to verify that the value provided in the **CRC** field (i.e., sent in fields **CRC0** through **CRC3**)  
6182 matched the output of the selected CRC algorithm, and therefore that the Message was  
6183 correctly received. The receiver shall use the same method for computing the CRC checksum  
6184 as the transmitter, by using the valid contents of all received Data Blocks (as defined above).

6185     **Transition\_Verify** shall use the SDA[0] line for the first two half-clocks, and shall follow  
6186 the I3C “Park1,High-Z” approach for completion by the receiver (see *Section 5.2.4.2*).

- 6187 • **Bits[1:0]**:
  - 6188 • Bit[0] as SDA[0]’s first half-clock shall be Parked High by the transmitter of the data (i.e.,  
6189 by the Controller for a Write, or by the Target for a Read).
  - 6190 • Bit[1] as SDA[0]’s second half-clock shall be High-Z’ed by the transmitter of the data  
6191 (i.e., by the Controller for a Write, or by the Target for a Read).

6192     To confirm that the CRC field value matched the output of the selected CRC  
6193 algorithm, the receiver shall drive SDA[0] Low. Alternatively, if the CRC did  
6194 not match, then the receiver shall leave the SDA[0] line undriven (and therefore  
6195 High) for Bit[1].

6196 **Note:**

6197     *If the Target was driving the SCL during a Read, then it shall hand off the SCL on the  
6198 second half-clock. The Controller shall drive/hold the SCL line High during this second  
6199 half-clock, matching the Target, and then drive the next SCL clock edge.*

6200     *For error handling, if the Target stops driving the Clock for more than  $t_{BT\_FREQ}$ , then the  
6201 Controller will take over the clock. This would happen in the event that the Controller  
6202 has lost framing due to an error.*

- 6204 • **Bits[4:2]** = 3’b0 always.

6205 **Note:**

6206     *Due to the different bit packing schemes for HDR-BT transition bytes (which depend on  
6207 the Multi-Lane configuration of the addressed Target or Group for a transfer) these bits  
6208 cannot be usable for any meaningful purpose by the receiver, and thus may never be  
6209 used by the receiver to indicate any post-transfer status or subsequent actions.*

- 6210 • **Bits[7:5]**:

- 6211 • Reserved for future use by MIPI I3C WG. These bits shall be set to 3’d0.

6212     **For HDR-BT Read transfers**, the Target shall release SDA[0] after the second half-clock (i.e.,  
6213     Bit[1]). Subsequent actions shall depend on the bit packing scheme, per **Section 5.2.4.2**, as  
6214     follows:

- 6215     • **If the Target was configured to use a bit packing scheme with multiple clock cycles (i.e.,  
6216        Single Lane or Dual Lane):** If the Controller (as receiver) does not verify the transfer and  
6217        leaves SDA[0] undriven for the second half-clock, then it shall pull SDA[0] Low after Bit[1]  
6218        (i.e., the following half-clock), unless it loses framing or there is an error.
- 6219     • **If the Target was configured to use a bit packing scheme with a single clock cycle (i.e., Quad  
6220        Lane):** If the Controller (as receiver) does not verify the transfer and leaves SDA[0] undriven  
6221        for the second half-clock, then SDA[0] shall remain High through the end of the  
6222        **Transition\_Verify** byte. After this, the CRC Block ends and the Controller typically drives  
6223        either the HDR Restart Pattern or the HDR Exit Pattern.

6224     **For HDR-BT Read transfers that use additional Data Lanes**, the Target shall drive these Data Lanes  
6225     (e.g., SDA[1:3]) to Low for the first half-clock, and then High-Z these Lanes for the second half-  
6226     clock (i.e., along with the High-Z of SDA[0]). If the Target was providing SCL clock, then this  
6227     coincides with the handoff of SCL and SDA[0] to the Controller (as receiver). Unless the  
6228     Controller encounters a framing issue and must use an error recovery procedure (i.e., without  
6229     verifying the Read transfer), the Controller shall take ownership of these additional Data Lanes for  
6230     the second half-clock, and shall drive them Low at the appropriate time to either verify or not  
6231     verify the transfer.

6232     **For HDR-BT Write transfers**, the Controller (as transmitter) shall drive SDA[0] to Low as required  
6233     by the configured bit packing scheme, after providing the receiver (i.e., the addressed Target or  
6234     Group) an opportunity to verify the transfer for the second half-clock. After this opportunity, the  
6235     Controller shall control and drive SDA[0] as required by the bit packing scheme to ensure that  
6236     Bits[4:2] are always 3'd0:

- 6237     • **If the receiver was configured to use a bit packing scheme with multiple clock cycles (i.e.,  
6238        Single Lane or Dual Lane):** If the receiver does not verify the transfer and leaves SDA[0]  
6239        undriven (i.e., High) for the second half-clock, then the Controller shall pull SDA[0] Low  
6240        after Bit[1] (i.e., the following half-clock); and subsequently shall either hold SDA[0] Low  
6241        through the end of the **Transition\_Verify** byte, or optionally (i.e., by prior agreement and  
6242        configuration) High-Z or drive to High SDA[0] as needed (i.e., for any such reserved  
6243        Bits[7:5] that might be used) per the bit packing scheme. Following the last clock cycle, the  
6244        Controller shall pull SDA[0] High before it drives either the HDR Restart Pattern or the HDR  
6245        Exit Pattern.
- 6246     • **If the receiver was configured to use a bit packing scheme with a single clock cycle (i.e.,  
6247        Quad Lane):** If the receiver does not verify the transfer and leaves SDA[0] undriven (i.e.,  
6248        High) for the second half-clock, then SDA[0] shall remain High through the end of the  
6249        **Transition\_Verify** byte. After this, the CRC Block ends and the Controller shall drive either  
6250        the HDR Restart Pattern or the HDR Exit Pattern.

6251     **For HDR-BT Write transfers that use additional Data Lanes**, the Controller shall drive these Data  
6252     Lanes (e.g., SDA[1:3]) to Low (i.e., 0 values) for the first half-clock. Subsequently, the Controller  
6253     shall either hold these Data Lanes to Low for the remaining clock cycles of the **Transition\_Verify**  
6254     byte; or optionally (i.e., by prior agreement and configuration) High-Z or drive to High any  
6255     relevant Data Lanes as needed (i.e., for any such reserved Bits[7:5] that might be used) for the  
6256     receiver's bit packing scheme.

6257     **Note:**

6258     The HDR-BT CRC Block diagrams in **Section 5.2.4.6** show the reserved Bits[7:5] as 3'd0.

### 5.2.4.3.4 Data Block Delay Mechanism

The Data Block Delay mechanism is intended to allow Targets to get additional time when returning Read data. It is mainly intended for situations where the Controller provides the clock (i.e., controls SCL for a Read transfer). However, it may still be useful when the Target controls SCL for a Read transfer, because it allows the Controller to terminate the Read transfer instead of requiring the Controller to continue waiting for the Target to provide data (i.e., where the Controller would become stuck for up to the maximum number of delay attempts).

#### Operational Flow

At the start of each HDR-BT Read transfer, the Controller shall determine whether the Target is permitted to use the Data Block Delay mechanism, and indicate this in Bit[2] of the **Transition** byte of the Header Block: if Bit[2] has a value of 1, then the Target is not permitted to use the Data Block Delay mechanism. However, if Bit[2] has a value of 0, then the Target (as transmitter) is permitted to use the Data Block Delay mechanism (see [Section 5.2.4.3.1](#)).

##### Note:

*The remainder of this section assumes that the Controller indicated that the Target was permitted to use the Data Block Delay mechanism during an HDR-BT Read transfer.*

During the Read transfer, as the Target (as transmitter) prepares to send each Data Block except the Last Data Block (per [Section 5.2.4.3.2](#)), it may choose either of two options:

##### Either:

- Send the next Data Block with a full 32 bytes of data.

First, the Target sends the **Transition\_Control** byte, with Bit[4] having a value of 0; then the Target sends the remaining 32 bytes of Data (i.e., Byte 0 to Byte 31). This is a complete Data Block.

##### Or:

- Delay sending the Data Block, and send a Delay byte in its place.

The Target sends a single **Transition\_Control** byte (per [Section 5.2.4.3.2](#)), using the same “Park1,High-Z” mechanism on SDA[0]. In Bit[4] the Target sends a value of 1, indicating that it is delaying the next Data Block and not providing a full Data Block at this time.

The Target (as transmitter) may send up to the maximum number of Delay bytes (i.e., up to **fBT\_DBDB** at each opportunity) before it must either send the next real Data Block (i.e., with a full 32 bytes of data), or send a Last Data Block to end the HDR-BT Read transfer.

#### Usage Notes

The Controller (as receiver) shall examine the value of Bit[4] to determine whether the first byte is the **Transition\_Control** byte (i.e., is the start of a valid Data Block), or is a Delay byte. Upon making this determination, the Controller may decide that it does not wish to continue waiting for delayed Data Blocks and instead wishes to end the transfer, and it may do so using the “Park1,High-Z” mechanism on SDA[0], at any of the Delay bytes (i.e., as it would with a typical Data Block).

##### Note:

*HDR-BT packs bytes of Transition content using different bit packing schemes, based on the Multi-Lane configuration of the Target that is addressed in the Header Block (per [Section 5.2.4.2](#)). Since these bit packing schemes have different locations for Bit[4] with respect to the timing and the “Park1,High-Z” mechanism, the knowledge that a received byte is a Delay byte (and not the first valid **Transition\_Control** byte in a real Data Block) might be transmitted after the Controller’s opportunity to drive SDA[0] Low to terminate the transmission. In QUAD Lane configuration, the Target sends Bit[4] early enough to give the Controller the opportunity to terminate the transmission. However, in DUAL Lane or SINGLE Lane configurations, the Target sends Bit[4] later, so Controller must react afterwards. As a result, the next opportunity for the Controller to use the “Park1,High-Z” mechanism (for DUAL Lane and SINGLE Lane configurations) is at the start of the next Delay byte, or the next real Data Block.*

6306 The Target may use the Data Block Delay mechanism repeatedly throughout the HDR-BT Read transfer,  
6307 before the first Data Block or any subsequent Data Block, so long as Bit[2] of **Transition\_Control** is 0 (i.e.,  
6308 not a Last Data Block).

6309 The Data Block Delay mechanism should not be used when the Controller has activated any other Targets  
6310 wishing to have the right to terminate the transaction, as they may not be able to track this mechanism  
6311 properly. That is, when the Controller is Reading from Target A, but has also activated Target B in order to  
6312 be able to terminate the transaction, then it should indicate that Data Block Delay is not permitted.

6313 If the Controller controls the SCL for a Read transfer, and if the Target is not permitted to use the Data Block  
6314 Delay mechanism but still cannot provide Data Blocks to safely maintain the HDR-BT Read transfer (i.e.,  
6315 due to internal data readiness), then the Controller might need to slow the SCL (i.e., reduce the data rate) to  
6316 better match the Target's capability. This either should be arranged by private contract between the Controller  
6317 and Target, or should be discovered from the Target before the Controller starts the HDR-BT Read transfer.

6318 **Note:**

6319 *The I3C Basic Specification does not define a mechanism for discovering a Target's capability to*  
6320 *provide Read data using HDR-BT, or whether it can sustain HDR-BT Read transfers at a given*  
6321 *minimum transfer rate. It is assumed that this mechanism could be a private contract between the*  
6322 *Controller and the Target, or could be discovered and controlled by other configuration methods.*

6323 Alternatively, if the Target is unable to provide the next Data Block that contains a full 32 bytes of data, then  
6324 it may emit a Last Data Block and end the transaction early.

6325 **Note:**

6326 *The I3C Basic Specification does not define a mechanism for the Target (as transmitter) to explicitly*  
6327 *inform the Controller (as receiver) that a Last Data Block was unexpected, in cases where the Target*  
6328 *was unable to provide a Data Block that contained a full 32 bytes of data. This may happen if the*  
6329 *Target was unable to provide a full 32 bytes of data at a sustained rate due to extended delay*  
6330 *conditions (i.e., a prolonged stall from other application logic). The Target may encounter this*  
6331 *situation, even when using the Data Block Delay mechanism, if it had already sent the maximum*  
6332 *number of Delay bytes before the next Data Block. The Target may also encounter this situation if it*  
6333 *was not permitted to use the Data Block Delay mechanism. In either case, the Controller must handle*  
6334 *such a situation where the full data message for a Read transfer is shorter than expected, based on*  
6335 *the specific I3C content protocol or a private contract between Controller and Target.*

### 5.2.4.3.5 Performance

6336 The Bus efficiency can be seen in **Table 77** using 12.5 MHz; all numbers can be scaled to Freq:

6337

**Table 77 Bus Efficiency**

| Measurement                                                                                                                                                                                                     | Raw Rate<br>(Single / Dual / Quad) | Real Data Rate<br>Calculation <sup>1</sup> | Single / Dual / Quad<br>Real Data Rate<br>(Rounded) |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--------------------------------------------|-----------------------------------------------------|
| Data blocks                                                                                                                                                                                                     | 25 Mbps / 50 Mbps / 100 Mbps       | 32 / 33 * freq                             | 24 Mbps / 48 Mbps / 96.97 Mbps                      |
| 1 KByte Message                                                                                                                                                                                                 | " / "                              | 1024 / (1024+12) * 32 / 33 * freq          | 23.96 Mbps / 47.9 Mbps / 95.8 Mbps                  |
| 10 KByte Message                                                                                                                                                                                                | " / "                              | 10K / (10K+12) * 32 / 33 * freq            | 24 Mbps / 48 Mbps / 96.86 Mbps                      |
| <b>Note:</b>                                                                                                                                                                                                    |                                    |                                            |                                                     |
| 1. The equation for Messages (vs. just data blocks) factors in the header and CRC as overhead.<br>However, to keep it simple, the expression is incorrect by 12*33/32 or 0.375*freq, so about 1 KHz worst case. |                                    |                                            |                                                     |

6338 Worst case and average delay when terminating a Message early at 12.5 MHz:

- 6339 • **Single Lane:** Worst Case: 10.5  $\mu$ s, Average: 5.28  $\mu$ s. Plus 1.92  $\mu$ s for CRC
- 6340 • **Dual Lane:** Worst Case: 5.28  $\mu$ s, Average: 2.64  $\mu$ s. Plus 960 ns for CRC
- 6341 • **Quad Lane:** Worst Case: 2.64  $\mu$ s, Average 1.32  $\mu$ s. Plus 480 ns for CRC

6342 **Note:**

- 6343 • Parity is only lightly used in this protocol. It is mainly used to catch framing errors. The positive  
6344 Verification at the end (after the CRC) ensures that the transmission was correct in terms of bits  
6345 and framing.
- 6346 • The Verify model allows the I3C Controller's Host system to operate a TCP/IP style windowing  
6347 mechanism to avoid the processor having to check too often. This means that the Host can  
6348 queue up blocks of, e.g., 1 K to 10 K bytes, and then pipeline back the verify successes/failures,  
6349 allowing the Host to resubmit any that failed, freeing up ones that succeeded.

#### 5.2.4.4 CCC Transmission in HDR-BT Mode

6350 A special HDR-BT syntax is used for transmitting Common Command Codes in the HDR-BT protocol. The  
 6351 following formats are defined, as specific instantiations of the generic HDR CCC flows (see [Section 5.2.1.2](#)).  
 6352 The Broadcast CCC flow is shown in [Figure 124](#), and the Direct CCC flow is shown in [Figure 125](#).



**Figure 124 Begin Broadcast CCC in HDR-BT**



#### 5.2.4.4.1 HDR-BT CCC Header Block

6357 Two versions of the HDR-BT Header Block are defined: HDR-BT CCC Indicator Block and HDR-BT CCC  
6358 Selector Block.

##### HDR-BT CCC Indicator Block

6359 An HDR-BT CCC Header Block that begins the framing for a Broadcast CCC or a Direct CCC shall be  
6360 referred to as the HDR-BT CCC Indicator Block.

6361 The HDR-BT CCC Indicator Block shall take the structure of the HDR-BT Header Block Format (see  
6362 *Section 5.2.4.3.1*). It is a common CCC Flow Element, and shall always be transmitted according to the bit  
6363 packing format for the currently configured HDR-BT Coding (see *Section 5.3.2.4.1*).

- 6364 • The **Address** field (byte 0) shall contain the Broadcast Address (7'h7E).
- 6365 • The **Cmd0** field (byte 1) shall contain the Command Code.
- 6366 • For Direct CCCs, the **Cmd1** field (byte 2) shall contain the optional Defining Byte for the  
6367 Command Code. If the CCC does not support an optional Defining Byte, then the **Cmd1** field shall  
6368 contain the value 8'h00 for a Direct CCC framing.
- 6369 • For a Broadcast CCC framing, fields **Cmd1/Cmd2/Cmd3** may store the first three data bytes of the  
6370 Broadcast data, as needed:
  - 6371 • If the Broadcast data is less than three bytes, then the unused fields shall contain the value  
6372 8'h00, and Targets shall ignore any fields whose bytes are not part of the data format defined  
6373 for this Broadcast CCC.
  - 6374 • If the Broadcast data is longer than three bytes, then the Controller shall also send those  
6375 subsequent bytes in additional Data Blocks following the Header Block. However, Targets  
6376 shall first acknowledge receipt of the Header Block, as defined below.
- 6377 • The **Control** field (byte 5) shall be set to indicate the start of a CCC:
  - 6378 • Bit[0] contains 1'b0 to indicate a Write.
  - 6379 • Bit[3] contains 1'b0 to indicate the beginning of a CCC framing.
  - 6380 • Other bitfields shall be set accordingly.

##### HDR-BT CCC Selector Block

6381 An HDR-BT CCC Header Block that begins a Read Segment or a Write Segment in Direct CCC framing  
6382 shall be referred to as the HDR-BT CCC Selector Block.

6383 The HDR-BT CCC Selector Block shall take the structure of the HDR-BT Header Block Format (see  
6384 *Section 5.2.4.3.1*). It is a common CCC Flow Element, and shall always be transmitted according to the bit  
6385 packing format for the currently configured HDR-BT Coding (see *Section 5.3.2.4.1*).

- 6386 • The **Address** field (byte 0) shall contain the Address of the Target (or Group) to be addressed in  
6387 this Segment of the Direct CCC.
- 6388 • The **Cmd0/Cmd1/Cmd2/Cmd3** fields (bytes 1-4) shall be reserved, and shall each be set to 8'h00.
- 6389 • The **Control** field (byte 5) shall be set to indicate the continuation of a Direct CCC:
  - 6390 • **Bit[0]** contains 1'b0 to indicate a Write Segment (i.e., Direct Write or Direct SET), or 1'b1 to  
6391 indicate a Read Segment (i.e., Direct Read or Direct GET). Note that Group Addresses may  
6392 only be used with Write Segments.
  - 6393 • **Bit[3]** contains 1'b1 to indicate the continuation of a Direct CCC framing.
  - 6394 • Other bitfields shall be set accordingly.

#### 5.2.4.4.2 HDR-BT CCC Data Block

An HDR-BT CCC Data Block may follow an HDR-BT CCC Header Block, in the appropriate place for either a Broadcast CCC flow or a Direct CCC flow (see *Figure 124* or *Figure 125*).

##### Broadcast CCC Flow

The HDR-BT CCC Data Block in a Broadcast CCC flow shall take the structure of the HDR-BT Data Block Format (see *Section 5.2.4.3.2*), and shall contain up to 32 bytes of data in its payload.

As described in *Section 5.2.1.2*, HDR-BT CCC Data Blocks are common CCC Flow Elements and shall always be transmitted according to the bit packing format for the currently configured HDR-BT Coding (see *Section 5.3.2.4.1*).

##### Direct CCC Flow

The HDR-BT CCC Data Block in a Direct CCC flow (as part of a Write Segment or Read Segment) is a per-Target CCC Flow Element, and shall be transmitted according to the bit packing format of the currently configured Multi-Lane Frame format and Data Transfer Coding (see *Section 5.3.2.4.1*) for the addressed Target (or Group).

This may use a different bit packing format, and may use more additional data Lanes than the preceding HDR-BT CCC Selector Word. If so, then the Controller and indicated Target (or Targets in a Group, if applicable) shall correctly switch from one bit-packing format to another, as part of the CCC flow.

#### 5.2.4.4.3 HDR-BT CRC Block

An HDR-BT CRC Block serves as the Termination Marker, as described in the HDR-x generic CCC flows. To conform to the HDR-BT Mode Framing model (see *Section 5.2.4.3*), this Termination Marker uses the same structure as the standard HDR-BT CRC Block.

##### Broadcast CCC Flow

For the end of Broadcast data in a Broadcast CCC flow, the Controller shall transmit the HDR-BT CRC Block (see *Section 5.2.4.3.3*) at the end of the Broadcast data message.

As described in *Section 5.2.1.2*, HDR-BT CCC CRC Blocks are common CCC Flow Elements and shall always be transmitted according to the bit packing format for the currently configured HDR-BT Coding (see *Section 5.3.2.4.1*). This bit packing format shall be the same as that used in the preceding Block.

##### Direct CCC Flow

**Indicator Block:** When used after the HDR-BT CCC Indicator Block and any optional HDR-BT CCC Data Blocks for the framing of a Direct CCC flow (i.e., before the first Read or Write Segment), the HDR-BT CRC Block shall be transmitted by the Controller, as described above. This is also a common CCC flow element.

**Segment:** For the end of a Read or Write Segment sent in a Direct CCC flow, the HDR-BT CRC Block is a per-Target CCC Flow Element, and shall be transmitted according to the bit packing format of the currently configured Multi-Lane Frame format and Data Transfer Coding (see *Section 5.3.2.4.1*) for the addressed Target or Group. This bit packing format shall be the same as that used in the preceding HDR-BT CCC Data Block.

#### 5.2.4.4.4 HDR-BT CCC Indicator Block ACK

Per **Section 5.2.1.2.2**, a Target that supports CCCs in HDR-BT Mode shall indicate acknowledgement of the receipt of the HDR-BT CCC Indicator Block, using the standard method of acknowledging an HDR-BT write, i.e., by using Bits[1:0] of the Transition byte in the HDR-BT Header Block (per **Section 5.2.4.3.1**).

All such Targets shall acknowledge the Indicator Block for both Broadcast CCC flows and Direct CCC flows, since the same HDR-BT CCC Indicator Block format is used to signal the beginning of both flows.

If the Indicator Block's Command Code (byte 1) indicates a Direct CCC, then all Targets receiving that Indicator Block shall capture the new Command Code and optional Defining Byte (byte 2) and use these if they are addressed in a future Write or Read Segment in the Direct CCC framing.

**Note:**

*For Direct CCC flows, acknowledgement serves the important function of ensuring that a Target Device has captured the Command Code and optional Defining Byte from the Indicator Block, and is ready to match the Address on the next HDR-BT Header Block that is a Selector Block, and make a decision to respond to the Direct CCC if addressed, per **Section 5.2.1.2.2**.*

If the Controller does not receive acknowledgement from at least one Target, then it shall use any valid HDR-BT CCC End Procedure. Additionally, the Controller may initiate an error recovery procedure, which might include exiting HDR-BT Mode and attempting to re-send the CCC in SDR Mode.

#### 5.2.4.4.5 HDR-BT CCC Write Segment

An HDR-BT CCC Write Segment for a Direct Write or Direct SET CCC shall start with an HDR-BT CCC Selector Block to indicate the Address of the Target (or Group) to receive the data, followed by one or more HDR-BT CCC Data Blocks of the appropriate structure and format, if required by the CCC definition.

If the CCC definition does not require data to be written to the Target, then no additional Data Blocks shall be sent.

After the Controller sends the HDR-BT CCC Selector Block, the Target shall either indicate acceptance of the Direct CCC by acknowledging the write, or else reject the Direct CCC by not responding to the Controller. The Target shall use the cached Command Code and optional Defining Byte from the previously received HDR-BT CCC Indicator Block, and shall decide whether to accept or reject the Direct CCC immediately after receiving the HDR-BT CCC Selector Block and matching its own Dynamic Address (or Group Address, if assigned and applicable).

The Target shall use the standard methods to either accept or reject an HDR-BT write, as defined in **Section 5.2.4.3.1** regarding the handling of Bits[1:0] of the HDR-BT Header Block's Transition Byte field.

If the Target rejects the Direct CCC, then the Controller shall either send the HDR Restart Pattern and attempt another Read or Write Segment for this CCC, or else use any valid HDR-BT CCC End Procedure. For Direct CCCs to a Group Address, the Controller only sees this rejection if no Targets accept the Direct CCC.

If the Target accepts the Direct CCC, then the Controller shall send one or more HDR-BT CCC Data Blocks of the appropriate structure, if required by the CCC definition. Then the Controller shall send an HDR-BT CRC Block to terminate the data and end the Segment.

At the end of a Write Segment, the Controller shall either send the HDR Restart Pattern and attempt another Read or Write segment for this CCC, or else use any valid HDR-BT CCC End Procedure, per **Section 5.2.4.4.7**.

#### 5.2.4.4.6 HDR-BT CCC Read Segment

An HDR-BT CCC Read Segment for a Direct Read or Direct GET CCC shall start with an HDR-BT CCC Selector Block to indicate the Address of the Target to provide data for the CCC, followed by a Bus Turnaround. In response, the indicated Target will either accept the Direct CCC by transmitting one or more HDR-BT CCC Data Blocks of the appropriate structure, or else reject the Direct CCC by not responding to the Bus Turnaround condition.

The Target shall use the standard methods to either accept or reject an HDR-BT read, as defined in [Section 5.2.4.3.1](#) regarding the handling of Bits[1:0] of the HDR-BT Header Block's Transition Byte field.

If the Target accepts the Direct CCC, then the Controller shall yield control of the Bus to the Target, so that it can control the Bus to send the Data Blocks. After sending the Last Data Block, the Target shall send an HDR-BT CRC Block, indicating the end of the read transfer. Upon receiving the HDR-BT CRC Block the Target shall yield control of the Bus, and the Controller shall resume control.

At the end of a Read Segment, the Controller shall either send the HDR Restart Pattern and attempt another Read or Write Segment for this CCC, or else use any valid HDR-BT CCC End Procedure per [Section 5.2.4.4.7](#).

#### 5.2.4.4.7 HDR-BT CCC End Procedures

As illustrated in [Figure 126](#), the HDR-BT CCC ends using one of three possible CCC End Procedures.

##### Option 1: End HDR-BT CCC Followed by New HDR-BT CCC

This End Procedure indicates the end of a Broadcast or Direct CCC in HDR-BT Mode, and the beginning of a new Broadcast or Direct CCC in HDR-BT Mode.

This End Procedure begins with an HDR Restart Pattern, followed by an HDR-BT CCC Indicator Block which provides a new CCC with optional Defining Byte. Since the Indicator Block's Control field (byte 5) signals the beginning of a CCC framing (i.e., Bit[3] is set to 1'b0) the Target shall interpret this as the end of a Direct CCC framing (if present).

Following the Indicator Block, additional HDR-BT Blocks shall follow, per the CCC flow type.

The flow steps are:

1. Controller sends HDR Restart Pattern.
2. Controller sends HDR-BT CCC Indicator Block, using the same format described above.

The bit packing format of this Block shall be appropriate for the current Coding's common CCC flow elements (see [Section 5.3.2.4.1](#)).

3. Targets acknowledge receipt of Indicator Block, as defined above.
4. Flow continues as Broadcast CCC or Direct CCC, as shown above.

**Option 2: End HDR-BT CCC Followed by HDR-BT Generic Transaction (+ Optional HDR Exit)**

This End Procedure indicates the end of CCCs in HDR-BT Mode, and either a return to standard HDR-BT transactions, or a subsequent exit from HDR-BT Mode.

This End Procedure begins with an HDR Restart Pattern, followed by an HDR-BT Header Block which ends the CCC flow, but is neither an Indicator nor a Selector. This is followed by an HDR-BT CRC Block containing a checksum of the payload from the preceding Header Block. Since the preceding Header Block is neither an Indicator nor a Selector, no CCC or optional Defining Byte is included.

After this, the HDR Restart Pattern signals the end of CCC modality, and that the next HDR-BT Header Block must be treated as a standard HDR-BT transaction (not as a CCC flow). Alternatively, the HDR Exit Pattern signals the end of HDR-BT Mode and a subsequent return to SDR Mode.

In either case, the HDR-BT Header Block is distinguished from an HDR-BT CCC Indicator Block because it indicates a ‘Read’ command from the Broadcast Address (7’h7E), which would otherwise be an invalid combination for HDR-BT transactions. Target Devices shall interpret this condition followed by the CRC Block as the Termination Marker ending CCC modality, since this condition is distinct from the start of a new Broadcast CCC or Direct CCC (per CCC End Procedure Option 1, above).

The flow steps are:

1. Controller sends HDR Restart Pattern.
2. Controller sends HDR-BT Header Block, using the following values:
  - The **Address** field (byte 0) shall contain the Broadcast Address (7’h7E).
  - The **Control** field (byte 5) shall be set to indicate the end of the CCC modality:
    - **Bit[0]** contains 1’b1 to indicate a Read.
    - **Bit[3]** contains 1’b0 to indicate that Direct CCC framing is not continued from a prior Selector Block (if applicable).
    - Other bitfields shall be set accordingly.
  - The bit packing format of this Block shall be appropriate for the current Coding’s common CCC flow elements (see **Section 5.3.2.4.1**).
3. Targets do not acknowledge receipt of the HDR-BT Header Block.
4. Controller sends the HDR-BT CRC Block.
  - The bit packing format of this Block shall be appropriate for the current Coding’s common CCC flow elements (see **Section 5.3.2.4.1**).
  - Targets detect this distinct pattern (i.e., Read from 7’h7E with no Data Block) and end CCC modality.
5. Controller sends either HDR Restart Pattern, or HDR Exit Pattern.
  - If HDR Exit Pattern, then Controller exits HDR-BT Mode and returns the Bus to SDR Mode.

**Option 3: End HDR-BT CCC and return to SDR Mode**

This is the simplest End Procedure option. It indicates the end of CCCs in HDR-BT Mode and an immediate exit from HDR-BT Mode.

The flow steps are:

1. Controller sends HDR Exit Pattern.
2. Controller exits HDR-BT Mode and returns the Bus to SDR Mode.



Figure 126 HDR-BT CCC End Procedure Options

### 5.2.4.5 Options

6533 Targets that support HDR-BT shall support CRC-16.

6534 Targets that support HDR-BT may optionally also support CRC-32. When the **GETCAPS** Format 1 CCC is  
6535 sent (see **Section 5.1.9.3.19**), a Target that supports CRC-32 in HDR-BT Mode shall return a value of 1'b1  
6536 in bit 5 of the GETCAP3 byte (the third returned data byte). A Controller that sees the value 1'b1 in that bit  
6537 will know that the Target is capable of supporting CRC-32 in HDR-BT Mode.

6538 Targets that support HDR-BT shall support SCL from the Controller on Read. They may also optionally  
6539 support emitting their own SCL on Read.

6540 **Note:**

6541 *The I3C Basic Specification does not define a mechanism for discovering a Target's capability to*  
6542 *control SCL for Read transfers. The Controller may select whether the Target should control SCL or*  
6543 *not control SCL, using Bit[2] of the Control byte in the Header Block. Per Section 5.2.4.3.1, a Target*  
6544 *that does not actually support driving SCL for Read transfers shall not accept (i.e., must provide*  
6545 *NACK for) the Read transfer request, if it receives such a Header Block with Bit[2] set to 1 in the*  
6546 *Control byte. In this case, the Controller should retry the same Read transfer with Bit[2] set to 0, to*  
6547 *indicate that the Controller will control SCL for the Read transfer. If the Read transfer request's*  
6548 *Header Block was otherwise valid, then the Target should accept (i.e., should provide ACK for) this*  
6549 *Read transfer.*

6550 Targets may choose to support the Data Block Delay mechanism for Read transfers. This mechanism allows  
6551 the Target to delay sending a Data Block (when permitted by the Controller, as indicated in the Header Block)  
6552 if it does not have enough data bytes to fill the Data Block (see **Section 5.2.4.3.4**).

6553 **Note:**

6554 *The I3C Basic Specification does not define a mechanism for discovering whether the Target*  
6555 *supports the Data Block Delay mechanism. If the Target does not support the Data Block Delay*  
6556 *mechanism, then it shall ignore the value of Bit[2] in the Control byte of the Header Block, when the*  
6557 *Header Block indicates that this is a Read transfer. In such a case, the Target must either return full*  
6558 *Data Blocks, except for the Last Data Block; or mitigate the situation, depending on whether it*  
6559 *controls SCL for this Read transfer.*

- 6560 A) *If the Target controls SCL for this Read transfer, then it must either reduce the data rate or end*  
6561 *the transfer early, if it is unable to sustain the transfer of data bytes.*
- 6562 B) *If the Target does not control SCL for this Read transfer, or if it does not have that capability, then*  
6563 *it must end the transfer early, if it is unable to sustain the transfer of data bytes.*

6564 *If the Target does support the Data Block Delay mechanism, and if it was permitted to use this*  
6565 *mechanism for a Read transfer, then the Target may use either of these methods above, that might*  
6566 *be valid or permitted, and for which it has the capability; alternately, it may also use Delay bytes, per*  
6567 *Section 5.2.4.3.4.*

### 5.2.4.6 Diagrams



Figure 127 Header Block for Single Lane

6568  
6569



Figure 128 Header Block for Dual Lane and Quad Lane



Figure 129 Data Block for Single Lane



In Transition\_Control byte, transmitter High-Zs SDA[0] for **second half-clock** of C1. If receiver drives SDA[0] to Low (**shown in orange**), this terminates the transmission after the Transition\_Control byte. Transmitter then emits a CRC Block **as the next byte** (after Transition\_Control).

If Data Block Delay is permitted: Target as transmitter may drive Transition\_Control Bit[4] High (**shown in blue**) to indicate delayed data. Target may repeat for maximum of  $t_{BT\_DBD}$  Delay bytes. (Does not apply for Last Data Block before CRC Block.)





Figure 133 CRC Block for Quad Lane

6580

6581

6582

### 5.2.4.7 Transfer Flow Control

The Target can use the **Transition** byte, **Transition\_Control** byte, and **Transition\_Verify** byte to accept or reject a Write transfer, or to provide flow control at defined points during the Write transfer.

**Figure 134** shows several examples of Write transfer flow control:

- A Target that does not accept the Write transfer;
- A Target that accepts the Write transfer and receives all Data Blocks;
- A Target that terminates the Write transfer before the Controller has sent all Data Blocks; and
- A Target that indicates a CRC mismatch (or other error) after it has received the Data Blocks.



**Figure 134 HDR-BT Flow Control for Write Transfers**

The Target can also use the same **Transition** byte, **Transition\_Control** byte, and **Transition\_Verify** byte to accept or reject a Read transfer, or to provide flow control at defined points during the Read transfer. If the Data Block Delay mechanism is permitted (per *Section 5.2.4.3.4*), then the Target may also use this mechanism to delay sending Data Blocks while it prepares data to send to the Controller.

**Figure 135** shows several examples of Read transfer flow control:

- A Target that does not accept the Read transfer;
- A Target that accepts the Read transfer and sends all Data Blocks (i.e., without any delay or termination);
- A Target that handles the Controller terminating the Read transfer, and subsequently provides the CRC Block after the last Data Block that it sent; and
- A Target that uses the Data Block Delay mechanism before sending the first Data Block.



**Figure 135** HDR-BT Flow Control for Read Transfers

6603  
6604

### 5.3 Multi-Lane (ML) Data Transfer

Although I3C's HDR Modes achieve high data rates using two physical wires and advanced data transfer protocols, some applications would benefit from further increases in data throughput. Multi-Lane Data Transfer (ML) is one approach for achieving such increases, by employing any available additional physical wires to transfer the data payload faster. In ML the normal I3C SDA line is referred to as SDA[0], and the additional wires are called SDA[1], SDA[2], and SDA[3].

ML's advantages include reducing energy consumption and increased flexibility in adding features (e.g., procedures to improve data integrity).

**Example:** An application with a Camera module using Quad Lanes, an IMU using Dual Lanes, and a simple sensor (such as a temperature sensor) using only I3C SCL and SDA[0] wires, would benefit from ML capability.

ML data transfer is available for data transfers between ML-capable I3C Devices that have ML functionality enabled.

Depending upon the Bus design, a given ML-capable Device could reside on the same 2-wire I3C Bus as other non-ML-capable Devices (and/or other ML-capable Devices not currently in an ML-enabled state). Because ML performs all I3C Bus management functions (i.e., START, EXIT, Enter HDR, CCC, Flow Control, etc.) in the ordinary manner using only the SCL and SDA[0] lines, they remain valid and unchanged for all I3C Devices. As a result, ML transfers on an I3C Bus do not adversely affect any non-ML Devices resident on that Bus.

ML data transfer is available for supported I3C Modes (e.g., HDR-BT), using a per-Mode ML Frame format that specifies how SCL, SDA (referred to as SDA[0]), and the additional data wire(s) are used for ML data transfers in that Mode (see [Section 5.3.2](#)). During each ML Frame, ML-capable (and ML-enabled) Devices transfer data using SCL, SDA[0], and the additional data wires supported by that ML Frame format, while any non-ML Devices use only SCL and SDA[0] as usual.

For HDR-BT Mode, [Section 5.3.2.4](#) specifies ML Codings for each of the following ML Frame formats:

- **DUAL format** supporting three lines: SCL, SDA[0], and SDA[1]
- **QUAD format** supporting five lines: SCL, SDA[0], SDA[1], SDA[2], and SDA[3]

For each supported I3C Mode, the ML Frame formats might be similar in sequence and timing to I3C's normal (i.e., non-ML) Frame formats, or they might differ substantially, depending on the Data Transfer Coding.

During ML data transfers, activity on the additional data wire(s) (i.e., SDA[1], SDA[2], and SDA[3]) would not be visible to any non-ML Devices that might be resident on that Bus. Additionally, any ML-capable Devices that support the same I3C Mode but might not be connected to the same additional data wires, or that have not been enabled and configured to utilize these data wires, might not see or properly understand any ML transfers that use more data wires. For such cases, this might lead to failure of interoperability between Devices supporting the same I3C Mode. The specific nature of interoperability failures might depend on the currently configured Data Transfer Coding of such Devices, as well as the ML Frame format used for a particular ML transfer. To prevent such situations, Controllers shall ensure that all Devices supporting that same I3C Mode are configured to use a compatible (i.e., interoperable) Data Transfer Coding that enables interoperability on the I3C Bus. The recommended Data Transfer Coding(s) to use for such situations requiring interoperability shall be defined for each I3C Mode that supports Multi-Lane.

**Note:**

*Multi-Lane (ML) Frame Formats for other I3C Modes (e.g. SDR, HDR-DDR and HDR-TSP) are not included in I3C Basic. Placeholders for these I3C Modes appear under [Section 5.3.2](#).*

### 5.3.1 ML Data Transfer Setup

Set-up of an ML data transfer on an ML-capable I3C Bus has two main parts:

1. Configure and enable the I3C Devices capable of ML transfers using the MLANE CCC (*Section 5.3.1.1*)
2. The ML Frame format (*Section 5.3.2*)

ML-capable Devices shall default to SINGLE Lane configuration (i.e., basic 2-wire I3C), unless the system designer selects a different default configuration.

#### 5.3.1.1 ML Device Configuration

Controllers shall use the MLANE CCC (see *Section 5.1.9.3.30*) to set up and control ML functionality for ML-capable Devices. The MLANE CCC sets or gets, for a given I3C Mode (*Table 56*), the number of Additional Data Lanes (*Table 78*) and the Data Transfer Coding number (see *Section 5.3.2*) to use while communicating to one or more ML-capable Target Devices using that I3C Mode.

Controllers shall configure and enable ML-capable Devices via the MLANE CCC prior to starting ML data transfers, for each I3C Mode for which ML data transfers are to be used. An ML-capable Device may be configured to use any supported number of Additional Data Lanes for any supported I3C Mode.

The Controller shall configure each ML-capable Device with knowledge of its capabilities, and with awareness of the other Devices that support the same I3C Mode(s) and would also be used with ML data transfers, ensuring that such configuration is compatible with the configuration and ML capabilities of such other Devices.

It is the Controller's responsibility to successfully manage the configuration of all Target Devices on the Bus when ML data transfers are used. This depends on capability, connectivity, coordination, and configuration. To build a successful Multi-Lane configuration for all Devices on the I3C Bus, the Controller shall first determine which Target Devices are ML-capable, and then test each such Target Device's connectivity to the Additional Data Lanes (i.e., by using the Direct GET version of the MLANE CCC). For each I3C Mode in which Multi-Lane Transfers will be used, the Controller shall then determine which ML Frame formats are supported by a ML-capable Target Device, and coordinate this with similar data collected from all other ML-capable Target Devices that support that I3C Mode. Finally, once it determines the correct settings that use interoperable Data Transfer Codings, the Controller shall appropriately configure the I3C Bus and all Target Devices, using the MLANE CCC to set the ML Frame Format that shall be used in each I3C Mode.

An ML-capable Target Device shall have only one ML configuration setting (i.e., number of Additional Data Lanes and Data Transfer Coding number) per I3C Mode at a time, which is associated with its Dynamic Address, unless such a Device has multiple Dynamic Addresses per *Section 5.3.1.1.2*. The Controller shall choose the appropriate Defining Byte as the Sub-Command to configure an ML-capable Target Device for ML transfers in that I3C Mode.

**Note:**

*The appropriate ML configuration setting (i.e., ML Frame format) for a particular I3C Mode might depend on the other Devices on the I3C Bus that also support that same I3C Mode (per *Section 5.2.4.7*). Controllers shall ensure interoperability by choosing an ML configuration setting that is known to be interoperable with other such Devices (i.e., a compatible Data Transfer Coding) that also support that I3C Mode. A recommended procedure for Multi-Lane configuration should include using the MLANE CCC with the Sub-Command for Get ML Capabilities (i.e., Defining Byte 0xFF) to discover the supported capabilities (i.e., the possible ML configurations) of all ML-capable Devices, before using the MLANE CCC with other Sub-Commands to configure any ML-capable Devices for ML transfers for specific I3C Modes.*

*Controllers should use the GETCAPS Format 1 CCC (see *Section 5.1.9.3.19* and *Table 37*) to determine whether a Target Device is ML-capable, before using the MLANE CCC to configure and enable it for ML transfers. Additionally, for ML transfers in any HDR Mode, Controllers should also ensure that the HDR Mode is supported by such a Target Device, by using the GETCAPS Format 1 CCC (see *Table 35*). Controllers must also ensure that each Target Device that advertises ML*

6695 transfer capability is indeed connected to the appropriate number of additional data lanes (per **Figure 86**), before configuring such a Target Device to use a ML Frame format requiring such data lanes.

6696  
 6697 Special additional configuration requirements apply for ML-capable Devices that support Group  
 6698 Addressing (see **Section 5.3.1.1.1**), ML-capable Devices that present Virtual Targets with multiple  
 6699 Dynamic Addresses (see **Section 5.3.1.1.2**), and ML-capable Devices that do both of the above.

6700 Once received by the Target, the ML configuration for the Target's Dynamic Address shall remain in effect  
 6701 until a later MLANE CCC is correctly received, or until a RESET sequence that includes ML configuration  
 6702 is performed by the Controller.

6703 The default Lane configuration for ML-capable Devices shall be SINGLE Lane (3'b000). As a result, the  
 6704 default value of the MLANE Data Byte is 0x00.

6705 **Table 78 ML Lane Configurations**

| Number of Additional Data Wires | Lane Configuration                              | Description              | Multi-Lane? | Data Wires | Total Wires | Wires Supported |        |        |        |        |
|---------------------------------|-------------------------------------------------|--------------------------|-------------|------------|-------------|-----------------|--------|--------|--------|--------|
|                                 |                                                 |                          |             |            |             | SCL             | SDA[0] | SDA[1] | SDA[2] | SDA[3] |
| 0                               | SINGLE                                          | Ordinary 2-Wire I3C      | N           | 1          | 2           | ✓               | ✓      | -      | -      | -      |
| 1                               | DUAL                                            | Multi-Lane Data Transfer | Y           | 2          | 3           | ✓               | ✓      | ✓      | -      | -      |
| 3                               | QUAD                                            |                          | Y           | 4          | 5           | ✓               | ✓      | ✓      | ✓      | ✓      |
| 2,<br>4 through 7               | Reserved for future definition by MIPI Alliance |                          |             |            |             |                 |        |        |        |        |

### 5.3.1.1.1 ML Devices with Group Addresses

An ML-capable Target Device may also support Group Address capabilities (see **Section 5.1.4.4**) as indicated by bits[5:4] of the GETCAPS CCC's GETCAP2 byte (see **Section 5.1.9.3.19** and **Table 36**), and a Controller may assign such a Target to a Group Address and then subsequently send transactions to that Group Address or to the Target's Dynamic Address using Multi-Lane formatting. The Controller needs to know the ML capabilities of each Target Device in a Group, and configure them appropriately, such that all transactions sent to that Group Address are properly understood and received by all Target Devices that have been assigned to that Group Address.

**Note:**

*Per **Section 5.1.4.4**, a Target Device that supports Group Address capabilities shall receive transfers addressed to its Dynamic Address, as well as any assigned Group Addresses; all such addresses are in effect simultaneously. If such a Target also supports any HDR Modes, then the assigned Group Addresses are in effect for HDR Write transfers as well as SDR Write transfers, and the Controller may send transfers to the Group Address using any I3C Mode that this Target (and other Targets assigned to the same Group Address) might support.*

Before the Controller assigns a Group Address to an ML-capable Target Device on an I3C Bus that supports Multi-Lane, it also needs to know the ML configuration of the other Target Devices that are assigned to that Group Address, and take steps to ensure that all such Target Devices are configured to use the same number of Additional Data Lanes and the same Data Transfer Coding, when it sends transfers to that Group Address. The Controller also needs to know whether the Target only supports a single ML configuration (i.e., variant 2'b00) that applies to its Dynamic Address as well as any currently-assigned Group Addresses, or whether the Target supports separate ML configurations (i.e., a different number of Additional Data Lanes or an alternate Data Transfer Coding) for each assigned Group Address (i.e., variant 2'b01).

**For I3C Basic:**

- An I3C Controller Device that supports Multi-Lane and also supports Group Address capabilities shall only recognize and configure I3C Target Devices that report as variant 2'b01, when configuring Multi-Lane transfers involving Group Addresses.
- An I3C Target Device that supports Multi-Lane and also supports Group Address capabilities must also support multiple ML configurations within a Target Device (i.e., variant 2'b01 must be reported by the MLANE Direct GET CCC with the Sub-Command for Group ML Capabilities).

**Note:**

*Per **Section 5.3.1.1.2**, a composite Device that has shared Peripheral Logic and supports a separate Dynamic Address for each Virtual Target that is presented on the Bus shall support a separate ML configuration for each Dynamic Address. If such a composite Device also supports Group Address capabilities, then it shall also support separate ML configurations for each currently assigned Group Address (i.e., variant 2'b01) per this section, such that each Dynamic Address may be assigned to Group Addresses in a similar manner (i.e., act according to the requirements for variant 2'b01 as detailed below).*

If an I3C Bus contains ML-capable Targets of both variants (i.e., variant 2'b00 and variant 2'b01), then the Controller shall not assign the same Group Address to Target Devices of both variants, due to the increased complexity of configuring Multi-Lane transfers for such a Group Address, as well as the possibility of misconfiguration among such Target Devices.

**Note:**

*Support for variant 2'b00 is not included in the I3C Basic Specification. However, an I3C Controller that supports any version of the I3C Basic Specification might receive a response from an ML-capable I3C Target that supports the full I3C Specification and reports as variant 2'b00, when used with the MLANE Direct GET CCC with the Sub-Command for Group ML Capabilities (i.e., Defining Byte 0x9B). Such an I3C Controller must not attempt to configure any variant 2'b00 Targets for ML transfers involving Group Addresses, as the I3C Controller would not support this variant.*

**Variant 2'b01****Note:**

*This is the only supported variant for I3C Basic.*

If an ML-capable Target that supports Group Address capabilities also supports separate ML configurations (i.e., variant 2'b01), then it shall maintain a configuration for each currently assigned Group Address, once assigned by the Controller using the SETGRPA CCC (see **Section 5.1.9.3.27**). A Target's initial ML configuration for a newly-assigned Group Address shall be set to the common ML configuration (i.e., ML Frame format) for the I3C Mode and the configuration of the Device, per **Section 5.3.1.1**:

- For HDR-BT Mode, the initial common ML configuration shall be SINGLE-lane with the default Data Transfer Coding. This is equivalent to Data Byte 0x00, as used with the MLANE Direct SET CCC Sub-Command to set the ML Configuration for that I3C Mode, when sent to the Group Address (per **Section 5.1.9.3.30**).
- However, the common ML configuration may subsequently be changed if the Controller configures the Device to use an ML Frame format that is based on any alternate Data Transfer Coding (per **Section 5.3.2.4**):
  - For Group Address assignments that were present before configuring such a Device to use an alternate Data Transfer Coding, the Device shall change the ML configuration to use the new common ML Frame format for this alternate Data Transfer Coding. In some cases, this might result in an ML configuration for an assigned Group Address changing to reflect the common ML Frame format, which may include a different number of additional data lanes than what was originally configured for that Group Address.
  - For Group Address assignments that were configured with the SETGRPA CCC after such a Device was configured to use an alternate Data Transfer Coding, the Device shall use the new common ML configuration for this alternate Data Transfer Coding.
  - In both cases, the data returned in response to the MLANE Direct GET CCC with the Sub-Command for Get Group Report (i.e., Defining Byte 0x9C) shall always reflect the correct status of each Group Address assignment.
- Additional requirements may apply for ML-capable Devices that also present multiple Virtual Targets (per **Section 5.3.1.2**).

The Controller may subsequently configure all such Targets that support separate ML configurations and are assigned to this Group Address to use a different ML Frame format for write transactions directed to the Group, by sending the MLANE Direct SET CCC to the Group Address. The Controller shall only use the Group Address with the MLANE CCC, if and only if all such Targets (i.e., members assigned to that Group Address) support separate ML configurations, and only if all such Targets support the indicated ML Frame format. It is the responsibility of the Controller to make this determination before assigning ML-capable Targets to a Group Address, and before sending the MLANE Direct SET CCC to a Group Address with a particular Data Byte value with the intent to configure the Group (i.e., to set the ML Frame format for all Targets that are members assigned to that Group Address).

The Controller should determine whether an ML-capable Target does support separate ML configurations by using the MLANE Direct GET CCC (see **Section 5.1.9.3.30**) with the Sub-Command for Group ML Capabilities (i.e., Defining Byte 0x9B). A Target that supports separate ML configurations shall indicate this support (see **Table 56**) as well as the number of Group Addresses to which it is currently assigned. To verify that an ML configuration change sent to the Group Address was successfully applied, the Controller should use the MLANE Direct GET CCC with the Sub-Command for Get Group ML Report (i.e., Defining Byte 0x9C) for each Target assigned to that Group (i.e., by sending the MLANE Direct GET CCC with Defining Byte 0x9C to each Target's Dynamic Address) to read its current ML configurations for all currently assigned Group Addresses.

6800 The Controller may also reset all current ML configurations for a Target (including any configured Group  
6801 Address configurations) by sending the MLANE CCC with the Sub-Command for Reset ML (i.e., Defining  
6802 Byte 0x7F). This shall reset all such Targets assigned to the Group Address to a known common ML Frame  
6803 format.

6804 If a Target supports multiple current ML configurations for all its assigned Group Addresses, then each ML  
6805 configuration may be set to any of the supported ML Frame formats, as returned by the MLANE Direct GET  
6806 CCC with the Sub-Command for Get ML Capabilities (i.e., Defining Byte 0xFF), as long as they are all  
6807 configured to be mutually interoperable within the same I3C Mode.

6808 **Note:**

6809 *Special restrictions apply for certain ML Frame formats that are not interoperable with the current ML  
6810 Frame format that is configured for the Dynamic Address to which the Group Address is assigned.  
6811 Such restrictions apply for I3C Modes (such as HDR-BT) that define alternate Data Transfer Codings  
6812 that are not interoperable with the default Data Transfer Coding. In no case shall a Device allow any  
6813 assigned Group Address to be configured to use an ML Frame format that is based on a Data  
6814 Transfer Coding that is not interoperable with the Data Transfer Coding of the Dynamic Address's  
6815 currently configured ML Frame format.*

6816 The Controller may use the MLANE CCC to configure the current ML Frame format for transfers addressed  
6817 to the Group Address (i.e., by sending the MLANE Direct SET CCC to the Group Address) to set this  
6818 configuration, which will not change the current ML configuration for the Target's Dynamic Address of any  
6819 such Target within that Group. Such a Target will keep track of its multiple current configurations for its  
6820 assigned Addresses, and will use the Address received for each transaction to match and select the correct  
6821 ML configuration based on the Address.

6822 **Note:**

6823 *The variant is a global option that applies to the Target Device, for all I3C Modes in which Multi-Lane  
6824 transfers are supported. For I3C Basic, HDR-BT Mode is the only I3C Mode that supports Multi-Lane  
6825 transfers (see Section 5.3.2).*

6826 *Per Section 5.1.9.3.30, such an ML-capable Target shall also support the MLANE CCC as a  
6827 Broadcast SET CCC in addition to a Direct SET CCC addressed to an assigned Group Address, for  
6828 supported I3C Modes. In such a case, the MLANE Broadcast SET CCC shall change the ML  
6829 configuration for all currently assigned Group Addresses as well as the assigned Dynamic Address,  
6830 and shall also set (or reset) the common ML configuration for newly-assigned Group Addresses.*

## Variant 2'b00

6831 Support for this variant is not included in I3C Basic. To gain access to this capability, please contact MIPI  
6832 Alliance.

### 5.3.1.1.2 ML Devices with Multiple Dynamic Addresses

If an ML-capable Target Device is a Virtual Target with its BCR bit[4] set to 1 (see *Table 5*), and also shares its Peripheral logic with other Virtual Targets within the same composite Device (see *Section 5.1.2.1.2* and *Section 5.1.9.3.26*, i.e., the RSTACT CCC with Defining Byte 0x04 in *Table 53*), then the Device shall support separate ML configurations for each Dynamic Address that such a Device presents to the I3C Bus.

**Note:**

*Before assigning separate ML configurations to each Virtual Target, the Controller should use the GETCAPS Format 2 CCC with Defining Byte VTCAPS (see *Section 5.1.9.3.19*) to determine which Devices present Virtual Targets using shared Peripheral logic; and also use the RSTACT CCC with Defining Bytes 0x04 and 0x84 (see *Section 5.1.9.3.26*) to correctly identify which Dynamic Addresses are associated together within the same composite Device having shared Peripheral logic. With this knowledge, the Controller can prepare for any interactions that might result from sending the MLANE Direct SET CCC to one Dynamic Address, if such interactions or side effects are defined for a particular I3C Mode.*

For such composite Devices, using the MLANE Direct SET CCC to read or change the current ML configuration for one Virtual Target's Dynamic Address shall only act on that Virtual Target, and shall not affect any other Virtual Targets within the same Device, unless the Controller sends a MLANE Direct SET CCC for a particular I3C Mode to configure one Dynamic Address to use an Data Transfer Coding that is not interoperable with the default Data Transfer Coding or current Data Transfer Coding of the ML-capable Device. Such exceptions are specifically defined in the appropriate sub-sections of *Section 5.3.2* that define alternate Data Transfer Codings for such I3C Modes (i.e., for HDR-BT Mode) that have interoperability advisories. Note that such alternate Data Transfer Codings also carry special requirements that apply to the entire ML-capable Device with respect to its support for ML transfers in such I3C Modes.

In all other cases, the Controller may send an MLANE Direct SET CCC to configure one Dynamic Address with a valid ML configuration, and the Device shall apply that valid ML configuration to only the Virtual Target using that assigned Dynamic Address (i.e., with no effect on other Virtual Targets using other assigned Dynamic Addresses).

**Note:**

*An ML-capable Target Device that presents multiple Virtual Targets might also support Group Addressing (see *Section 5.3.1.1.1*) in addition to multiple Dynamic Addresses. If so, then the conditions in that section shall also apply, and each assigned Dynamic Address may be assigned to any available Group Address.*

*Per *Section 5.1.9.3.30*, such an ML-capable Target shall also support the MLANE CCC as a Broadcast SET CCC in addition to a Direct SET CCC addressed to an assigned Group Address, for supported I3C Modes. In such a case, this shall attempt to change the ML configuration for all currently assigned Group Addresses as well as the assigned Dynamic Address, and may also set (or reset) the common ML configuration for newly-assigned Group Addresses. For HDR-BT, this may also change the common Data Transfer Coding that is used for ML transfers that are addressed to the Broadcast Address (e.g., for CCC flows in HDR Modes).*

All Virtual Targets within the same Device should return the same output when using the MLANE Direct GET CCC with Defining Byte 0xFF (see *Table 56*) to read the supported ML Frame formats. In cases where a Device has been set to use an alternate Data Transfer Coding (i.e., one that is not interoperable with the default Data Transfer Coding, as above) then the Device may filter the output of the MLANE Direct GET CCC, and only return the possible ML Frame formats that may be chosen within the currently configured Data Transfer Coding.

6877 If the Controller uses the MLANE Direct SET CCC with Defining Byte 0x7F, then the Sub-Command for  
6878 Reset ML shall only apply to the addressed Virtual Target (i.e., the Dynamic Address to which it was sent),  
6879 and shall not affect any other Virtual Targets within the same Device. In all cases, the Sub-Command for  
6880 Reset ML as a Direct SET CCC shall not cause the Device to cause (or attempt to apply) an inconsistent set  
6881 of ML configurations that might have a mix of Data Transfer Codings for different Virtual Targets that are  
6882 not interoperable; for such special cases, the defined behavior of a Sub-Command for Reset ML as a Direct  
6883 SET CCC shall be specifically defined in the appropriate sub-sections of **Section 5.3.2** that might define  
6884 alternate Data Transfer Codings for a particular I3C Mode (as above). If not so defined, then the Sub-  
6885 Command for Reset ML as a Direct SET CCC shall have the effect of returning one Virtual Target's Dynamic  
6886 Address to the default Data Transfer Coding with the default Lane Configuration.

6887 If the Controller uses the MLANE Broadcast CCC with the Sub-Command for Reset ML (i.e., Defining Byte  
6888 0x7F), then this action shall apply to all Virtual Targets (i.e., all assigned Dynamic Addresses within the  
6889 Device) and return them all to the default Data Transfer Coding with the default Lane Configuration.

### 5.3.1.2 The ML Frame

Before starting any ML data transfers, the Controller shall configure the resident ML-capable Devices using the appropriate version of the MLANE CCC (see [Section 5.1.9.3.30](#)). Controllers should use MLANE's Direct GET Sub-Command for the relevant I3C Modes, to check that the current ML configuration of each ML-capable Device is correct for all I3C Modes in which Multi-Lane transfers will be used. A Device's ML configuration parameters (i.e., Data Transfer Coding number and number of Additional Data Lanes) per I3C Mode remain in effect until a new MLANE SET CCC for that I3C Mode is correctly received, or until the Controller uses the MLANE CCC with the Sub-Command for Reset ML (i.e., Defining Byte 0x7F) to reset a single Device using its Dynamic Address (i.e., via Direct CCC) or to reset all Devices on the Bus (i.e., via Broadcast CCC).

Since all I3C Bus management is done using only the SCL and SDA[0] lines, an I3C ML Frame starts as specified by the ordinary framing rules for the selected I3C Mode. That is, the START, Address Arbitration, and entry into an HDR Mode (if so chosen) are all done in the same manner as for I3C SINGLE Lane configuration. During the ML data transfer, and within the Frame, ML-capable (and ML-enabled) Devices shall automatically communicate using the configured number of additional data Lanes and according to the configured Data Transfer Coding. EXIT from the I3C Frame follows the ordinary I3C rules specified for the selected I3C Mode.

For Multi-Lane transfers using any HDR Mode, the following common structured protocol elements are defined for ML transfers while in that HDR Mode:

- **HDR-x Header Element**, which typically indicates the Dynamic Address (or Group Address, if supported) to which the transfer is directed
  - In HDR-BT Mode, this is the HDR-BT Header Block (see [Section 5.2.4.3.1](#)).
- **HDR-x Data Element**, which typically contains data bytes using Additional Data Lane(s)
  - In HDR-BT Mode, this is the HDR-BT Data Block (see [Section 5.2.4.3.2](#)).
- **HDR-x Termination Element**, which indicates the end of the transfer
  - In HDR-BT Mode, this is the HDR-BT CRC Block (see [Section 5.2.4.3.3](#)).

**Note:**

*The I3C Basic Specification does not include the structured protocol elements for other HDR Modes, as I3C Basic does not include support for Multi-Lane (ML) transfers in other HDR Modes. To gain access to Multi-Lane (ML) Data Transfer support for other HDR Modes, contact MIPI Alliance.*

[Section 5.3.2.4](#) provides examples of typical ML Frames in HDR-BT Mode using the specific structured protocol elements arranged into ML transfers in the supported Lane Configurations, for each of the supported HDR-BT Data Transfer Codings. The ML Framing model extends the standard HDR read/write transfer model, using the same typical flow of structured protocol elements (e.g., one HDR-BT Header Block, followed by one or more HDR-BT Data Blocks, and one HDR-BT CRC Block) and then either ending the ML Frame with the HDR Exit Pattern, or continuing to the next ML transfer after the HDR Restart Pattern.

### 5.3.2 ML Frame Formats

**Table 79** indicates which section of this specification describes the ML Frame format used for each I3C Mode that supports Multi-Lane. For each supported I3C Mode, the 1-Lane (Default) Mode is also detailed in the referenced section.

**Table 79 All ML Frame Formats**

| I3C Mode | ML Data Transfer | MLANE CCC Fields |           | Coding | Additional Data Lanes | Section          | For More Details See |  |
|----------|------------------|------------------|-----------|--------|-----------------------|------------------|----------------------|--|
|          |                  | Defining Byte    | Data Byte |        |                       |                  |                      |  |
| HDR-BT   | HDR-BT DUAL      | 0x23             | 0x01      | 0      | 1                     | <b>5.3.2.4.2</b> | <b>Table 80</b>      |  |
|          |                  | 0x23             | 0x19      | 3      | 1                     |                  |                      |  |
|          | HDR-BT QUAD      | 0x23             | 0x03      | 0      | 3                     | <b>5.3.2.4.3</b> |                      |  |
|          |                  | 0x23             | 0x1B      | 3      | 3                     |                  |                      |  |
|          |                  | 0x23             | 0x3B      | 7      | 3                     |                  |                      |  |

**Note:**

In addition to the above, the full I3C Specification includes definitions for more ML Frame formats:

*SDR Based ML Frame Formats:*

*SDR-ML DUAL Coding*

*SDR-ML QUAD Coding*

*HDR-DDR Based ML Frame Formats:*

*HDR-DDR-ML DUAL Coding*

*HDR-DDR-ML QUAD Coding*

*HDR-TSP Based ML Frame Formats:*

*HDR-TSP-ML DUAL Coding*

*HDR-TSP-ML QUAD Coding*

To gain access to these capabilities, please contact MIPI Alliance.

#### 5.3.2.1 SDR Based ML Frame Formats

This section is not included in the I3C Basic Specification because I3C Basic does not support Multi-Lane (ML) Data Transfers in SDR Mode. To gain access to this capability, please contact MIPI Alliance.

#### 5.3.2.2 HDR-DDR Based ML Frame Formats

This section is not included in the I3C Basic Specification because I3C Basic does not support Multi-Lane (ML) Data Transfers in HDR-DDR Mode. To gain access to this capability, please contact MIPI Alliance.

#### 5.3.2.3 HDR-TSP Based ML Frame Formats

This section is not included in the I3C Basic Specification because I3C Basic does not support Multi-Lane (ML) Data Transfers in HDR-TSP Mode. To gain access to this capability, please contact MIPI Alliance.

### 5.3.2.4 HDR-BT Based ML Frame Formats

For all HDR-BT Based ML Frame formats the MLANE Defining Byte value shall be 0x23 (i.e., the same numerical value as the ENTHDR3 CCC).

Within Defining Byte 0x23 there could be several Data Transfer Coding schemes specifying the data payload format and optional additional information being transferred. Additionally, several “alternate mode” Data Transfer Codings have been defined, which allow for enhanced performance by using additional data Lanes for transferring HDR-BT Header Blocks, as well as the common CCC flow elements in the HDR-BT CCC flows (see **Section 5.3.2.4.1** and **Table 80**).

The default Data Transfer Coding is HDR-BT Coding 0 (compatible mode). Other Data Transfer Codings could be added, as suitable for specific applications or performance requirements.

The currently defined ML Frame formats for HDR-BT Based ML Frames are shown in **Table 80**.

**Table 80 HDR-BT Frame Formats in Multi-Lane**

| I3C Mode | ML Data Transfer | MLANE CCC Fields |           | Coding | Additional Data Lanes | Formatting Notes                                                                                                                                     | Section          |
|----------|------------------|------------------|-----------|--------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
|          |                  | Defining Byte    | Data Byte |        |                       |                                                                                                                                                      |                  |
| HDR-BT   | HDR-BT (1-Lane)  | 0x23             | 0x00      | 0      | 0                     | All HDR-BT Blocks use 1-Lane formatting (Compatible Mode)<br><b>Note:</b> This is the initial default ML configuration for all HDR-BT Target Devices | <b>5.3.2.4.1</b> |
|          |                  | 0x23             | 0x01      | 0      | 1                     | Header Blocks and common CCC flow elements use 1-Lane formatting (Compatible Mode)                                                                   |                  |
|          | HDR-BT DUAL      | 0x23             | 0x19      | 3      | 1                     | Header Blocks and common CCC flow elements use 2-Lane formatting (“Alternate Mode”)                                                                  | <b>5.3.2.4.2</b> |
|          |                  | 0x23             | 0x03      | 0      | 3                     | Header Blocks and common CCC flow elements use 1-Lane formatting (Compatible Mode)                                                                   |                  |
|          | HDR-BT QUAD      | 0x23             | 0x1B      | 3      | 3                     | Header Blocks and common CCC flow elements use 2-Lane formatting (“Alternate Mode”)                                                                  | <b>5.3.2.4.3</b> |
|          |                  | 0x23             | 0x3B      | 7      | 3                     | Header Blocks and common CCC flow elements use 4-Lane formatting (“Alternate Mode”)                                                                  |                  |

**Note:**

The “Alternate Mode” Codings for HDR-BT Mode may not be used unless all HDR-BT Target Devices on the Bus are ML-capable and have been configured to use interoperable Codings.

Configuring an HDR-BT capable Target Device to use an “Alternate Mode” Coding shall change how the Device interprets the HDR-BT Header Block, which affects its ability to match an assigned Address for subsequent HDR-BT transfers. This includes Devices that support Group Addressing per **Section 5.3.1.1.1**, as well as Devices that support multiple Dynamic Addresses as Virtual Targets (per **Section 5.3.1.1.2**).

Selecting an “Alternate Mode” Coding requires the Controller to use a different formatting for all HDR-BT Header Blocks, as well as all common CCC flow elements in the HDR-BT CCC flows. If any HDR-BT Target Device is unable to understand that formatting due to an incompatible configuration, or due to being non-ML-capable, then it will not properly receive and understand many of the HDR-BT Blocks, and this might cause communication errors. See **Section 5.3.2.4.1** for more details on which HDR-BT Multi-Lane Frame formats are interoperable for “Alternate Mode”.

6972  
6973 **Figure 136** illustrates a common ML Frame for HDR-BT, using Coding 0. This Coding supports HDR-BT Target Devices that use any number of additional data Lanes (including no additional data Lanes).



6974  
6975 **Figure 136 Typical ML I3C Frame Based on HDR-BT Mode (Coding 0)**

6976

**Figure 137** illustrates a common ML Frame for HDR-BT, using Coding 3. When using this Coding, no 1-Lane HDR-BT Target Devices are supported.



**Figure 137 Typical ML I3C Frame Based on HDR-BT Mode (Coding 3)**

6977  
6978

6979  
6980 **Figure 138** illustrates a common ML Frame for HDR-BT, using Coding 7. When using this Coding, no 1-Lane or 2-Lane ML HDR-BT Target Devices are supported.



6981  
6982 **Figure 138 Typical ML I3C Frame Based on HDR-BT Mode (Coding 7)**

### 5.3.2.4.1 HDR-BT Codings and Interoperability for CCCs

HDR-BT defines several “Alternate Mode” ML Frame formats that may optionally be used for increased performance efficiency. However, not all of these are mutually interoperable. **Table 81** lists the supported Codings and defines how they affect the formatting of various CCC flow elements that comprise CCC flows in HDR-BT Mode.

**Table 81** HDR-BT Frame Format Details and Coding Interoperability for CCCs in Multi-Lane

| Coding and Meaning      | HDR-BT Header Block Format              | HDR-BT Data Blocks and CRC Block Format                                                                                                         | Common ML Frame Format (i.e., Default Data Byte) | Common CCC Flow Elements              | Per-Target CCC Flow Elements                                                         | Notes                                                                  |
|-------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| 0<br>(Compatible Mode)  | SINGLE Lane<br>(see <b>Figure 127</b> ) | 1-Lane: <b>Table 70</b> and <b>Table 73</b><br>2-Lane ML: <b>Table 71</b> and <b>Table 74</b><br>4-Lane ML: <b>Table 72</b> and <b>Table 75</b> | 0x00<br>(SINGLE Lane)                            | Use 1-Lane HDR-BT Frame formatting    | May use 1-Lane, 2-Lane ML, or 4-Lane ML (as configured per Target's ML Frame format) | The only Coding that is compatible with 1-Lane (non-ML) HDR-BT Targets |
| 3<br>(“Alternate Mode”) | DUAL Lane<br>(see <b>Figure 128</b> )   | 1-Lane: <i>Not Supported</i><br>2-Lane ML: <b>Table 71</b> and <b>Table 74</b><br>4-Lane ML: <b>Table 72</b> and <b>Table 75</b>                | 0x19<br>(DUAL Lane)                              | Use 2-Lane ML HDR-BT Frame formatting | May use 2-Lane ML or 4-Lane ML (as configured per Target's ML Frame format)          | Requires all HDR-BT Targets to support at least 1 additional data Lane |
| 7<br>(“Alternate Mode”) | QUAD Lane<br>(see <b>Figure 128</b> )   | 1-Lane: <i>Not Supported</i><br>2-Lane ML: <i>Not Supported</i><br>4-Lane ML: <b>Table 72</b> and <b>Table 75</b>                               | 0x3B<br>(QUAD Lane)                              | Use 4-Lane ML HDR-BT Frame formatting | Use 4-Lane ML only                                                                   | Requires all HDR-BT Targets to support all 3 additional data Lanes     |

All supported ML Frame formats shown in **Table 79** shall indicate which of these Data Transfer Codings they support, which in a mixed ML-configuration Bus determines their level of interoperability with other ML Frame formats.

6989 As noted in **Section 5.3.2.4**, configuring the I3C Bus (i.e., all HDR-BT capable Targets) to use an “Alternate  
6990 Mode” Data Transfer Coding requires all such Targets to be configured to use the “Alternate Mode” Coding.  
6991 This configuration may be done individually for each Target, by sending the MLANE Direct SET CCC with  
6992 Defining Byte 0x23 for each HDR-BT capable Target; or it may be done simultaneously for all Targets, by  
6993 sending the MLANE Broadcast CCC with Defining Byte 0x23.

6994 However, the Controller shall not attempt to configure any ML-capable HDR-BT Targets to use any  
6995 “Alternate Mode” Coding, unless it first ensures that all other HDR-BT Targets are capable of interoperating  
6996 with this Coding and may be configured to use a mutually interoperable ML Frame format that is based on  
6997 the same Coding.

6998 When a Target that supports any HDR-BT “Alternate Mode” Codings first receives either an MLANE Direct  
6999 SET CCC with Defining Byte 0x23 sent to an assigned Dynamic Address, or an MLANE Broadcast CCC  
7000 with Defining Byte 0x23 that is sent to the I3C Bus; and either CCC has a message with a Data Byte that  
7001 selects an ML Frame format based on such an “Alternate Mode” Coding which is not interoperable with  
7002 Coding 0, this shall change the HDR-BT configuration for the Device, and affect how the Device and its  
7003 Peripheral logic must interpret HDR-BT Header Blocks for all subsequent HDR-BT transfers. For HDR-BT  
7004 Mode, this configuration is defined as a ‘sticky’ state, and shall also determine how subsequent MLANE  
7005 CCCs are either accepted or rejected.

- 7006 • Such a change shall become ‘sticky’ if accepted, and shall affect the Peripheral logic that receives  
7007 HDR-BT transfers within the Device:
  - 7008 • **If the Device receives the MLANE Direct SET CCC with Defining Byte 0x23**, then such a  
7009 change shall only be accepted if the Device was previously configured to use Coding 0 (i.e.,  
7010 not in the ‘sticky’ state).
  - 7011 • **If the Device receives the MLANE Broadcast CCC with Defining Byte 0x23**, then such a change  
7012 shall always be accepted.
- 7013 • While in a ‘sticky’ state, the Device shall not accept a configuration change via the MLANE  
7014 Direct SET CCC with Defining Byte 0x23 to use any other ML Frame formats that are not  
7015 interoperable with that “Alternate Mode” Coding.
- 7016 • However, the Device shall continue to accept configuration changes via the MLANE Broadcast  
7017 CCC with Defining Byte 0x23 to use any other ML Frame formats that are valid and supported.  
7018 For such MLANE Broadcast CCCs, ‘sticky’ state checking is bypassed.

For HDR-BT Targets that support multiple assigned Addresses, HDR-BT defines several sets of conditions as valid actions (per **Section 5.3.1.1**) that apply to the use of the MLANE CCC with “Alternate Mode” Codings:

- Entering the ‘sticky’ state (i.e., switching from Coding 0 to any “Alternate Mode” Coding) affects all assigned Addresses within the Device (i.e., the shared Peripheral logic that receives HDR-BT transfers and matches assigned Addresses within HDR-BT Header Blocks). The Device shall not accept any subsequent MLANE Direct SET CCCs that would attempt to re-configure one assigned Address to use a Data Transfer Coding that is incompatible (i.e., not interoperable) with the first “Alternate Mode” Coding that was used to put the Device into the ‘sticky’ state.
- If the Device supports separate ML configurations for Group Addresses (per **Section 5.3.1.1.1**), then:
  - On entering the ‘sticky’ state, the Device shall change the ML configuration for all currently assigned Group Addresses to the common ML Frame format for that “Alternate Mode” Coding, per **Table 79**. The Device shall also apply this same common ML Frame format as the initial ML configuration for any subsequently assigned Group Addresses.
  - Such a configuration change shall also limit the available ML Frame formats that the Device might accept upon subsequent use of the MLANE Direct SET CCC with Defining Byte 0x23. This shall prevent any assigned Group Address from being re-configured to use a Coding that is not interoperable with the Dynamic Address (or one of the Dynamic Addresses, if multiple Dynamic Addresses are supported).
  - Per **Section 5.3.1.1.1**, an MLANE Direct SET CCC sent to an assigned Group Address shall not cause the Device to enter or leave the ‘sticky’ state, nor shall the Device change the ML configuration for any assigned Dynamic Address as a result. The Device shall only accept an MLANE Direct SET CCC with an ML Frame format sent to an assigned Group Address if that ML Frame format is compatible (i.e., interoperable) with the current ML configuration of the associated Dynamic Address.
- If the Device supports multiple assigned Dynamic Addresses (i.e., a composite Device that presents multiple Virtual Targets, per **Section 5.3.1.1.2**), then:
  - The first such MLANE Direct SET CCC sent to any assigned Dynamic Address with an ML Frame format based on an “Alternate Mode” Coding shall also change the ML configuration for the Device’s other assigned Dynamic Addresses, to use the common ML Frame format for that “Alternate Mode” Coding.

In this case, the Controller may (and should) send subsequent MLANE Direct SET CCCs to the Device’s other assigned Dynamic Addresses, with compatible ML Frame formats (or the same ML Frame format).

    - Similarly, the MLANE Broadcast CCC shall cause a simultaneous ML configuration change to all assigned Dynamic Addresses, as though the Device had received (and accepted) a series of MLANE Direct SET CCCs that were sent to each of its assigned Dynamic Addresses.
    - Note that the provided ML Frame format (i.e., the Data Byte after the Defining Byte) for each MLANE SET CCC (either Direct or Broadcast) must be valid and supported for the Device, if such configuration changes are to take effect, per **Section 5.1.9.3.30**.
    - Subsequent MLANE Direct SET CCCs sent to any assigned Dynamic Address shall only be accepted if the provided ML Frame format is compatible with that same “Alternate Mode” Coding (i.e., uses the same Coding, or one that is expressly defined to be interoperable). This shall prevent any assigned Dynamic Address from being subsequently re-configured to use a Coding that is not interoperable with other Dynamic Addresses.
  - If the Device supports both Group Addresses and multiple Dynamic Addresses (i.e., the union of both), then both sets of conditions listed above shall apply.

Once the Controller has configured the I3C Bus and all known HDR-BT capable Target Devices to use an “Alternate Mode” Coding, it must avoid such situations that might arise, in cases where a new Target Device might join or re-join the Bus (i.e., a Hot-Join Request, or a return from a deep sleep state with loss of configuration) and the Controller has not yet determined whether the Target Device supports HDR-BT Mode (and, if so, whether it also supports and can be configured to use an interoperable Coding). For some situations, the Controller must immediately stop all HDR-BT transfers if it detects an unknown Target Device, until it can fully determine such a Target Device’s capabilities and current configuration.

An HDR-BT Target that has been configured to use Coding 0 with additional data Lanes (i.e., DUAL or QUAD transfers in Coding 0) may be switched back to 1-Lane compatibility mode (in Coding 0) via the MLANE CCC, using Defining Byte 0x23 and Data Byte 0x00, via Broadcast CCC or Direct CCC. This result can also be achieved by sending the MLANE CCC with the Sub-Command for Reset ML (i.e., Defining Byte 0x7F) in its Broadcast CCC or Direct SET CCC formats. However, an HDR-BT Target that has been configured to use an “Alternate Mode” Coding may only be configured back to 1-Lane compatibility mode (i.e., back to Coding 0 and leaving the ‘sticky’ state) by sending the MLANE Broadcast CCC (i.e., not a Direct SET CCC) with Defining Byte 0x23 and Data Byte 0x00, or by sending the MLANE Broadcast CCC with the Sub-Command for Reset ML.

**Note:**

*When an HDR-BT Target that has been configured to use an “Alternate Mode” Coding leaves the ‘sticky’ state or accepts a new ML Frame format based on an “Alternate Mode” Coding (i.e., by receiving the MLANE Broadcast CCC with either sub-command, as defined above), the ML configurations for all assigned Addresses shall be simultaneously configured back to either 1-Lane compatibility mode (i.e., with the Sub-Command for Reset ML), or to the new ML Frame format (i.e., with Defining Byte 0x23).*

7090  
7091 **Figure 139** illustrates the valid state transitions for HDR-BT Targets that support any “Alternate Mode” Codings, when used with the MLANE SET CCC with Defining Byte 0x23.



7092  
7093 **Figure 139 Valid State Transitions for HDR-BT Data Transfer Codings**

7094 **Note:**

7095 In **Figure 139**, the solid lines show the valid state transitions for entering the ‘sticky’ state from Coding  
7096 0, via the MLANE Direct SET CCC or the MLANE Broadcast CCC. The dashed lines show the valid  
7097 state transitions within a currently configured Coding, via the MLANE Direct SET CCC with Defining  
7098 Byte 0x23. Such state transitions apply to Devices that support a single Address (i.e., only a Dynamic  
7099 Address) as well as Devices that support multiple Addresses (i.e., any combination of Virtual Targets  
7100 with multiple Dynamic Addresses, or currently assigned Group Addresses). The circles with double  
7101 lines show the common ML configurations for each Coding, which shall be used for each newly  
7102 assigned Group Address (if supported). This diagram does not show the valid state transitions for  
7103 leaving the ‘sticky’ state or changing to a different ‘Alternate Mode’ Coding via the MLANE Broadcast  
7104 CCC, although such valid state transitions are always possible via the MLANE Broadcast CCC with  
7105 Defining Byte 0x23.

In a Bus that mixes 1-Lane Target Devices (or ML-capable Target Devices in their default 1-Lane configuration) with 2-Lane ML and/or 4-Lane ML Target Devices that are all configured for Coding 0, any Target Devices that are configured for SINGLE Lane Coding 0 shall ignore any HDR-BT Data Blocks and HDR-BT CRC Blocks that are part of a transaction (either generic, or Direct CCC flow) addressed to another Target Device that is configured for DUAL Lane Coding 0 or QUAD Lane Coding 0. Because these DUAL Lane or QUAD Lane formatted Blocks might not have the same format and length that a Target Device in its default configuration can understand, such a Target Device may instead ignore these HDR-BT Blocks and wait for the HDR Restart Pattern, after which it will be able to receive and understand a subsequent HDR-BT Header Block and correctly parse its **Address** field.

CCC transactions in HDR-BT that use Multi-Lane shall conform to the special requirements of the CCC framing and modality for HDR-BT (see *Section 5.2.4.4*), as a specific instantiation of the generic CCC framing and modality for all HDR Modes (see *Section 5.2.1.2*). Such HDR-BT-capable Targets shall monitor the Bus for HDR-BT transactions that are either HDR-BT generic write/read transfers, or common CCC flow elements, according to the currently configured Data Transfer Coding of the Device:

- **If such a Target only has a single Dynamic Address:** Then the ML configuration (i.e., currently configured ML Frame format) for the Target's Dynamic Address shall apply to match either the assigned Dynamic Address or the Broadcast Address (i.e., 7'h7E) for common CCC flow elements, according to the Data Transfer Coding for this ML configuration.
- **If such a Target has multiple Dynamic Addresses** (i.e., a composite Device that presents Virtual Targets, per *Section 5.3.1.1.2*): Then the ML configuration (i.e., currently configured ML Frame format) for all such Dynamic Addresses must be interoperable, so that the Target can match the Broadcast Address (i.e., 7'h7E) with the specified ML Frame formatting of the Data Transfer Coding, for common CCC flow elements (per *Table 79*).

## Coding 0

The default ML Frame format for HDR-BT Devices is Coding 0 (Compatible Mode) which requires no additional data Lanes.

Coding 0 is intended for Buses with HDR-BT Targets of mixed support for Multi-Lane's additional data Lanes. It is interoperable with all 1-Lane, 2-Lane ML, and 4-Lane ML HDR-BT Targets that support Coding 0.

In Coding 0:

- All HDR-BT Header Blocks shall be transmitted using SDA[0] (i.e., 1-Lane mode) in order to ensure that all Targets that support HDR-BT are always able to receive and understand the format of the Header Block. This includes the specific variants of the Header Block used for the common CCC flow elements in the HDR-BT CCC flows. The bit packing shall follow the formats shown in *Table 70* for Data Bytes and *Table 73* for the Transition Byte.
- For generic HDR-BT transactions (i.e., not part of the HDR-BT CCC flows), all subsequent HDR-BT Data Blocks and the HDR-BT CRC Block shall be transmitted in a bit packing format appropriate for the Target's currently configured ML Frame format (see *Table 79*). If the Target is not ML-capable, or has not been configured to use a ML Frame format that uses additional data Lanes, then this bit packing format shall be the standard 1-Lane HDR-BT format (i.e., SDA[0] only).
- For all HDR-BT CCC flows, all common CCC flow elements shall be transmitted using SDA[0] (i.e., 1-Lane mode), so that all HDR-BT Targets can participate in the CCC flows regardless of their currently configured ML Frame format or the number of additional data Lanes they support. In this manner, all ML Frame formats that support Coding 0 are mutually interoperable for the common CCC flow elements.
- Following the HDR-BT CCC Selector Block in a Direct CCC flow, all subsequent HDR-BT Data Blocks and the HDR-BT CRC Block that are addressed to a Target currently configured for Coding 0 shall be transmitted in a bit packing format appropriate for the Target's currently configured ML Frame format (see *Table 79*).

### Coding 3

An optional Coding for HDR-BT Devices is Coding 3 (“Alternate Mode”), which requires at least one additional data Lane.

Coding 3 is intended for Buses with HDR-BT Targets that support at least one additional data Lane for Multi-Lane. It is interoperable with all other “Alternate Mode” Codings marked as Coding 3 in **Table 78**, and expressly not interoperable with any 1-Lane HDR-BT Targets, or any 2-Lane ML HDR-BT Targets that do not support Coding 3. When addressing HDR-BT Targets that support three additional data Lanes, it provides additional transfer speed for these per-Target transactions, while still allowing interoperability with any other HDR-BT Targets that only support one additional data Lane and have been configured for Coding 3.

In Coding 3:

- All HDR-BT Header Blocks shall be transmitted using SDA[0] and SDA[1], using the DUAL Lane bit packing formats shown in **Table 71** for Data Bytes and **Table 74** for the Transition Byte. See **Figure 128** for the HDR-BT Header Block format, **Figure 130** for the HDR-BT Data Block format, and **Figure 133** for the HDR-BT CRC Block format.
- For generic HDR-BT transactions (i.e., not part of the HDR-BT CCC flows), all subsequent HDR-BT Data Blocks and the HDR-BT CRC Block shall be transmitted in a bit packing format appropriate for the Target’s currently configured ML Frame format, using either DUAL Lane or QUAD Lane formats (see **Table 79**).
- For all HDR-BT CCC flows, all common CCC flow elements shall be transmitted using SDA[0] and SDA[1], using the same DUAL Lane bit packing formats. All HDR-BT Targets that are currently configured for Coding 3 can participate in the CCC flows regardless of the number of additional Lanes (i.e., Lanes beyond SDA[1]) that they are configured to use. In this manner, all ML Frame formats that support Coding 3 are mutually interoperable, for the common CCC flow elements.
- Following the HDR-BT CCC Selector Block in a Direct CCC flow, all subsequent HDR-BT Data Blocks and the HDR-BT CRC Block addressed to a Target currently configured for Coding 3 shall be transmitted in a bit packing format appropriate for the Target’s currently configured ML Frame format, using either DUAL Lane or QUAD Lane formats (see **Table 79**).

This “Alternate Mode” is not compatible with other ML-capable HDR-BT Targets not configured to use an “Alternate Mode” Coding marked as Coding 3, or other HDR-BT Targets that are not ML-capable. Such Targets will not correctly receive and understand any HDR-BT Header Blocks transmitted in this bit packing format, and as a result they will not participate in any HDR-BT transactions, and could even cause communication errors.

**Note:**

*In Coding 3, the Controller shall not use the SINGLE Lane formats for any HDR-BT structured protocol elements, such as the HDR-BT Header Block, Data Block or CRC Block.*

*Once an HDR-BT capable Target that supports Coding 3 has been configured to use an ML Frame format that uses Coding 3 or any other “Alternate Mode” Coding that is interoperable, the entire Device enters a ‘sticky’ state and shall not accept any configuration changes via the MLANE CCC that might use any other Coding not interoperable with Coding 3, except for certain MLANE sub-commands sent as a Broadcast CCC. If the MLANE Direct SET CCC is used, then such a Device may only enter the ‘sticky’ state from Coding 0.*

A Controller shall not enable any ML-capable HDR-BT Targets to use any “Alternate Mode” Coding marked as Coding 3, unless it first ensures that all other HDR-BT Targets are capable of interoperating with Coding 3. A Controller shall not initiate any HDR-BT transactions using DUAL Lane or QUAD Lane bit packing formats for all HDR-BT Blocks, unless it has previously configured all HDR-BT Targets on the Bus to use an “Alternate Mode” Coding marked as Coding 3. Once a Controller has configured all HDR-BT Targets on the Bus to use Coding 3, it must drive all HDR-BT transactions using the correct bit packing format for each HDR-BT Block, according to the conditions above.

## Coding 7

An optional Coding for HDR-BT Devices is Coding 7 (“Alternate Mode”), which requires three additional data Lanes.

Coding 7 is intended for Buses with HDR-BT Targets that support three additional data Lanes for Multi-Lane. It is not interoperable with any other Codings in **Table 79**, and is expressly not interoperable with any 1-Lane or 2-Lane ML HDR-BT Targets, nor with any 4-Lane ML HDR-BT Targets that do not support Coding 7.

In Coding 7:

- All HDR-BT Blocks shall be transmitted using SDA[0], SDA[1], SDA[2], and SDA[3], using the QUAD Lane bit packing formats shown in **Table 72** for Data Bytes and **Table 75** for the Transition Byte. See **Figure 128** for the HDR-BT Header Block format, **Figure 130** for the HDR-BT Data Block format, and **Figure 133** for the HDR-BT CRC Block format.
- For generic HDR-BT transactions and for all HDR-BT CCC flows, all HDR-BT Data Blocks and HDR-BT CRC Blocks shall also be transmitted in the same QUAD Lane bit packing format.

This “Alternate Mode” is not compatible with other ML-capable HDR-BT Targets that are not configured to use an “Alternate Mode” Coding marked as Coding 7, or other HDR-BT Targets that are not ML-capable. Such Targets will not correctly receive and understand any HDR-BT Header Blocks transmitted in this bit packing format, and as a result they will not participate in any HDR-BT transactions, and could even cause communication errors.

**Note:**

*In Coding 7, the Controller shall not use the SINGLE Lane or DUAL Lane formats for any HDR-BT structured protocol elements, such as the HDR-BT Header Block, Data Block or CRC Block.*

*Once an HDR-BT capable Target that supports Coding 7 has been configured to use an ML Frame format that uses Coding 7 or any other “Alternate Mode” Coding that is interoperable, the entire Device enters a ‘sticky’ state and shall not accept any configuration changes via the MLANE CCC that might use any other Coding not interoperable with Coding 7, except for certain MLANE sub-commands sent as a Broadcast CCC. If the MLANE Direct SET CCC is used, then such a Device may only enter the ‘sticky’ state from Coding 0.*

A Controller shall not enable any ML-capable HDR-BT Targets to use any “Alternate Mode” Coding marked as Coding 7, unless it first ensures that all other HDR-BT Targets are capable of interoperating with Coding 7. A Controller shall not initiate any HDR-BT transactions using QUAD Lane bit packing formats for all HDR-BT Blocks, unless it has previously configured all HDR-BT Targets on the Bus to use an “Alternate Mode” Coding marked as Coding 7. Once a Controller has configured all HDR-BT Targets on the Bus to use Coding 7, it must drive all HDR-BT transactions using QUAD Lane bit packing formats for all HDR-BT Blocks.

### 5.3.2.4.2 HDR-BT DUAL Coding

The default Coding for HDR-BT DUAL is Coding 0 (compatible mode); its additional Data Byte used by the MLANE CCC is 0x01 (i.e., {5'd0, 3'd1}).

In this ML Frame format, all HDR-BT Blocks that are part of generic HDR-BT transactions (except for the HDR-BT Header Blocks), or that comprise the per-Target CCC flow elements, shall be transmitted using SDA[0] and SDA[1], using the DUAL Lane bit packing formats shown in *Table 71* for Data Bytes and *Table 74* for the Transition Byte. See *Figure 130* for the HDR-BT Data Block format, and *Figure 133* for the HDR-BT CRC Block format. For additional details, see also Coding 0 in *Section 5.3.2.4.1*.

Any Targets that are not configured for DUAL Lane Coding 0 might not be able to receive and understand any HDR-BT Data Blocks and HDR-BT CRC Blocks that are not part of a transaction (either generic, or Direct CCC flow) addressed to their Target Address. Because these Blocks might not have the same format and length as their currently configured ML Frame format, such a Target may instead ignore these HDR-BT Blocks and wait for the HDR Restart Pattern, after which it will be able to receive and understand a subsequent HDR-BT Header Block and correctly parse its **Address** field.

#### “Alternate Mode” Codings for DUAL Lane: Coding 3

In some Bus configurations, it might be desirable to utilize one additional data Lane for HDR-BT Blocks, for increased performance and Bus efficiency. This requires all Targets on the Bus that support HDR-BT to be configured to support ML Frame formats that are interoperable (i.e., that expect to use the same number of additional data Lanes in the same locations in HDR-BT transactions).

One “Alternate Mode” Coding for HDR-BT DUAL is Coding 3; its additional Data Byte used by the MLANE CCC is 0x19 (i.e., {5'd3, 3'd1}).

In this ML Frame format, HDR-BT Blocks that are part of generic HDR-BT transactions (except for the HDR-BT Header Blocks), or that comprise the per-Target CCC flow elements, shall be transmitted using SDA[0] and SDA[1], using the DUAL Lane bit packing formats listed above. For additional details, see also Coding 3 in *Section 5.3.2.4.1*.

As previously stated, the HDR-BT Header Blocks and all HDR-BT Blocks comprising the core CCC flow elements shall be transmitted in DUAL Lane bit packing format.

In a Bus that mixes 2-Lane ML and 4-Lane ML Targets, all of which are configured for Coding 3, any Targets configured for DUAL Lane Coding 3 shall ignore any HDR-BT Data Blocks and HDR-BT CRC Blocks that are part of a transaction (either generic, or Direct CCC flow) addressed to another Target configured for QUAD Lane Coding 3.

Any Targets not configured for DUAL Lane Coding 3 might not be able to receive and understand any HDR-BT Data Blocks and HDR-BT CRC Blocks that are not part of a transaction (either generic, or Direct CCC flow) addressed to their Target Address. Because these Blocks might not have the same format and length as their currently configured ML Frame format, such a Target may instead ignore these HDR-BT Blocks and wait for the HDR Restart Pattern, after which it will be able to receive and understand a subsequent HDR-BT Header Block and correctly parse its **Address** field.

### 5.3.2.4.3 HDR-BT QUAD Coding

The default Coding for HDR-BT QUAD is Coding 0 (Compatible Mode); its additional Data Byte used by the MLANE CCC is 0x03 (i.e., {5'd0, 3'd3}).

In this ML Frame format, all HDR-BT Blocks that are part of generic HDR-BT transactions (except for the HDR-BT Header Blocks), or that comprise the per-Target CCC flow elements, shall be transmitted using SDA[0], SDA[1], SDA[2], and SDA[3], using the QUAD Lane bit packing formats shown in *Table 72* for Data Bytes and *Table 75* for the Transition Byte. See *Figure 130* for the HDR-BT Data Block format, and *Figure 133* for the HDR-BT CRC Block format. For additional details, see also Coding 0 in *Section 5.3.2.4.1*.

Any Targets not configured for QUAD Coding 0 might not be able to receive and understand any HDR-BT Data Blocks and HDR-BT CRC Blocks that are not part of a transaction (either generic, or Direct CCC flow) addressed to their Target Address. Because these Blocks might not have the same format and length as their currently configured ML Frame format, such a Target may instead ignore these HDR-BT Blocks and wait for the HDR Restart Pattern, after which it will be able to receive and understand a subsequent HDR-BT Header Block and correctly parse its **Address** field.

#### “Alternate Mode” Codings for QUAD Lane

In some Bus configurations, it might be desirable to utilize the three additional data Lanes for HDR-BT Blocks, for increased performance and Bus efficiency. This requires all Targets on the Bus that support HDR-BT to be configured to support ML Frame formats that are interoperable (i.e., that expect to use the same number of additional data Lanes in the same locations in HDR-BT transactions).

#### Coding 3

One “Alternate Mode” Coding for HDR-BT QUAD is Coding 3; its additional Data Byte used by the MLANE CCC is 0x1B (i.e., {5'd3, 3'd3}).

In this ML Frame format, HDR-BT Blocks that are part of generic HDR-BT transactions (except for the HDR-BT Header Blocks), or that comprise the per-Target CCC flow elements, shall be transmitted using SDA[0], SDA[1], SDA[2], and SDA[3], using the QUAD Lane bit packing formats listed above. See also Coding 3 in *Section 5.3.2.4.1*.

As previously stated, the HDR-BT Header Blocks and all HDR-BT Blocks comprising the core CCC flow elements shall be transmitted in DUAL Lane bit packing format.

In a Bus that mixes 2-Lane ML and 4-Lane ML Targets, all of which are configured for Coding 3, any Targets configured for QUAD Lane Coding 3 shall ignore any HDR-BT Data Blocks and HDR-BT CRC Blocks that are part of a transaction (either generic, or Direct CCC flow) addressed to another Target configured for DUAL Lane Coding 3.

Any Targets not configured for QUAD Lane Coding 3 might not be able to receive and understand any HDR-BT Data Blocks and HDR-BT CRC Blocks that are not part of a transaction (either generic, or Direct CCC flow) addressed to their Target Address. Because these Blocks might not have the same format and length as their currently configured ML Frame format, such a Target may instead ignore these HDR-BT Blocks and wait for the HDR Restart Pattern, after which it will be able to receive and understand a subsequent HDR-BT Header Block and correctly parse its **Address** field.

#### Coding 7

Another “Alternate Mode” Coding for HDR-BT QUAD is Coding 7; its additional Data Byte used by the MLANE CCC is 0x3B (i.e., {5'd7, 3'd3}).

In this ML Frame format, all HDR-BT Blocks shall be transmitted using SDA[0], SDA[1], SDA[2], and SDA[3], using the QUAD Lane bit packing formats listed above. See also Coding 7 in *Section 5.3.2.4.1*.

As QUAD Lane Coding 7 is not interoperable with any other Codings, nor with any other HDR-BT Targets supporting fewer than 3 additional data Lanes, it shall not be used in any Bus configuration in which it could cause communication errors.

## 6 I3C Electrical Specifications

### 6.1 DC I/O Characteristics

This Section describes the DC operating parameters of the I3C interface in two modes: Push-Pull Mode and Open Drain Mode. In Push-Pull Mode, the SDA pin drives at higher speeds with a totem-pole driver.

Two important parameters should be noted for I3C:

- The I3C interface targets nominal operating voltages of 1.2V, 1.8V, and 3.3V or less. The I3C interface is not characterized for 5V systems, but could be extended to support 5V if sufficient driver strength, reduced diameter, and/or reduced speed is used in the system.
- For peak speeds the capacitance loading allowed is reduced to 50 pF, which is much lower than Legacy I<sup>2</sup>C. With I3C higher capacitance Busses are possible, but only at reduced speeds and with reduced features (e.g., if no I<sup>2</sup>C Devices are supported).

Optionally, the I3C Basic interface also targets a nominal operating voltage of 1.0V and a 100 pF capacitive loading for new usages, such as Serial Presence Detect (SPD) in DDR5.

**Table 82 I3C I/O Stage Characteristics Common to Push-Pull Mode and Open Drain Mode**

| Parameter                                 | Symbol     | Conditions                                                                                                | Min                                                                               | Typ                       | Max            | Unit          | Notes         |
|-------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------|----------------|---------------|---------------|
| Operating Voltage                         | $V_{DD}$   | —                                                                                                         | 1.10                                                                              | 1.20                      | 1.30           | V             | 1             |
|                                           |            |                                                                                                           | 1.65                                                                              | 1.80                      | 1.95           |               |               |
|                                           |            |                                                                                                           | 2.97                                                                              | 3.30                      | 3.63           |               |               |
| Low-Level Input Voltage                   | $V_{IL}$   | —                                                                                                         | -0.1 * $V_{DD}$                                                                   | —                         | 0.3 * $V_{DD}$ | V             | 8             |
| High-Level Input Voltage                  | $V_{IH}$   | —                                                                                                         | 0.7 * $V_{DD}$                                                                    | —                         | 1.1 * $V_{DD}$ | V             | 8             |
| Schmitt Trigger Inputs Hysteresis         | $V_{hys}$  | —                                                                                                         | 0.1 * $V_{DD}$                                                                    | —                         | —              | V             | —             |
| Output Low Level                          | $V_{OL}$   | For $V_{DD} < 1.4V$ : $I_{OL} = 2\text{ mA}$                                                              | —                                                                                 | —                         | 0.18           | V             | 2             |
|                                           |            | For $V_{DD} \geq 1.4V$ : $I_{OL} = 3\text{ mA}$                                                           | —                                                                                 | —                         | 0.27           | V             | 2             |
| Input Current<br>(per Input-Only I/O Pin) | $I_i$      | -100 mV < $V_i < V_{DD} + 100\text{ mV}$ for $\geq 1.8V$ nominal                                          | -10                                                                               | —                         | 10             | $\mu\text{A}$ | 2             |
|                                           |            | -100 mV < $V_i < V_{DD} + 100\text{ mV}$ for $< 1.8V$ nominal                                             | -5                                                                                | —                         | 5              | $\mu\text{A}$ | 2             |
| Capacitance<br>(per I/O Pin)              | $C_i$      | For $< 1.8V$ nominal                                                                                      | —                                                                                 | —                         | 5              | pF            | 5             |
|                                           |            | For $\geq 1.8V$ nominal                                                                                   | —                                                                                 | —                         | 10             | pF            | 5             |
| Capacitance Mismatch Between Pins         | $\Delta C$ | Difference between SDA and SCL capacitance $C_i \leq 5\text{ pF}$                                         | —                                                                                 | —                         | 1.5            | pF            | 5             |
|                                           |            | Difference between SDA and SCL capacitance $C_i > 5\text{ pF}$                                            | —                                                                                 | —                         | 3              | pF            | 5             |
| <b>Push-Pull Only</b>                     |            |                                                                                                           |                                                                                   |                           |                |               |               |
| Output High Level                         | $V_{OH}$   | For $V_{DD} < 1.4V$ : $I_{OH} = -2\text{ mA}$                                                             | $V_{DD} - 0.18$                                                                   | —                         | —              | V             | 2, 9          |
|                                           |            | For $V_{DD} \geq 1.4V$ : $I_{OH} = -3\text{ mA}$                                                          | $V_{DD} - 0.27$                                                                   | —                         | —              | V             | 2, 9          |
| <b>Legacy Mode with Pull-Up</b>           |            |                                                                                                           |                                                                                   |                           |                |               |               |
| Pull-Up for Open Drain                    | $R_p$      | $t_r = \text{Max rise time}$<br>$C_b = \text{Bus Capacitance}$<br>$V_{DD} = 1.2V, 1.8V, \text{ or } 3.3V$ | $\frac{V_{DD} - V_{OL}}{3\text{ mA}}$<br><i>for <math>V_{DD} \geq 1.4V</math></i> | $\frac{t_r}{0.8473 * Cb}$ | 2833           | $\Omega$      | 3, 4,<br>6, 7 |
|                                           |            | $t_r = 120\text{ ns}$<br>$C_b = 50\text{ pF}$                                                             |                                                                                   |                           |                |               |               |

**Note:**

- 1) This I3C Basic Specification considered only 1.2V, 1.8V, and 3.3V, with associated tolerances, for typical cases requiring peak speeds using reduced capacitance loading. Other voltage ranges are not prohibited; for example, see **Table 83**. Any I3C Bus implementation shall ensure the correct operation of the Devices resident on the Bus, notably the inter-compatibility of their voltage ranges.
- 2) Negative sign for currents indicates that the Device is sinking current in this condition; see note 9.
- 3) The current of the Pull-Up must balance the time to pull SDA High against the capacitance of the line, with the current that a Target Device must sink in order to hold SDA at  $V_{OL}$ . Unless all Target Devices are known to have sufficiently strong drive (i.e., to pull SDA below  $V_{OL}$  in time), the Pull-Up should be sized between the minimum and maximum values.  
$$V(t1) = 0.3 * V_{DD} = V_{DD} (1 - e^{-t1/RC}); \text{ then } t1 = 0.3566749 * RC$$
$$V(t2) = 0.7 * V_{DD} = V_{DD} (1 - e^{-t2/RC}); \text{ then } t2 = 1.2039729 * RC$$
$$T = t2 - t1 = 0.8473 * RC$$
- 4) Pull-Up for Open Drain shall be switched off during I3C Push-Pull operation. May be implemented as: A Pull-Up internally; A current source internally; or an external Pull-Up resistor driven by a pin.
- 5) For Devices that support both 1.8V and 3.3V, the larger capacitance may be used.
- 6) Open Drain never occurs on SCL
- 7) A weak Pull-Up or High-Keeper is separately sized, whether passive or active; this needs to be applied for both Controller handoff (see **Section 5.1.7.2**) and “Park1,High-Z” uses in HDR-BT Mode (see **Section 5.2.4.2**).
- 8) The  $V_{IL\ min}$  and  $V_{IH\ max}$  allow for normal undershoot and overshoot on a Bus. Voltages that are lower than  $V_{IL\ min}$  and higher than  $V_{IH\ max}$  will be handled by protection circuits (i.e., ESD protection) as with any GPIO or standard pad Peripheral. The board designer should be made aware of any deviations outside  $V_{IL\ min}$  and  $V_{IH\ max}$ .
- 9) A Device shall be able to continuously sink the indicated current (indicated as a negative number) in this condition. For most pad types, the drive strength must be rated at twice the indicated current, since the rated drive strength is normally the peak current when the voltage difference is at its maximum. For  $V_{OL}$ , this is SDA at  $V_{DD}$ ; for  $V_{OH}$ , this is SDA at ground.

**Table 83 I3C Low Voltage / High Capacitive Load I/O Stage Characteristics for Push-Pull Mode and Open Drain Mode**

| Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Symbol           | Conditions                                                                                                   | Min                                    | Typ                        | Max                   | Unit             | Notes |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------|-----------------------|------------------|-------|
| Operating Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | V <sub>DD</sub>  | —                                                                                                            | 0.95                                   | 1.0                        | 1.25                  | V                | —     |
| Low-Level Input Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | V <sub>IL</sub>  | —                                                                                                            | -0.3                                   | —                          | 0.3                   | V                | —     |
| High-Level Input Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | V <sub>IH</sub>  | —                                                                                                            | 0.7                                    | —                          | 1.25                  | V                | 1     |
| Schmitt Trigger Inputs Hysteresis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | V <sub>hys</sub> | —                                                                                                            | 0.1 * V <sub>DD</sub>                  | —                          | 0.4 * V <sub>DD</sub> | V                | —     |
| Output Low Level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | V <sub>OL</sub>  | I <sub>OL</sub> = 4 mA                                                                                       | —                                      | —                          | 0.3                   | V                | 2     |
| Input Current (per Input-Only I/O Pin)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | I <sub>i</sub>   | -100 mV < V <sub>i</sub> < V <sub>DD</sub>                                                                   | -5                                     | —                          | 5                     | μA               | 2     |
| Capacitance (per I/O Pin)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | C <sub>i</sub>   | —                                                                                                            | —                                      | —                          | 5                     | pF               | —     |
| Capacitance Mismatch Between Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ΔC               | —                                                                                                            | —                                      | —                          | 1.5                   | pF               | —     |
| <b>Push-Pull Only</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                  |                                                                                                              |                                        |                            |                       |                  |       |
| Output High Level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | V <sub>OH</sub>  | I <sub>OH</sub> = -3 mA                                                                                      | 0.75                                   | —                          | —                     | V                | 2     |
| <b>Legacy Mode with Pull-Up</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                                                                                                              |                                        |                            |                       |                  |       |
| Pull-Up for Open Drain                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R <sub>p</sub>   | t <sub>r</sub> = Max rise time (100 ns)<br>C <sub>b</sub> = Bus Capacitance (100 pF)<br>V <sub>DD</sub> = 1V | $\frac{V_{DD} - V_{OL}}{4 \text{ mA}}$ | $\frac{t_r}{0.8473 * C_b}$ | Ω                     | 3, 4,<br>6, 7, 8 |       |
| <b>Note:</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 1) V <sub>DD</sub> with respect to Typical V <sub>DD</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 2) Negative sign for currents indicates current direction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 3) V(t1) = 0.3 * V <sub>DD</sub> = V <sub>DD</sub> (1 - e <sup>-t1/RC</sup> ); then t1 = 0.3566749 * RC<br>V(t2) = 0.7 * V <sub>DD</sub> = V <sub>DD</sub> (1 - e <sup>-t2/RC</sup> ); then t2 = 1.2039729 * RC<br>T = t2 - t1 = 0.8473 * RC                                                                                                                                                                                                                                                                                                                         |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 4) For higher capacitance Buses, Pull-Up for Open Drain should be switched off during I3C Push-Pull operation. This may be implemented as: A Pull-Up internally; a current source internally; an external Pull-Up resistor driven by a pin; or any combination of the above. The effective resistance comprising the Open Drain Pull-Up and High-Keeper Pull-Up shall be sized sufficiently to allow the Target to pull SDA Low within t <sub>DIG_L</sub> for adjusted clock speeds, and to allow SDA to rise within t <sub>rDA</sub> , per <b>Section 5.1.3.1</b> . |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 6) Open-Drain never occurs on SCL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 7) A weak pull-up needs to be applied as well for Controller handoff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  |                                                                                                              |                                        |                            |                       |                  |       |
| 8) R <sub>p</sub> Min should be decided based on the V <sub>IL</sub> specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                  |                                                                                                              |                                        |                            |                       |                  |       |

I3C supports Legacy I<sup>2</sup>C Targets. An important feature of an I<sup>2</sup>C Target is the 50 ns Spike Filter on the SDA and SCL pads. If a Spike Filter is implemented on all I<sup>2</sup>C Devices present on the I3C Bus, then the I3C Bus may operate at maximum rated clock frequency. If any I<sup>2</sup>C Device does not have a Spike Filter, then the I3C Bus speed is determined by the slowest Legacy I<sup>2</sup>C Device without a Spike Filter. Other requirements of an I<sup>2</sup>C Legacy Target are listed in *Table 84*.

**Table 84 Legacy I<sup>2</sup>C Device Requirements When Operating on I3C**

| Feature                                         | Required | Desirable | Not Used | Not Allowed | Notes |
|-------------------------------------------------|----------|-----------|----------|-------------|-------|
| <b>Fm Speed</b>                                 | X        | —         | —        | —           | —     |
| <b>Fm+ Speed</b>                                | —        | X         | —        | —           | —     |
| <b>HS and UFm</b>                               | —        | —         | X        | —           | 2     |
| <b>Static I<sup>2</sup>C Address</b>            | X        | —         | —        | —           | —     |
| <b>50 ns Spike Filter</b>                       | —        | X         | —        | —           | 1     |
| <b>Clock Stretching by Target</b>               | —        | —         | —        | X           | —     |
| <b>I<sup>2</sup>C Extended Address (10 bit)</b> | —        | —         | X        | —           | 2     |
| <b>I3C Reserved Address</b>                     | —        | —         | —        | X           | —     |

**Note:**

- 1) Lack of Spike Filter will severely degrade Bus performance and eliminate certain I3C Bus features
- 2) “Not Used” means that the I3C Controller will not make use of the I<sup>2</sup>C feature, however if the Target supports the feature, then it will not interfere with I3C Bus operation.

## 6.2 Timing Specification

7335 A key feature of I3C is to maximize the speed of data transfer and minimize the time required for low-power  
7336 Devices to remain in non-sleep states. In SDR (Single Data Rate) Mode this is accomplished by keeping Bus  
7337 capacitance low and clock speed high. For large packets of data an additional speed improvement is possible  
7338 using HDR Modes, where data is transferred on every clock edge. I3C supports Legacy I<sup>2</sup>C Fm and Fm+  
7339 Modes. **Table 85** gives reference timing requirements used in Legacy Mode.

7340

**Table 85 I3C Timing Requirements When Communicating With I<sup>2</sup>C Legacy Devices**

| Parameter                                                 | Symbol              | Timing Diagram                         | Legacy Mode<br>400kHz / Fm           |     | Legacy Mode<br>1MHz / Fm+            |     | Units | Notes |
|-----------------------------------------------------------|---------------------|----------------------------------------|--------------------------------------|-----|--------------------------------------|-----|-------|-------|
|                                                           |                     |                                        | Min                                  | Max | Min                                  | Max |       |       |
| SCL Clock Frequency                                       | f <sub>SCL</sub>    | —                                      | 0                                    | 0.4 | 0                                    | 1.0 | MHz   | —     |
| Setup Time for a Repeated START                           | t <sub>SU_STA</sub> | <i>Figure 140</i>                      | 600                                  | —   | 260                                  | —   | ns    | —     |
| Hold Time for a (Repeated) START                          | t <sub>HD_STA</sub> | <i>Figure 140</i>                      | 600                                  | —   | 260                                  | —   | ns    | —     |
| SCL Clock Low Period                                      | t <sub>LOW</sub>    | <i>Figure 140</i><br><i>Figure 141</i> | 1300                                 | —   | 500                                  | —   | ns    | —     |
|                                                           | t <sub>DIG_L</sub>  | <i>Figure 141</i>                      | t <sub>LOW</sub> + t <sub>rCL</sub>  | —   | t <sub>LOW</sub> + t <sub>rCL</sub>  | —   | ns    | —     |
| SCL Clock High Period                                     | t <sub>HIGH</sub>   | <i>Figure 140</i><br><i>Figure 141</i> | 600                                  | —   | 260                                  | —   | ns    | —     |
|                                                           | t <sub>DIG_H</sub>  | <i>Figure 141</i>                      | t <sub>HIGH</sub> - t <sub>rCL</sub> | —   | t <sub>HIGH</sub> + t <sub>rCL</sub> | —   | ns    | —     |
| Data Setup Time                                           | t <sub>SU_DAT</sub> | <i>Figure 140</i>                      | 100                                  | —   | 50                                   | —   | ns    | —     |
| Data Hold Time                                            | t <sub>HD_DAT</sub> | <i>Figure 140</i>                      | —                                    | —   | —                                    | —   | ns    | —     |
| SCL Signal Rise Time                                      | t <sub>rCL</sub>    | <i>Figure 140</i>                      | 20                                   | 300 | —                                    | 120 | ns    | —     |
| SCL Signal Fall Time                                      | t <sub>fCL</sub>    | <i>Figure 140</i>                      | 20 * (V <sub>DD</sub> / 5.5V)        | 300 | 20 * (V <sub>DD</sub> / 5.5V)        | 120 | ns    | —     |
| SDA Signal Rise Time                                      | t <sub>rDA</sub>    | <i>Figure 140</i>                      | 20                                   | 300 | —                                    | 120 | ns    | —     |
|                                                           | t <sub>rDA_OD</sub> | <i>Figure 144</i>                      | —                                    | —   | —                                    | —   | —     | —     |
| SDA Signal Fall Time                                      | t <sub>fDA</sub>    | <i>Figure 140</i>                      | 20 * (V <sub>DD</sub> / 5.5V)        | 300 | 20 * (V <sub>DD</sub> / 5.5V)        | 120 | ns    | —     |
| Setup Time for STOP                                       | t <sub>SU_STO</sub> | <i>Figure 140</i>                      | 600                                  | —   | 260                                  | —   | ns    | —     |
| Bus Free Time Between a STOP and a START                  | t <sub>BUF</sub>    | —                                      | 1.3                                  | —   | 0.5                                  | —   | μs    | —     |
| Pulse Width of Spikes that the Spike Filter Must Suppress | t <sub>SPIKE</sub>  | <i>Figure 156</i>                      | 0                                    | 50  | 0                                    | 50  | ns    | —     |

7341 During an I3C communication the drive on the SDA pin shall have the ability to dynamically switch between Push-Pull and Open Drain.  
 7342

7343

**Table 86 I3C Open Drain Timing Parameters**

| Parameter                                                             | Symbol             | Timing Diagram                         | I3C Open Drain Mode                     |                                                                                             | Units   | Notes |
|-----------------------------------------------------------------------|--------------------|----------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------|---------|-------|
|                                                                       |                    |                                        | Min                                     | Max                                                                                         |         |       |
| Low Period of SCL Clock                                               | $t_{LOW\_OD}$      | <i>Figure 144</i>                      | 200                                     | —                                                                                           | ns      | 1, 2  |
|                                                                       | $t_{DIG\_OD\_L}$   | <i>Figure 144</i>                      | $t_{LOW\_ODmin} + t_{fDA\_ODmin}$       | —                                                                                           | ns      | —     |
| High Period of SCL Clock (for First Broadcast Address)                | $t_{HIGH\_INIT}$   | —                                      | 200                                     | —                                                                                           | ns      | 9     |
| High Period of SCL Clock (for Mixed Bus)                              | $t_{HIGH}$         | <i>Figure 141</i>                      | —                                       | 41                                                                                          | ns      | 3, 4  |
|                                                                       | $t_{DIG\_H}$       | <i>Figure 141</i><br><i>Figure 156</i> | —                                       | $t_{HIGH} + t_{CF}$                                                                         | ns      | —     |
| High Period of SCL Clock (for Pure Bus)                               | $t_{HIGH}$         | <i>Figure 141</i>                      | 24<br>( $t_{HIGHmin}$ from Push-Pull)   | —                                                                                           | ns      | —     |
|                                                                       | $t_{DIG\_H}$       | <i>Figure 141</i><br><i>Figure 156</i> | 32<br>( $t_{DIG\_Hmin}$ from Push-Pull) | —                                                                                           | ns      | —     |
| Fall Time of SDA Signal                                               | $t_{fDA\_OD}$      | <i>Figure 144</i>                      | —                                       | 12                                                                                          | ns      | —     |
| SDA Data Setup Time During Open Drain Mode                            | $t_{SU\_OD}$       | <i>Figure 142</i><br><i>Figure 144</i> | 3                                       | —                                                                                           | ns      | —     |
| Clock After START (S) Condition                                       | $t_{CAS}$          | <i>Figure 144</i>                      | 38.4 nano                               | For ENTAS0: 1 $\mu$<br>For ENTAS1: 100 $\mu$<br>For ENTAS2: 2 milli<br>For ENTAS3: 50 milli | seconds | 5, 6  |
| Clock Before STOP (P) Condition                                       | $t_{CBP}$          | <i>Figure 145</i>                      | $t_{CASmin} / 2$                        | —                                                                                           | seconds | —     |
| Active Controller to Secondary Controller Overlap time during handoff | $t_{CRHPOoverlap}$ | <i>Figure 155</i>                      | $t_{DIG\_OD\_Lmin}$                     | —                                                                                           | ns      | 8     |
| Bus Available Condition                                               | $t_{AVAL}$         | —                                      | 1                                       | —                                                                                           | $\mu$ s | 7     |
| Bus Idle Condition                                                    | $t_{IDLE}$         | —                                      | 200                                     | —                                                                                           | $\mu$ s | —     |
| Time Internal Where New Controller Not Driving SDA Low                | $t_{NEWCRLOCK}$    | <i>Figure 155</i>                      | $t_{AVALmin}$                           | —                                                                                           | $\mu$ s | —     |

**Note:**

- 1)  $t_{LOW\_OD}$  Min was specified to be enough time for a pull-up resistor to pull the SDA line High in a typical system.
- 2) The Controller may use a shorter Low period if it knows that this is safe, i.e., that SDA is already above  $V_{IH}$
- 3) Based on  $t_{SPIKE}$ , rise and fall times, and interconnect
- 4) This maximum High period may be exceeded when the signals can be safely seen by Legacy I<sup>2</sup>C Devices, and/or in consideration of the interconnect (e.g., a short Bus)
- 5) On a Legacy Bus where I<sup>2</sup>C Devices need to see Start, the  $t_{CAS}$  Min value is further constrained (see **Section 5.1.3.3**)
- 6) Targets that do not support the optional ENTASx CCCs (see **Section 5.1.9.3.2**) shall use the  $t_{CAS}$  Max value shown for ENTAS3
- 7) On a Mixed Bus with Fm Legacy I<sup>2</sup>C Devices,  $t_{AVAL}$  is 300ns shorter than the Fm Bus Free Condition time ( $t_{BUF}$ )
- 8) This timing can be disregarded when external passive High-Keepers are applied on both SCL and SDA lines.
- 9) The Controller uses this timing to send the first Broadcast Address after Bus initialization, in order to disable the I<sup>2</sup>C Spike Filter for applicable I3C Target Devices (see **Section 5.1.2.2.2**).

7344

**Table 87 I3C Push-Pull Timing Parameters for SDR, ML, HDR-DDR, and HDR-BT Modes**

| Parameter                                                          | Symbol              | Timing Diagram                         | Min                                                                        | Typ                           | Max                                      | Units   | Notes |
|--------------------------------------------------------------------|---------------------|----------------------------------------|----------------------------------------------------------------------------|-------------------------------|------------------------------------------|---------|-------|
| SCL Clock Frequency                                                | $f_{SCL}$           | —                                      | 0.01                                                                       | 12.5                          | 12.9                                     | MHz     | 1     |
| SCL Clock Low Period                                               | $t_{LOW}$           | <i>Figure 140</i>                      | 24                                                                         | —                             | —                                        | ns      | —     |
|                                                                    | $t_{DIG\_L}$        | <i>Figure 141</i>                      | 32                                                                         | —                             | —                                        | ns      | 2, 4  |
| SCL Clock High Period<br>(for Mixed Bus)                           | $t_{HIGH\_MIXED}$   | <i>Figure 141</i>                      | 24                                                                         | —                             | —                                        | ns      | —     |
|                                                                    | $t_{DIG\_H\_MIXED}$ | <i>Figure 141</i>                      | 32                                                                         | —                             | 45                                       | ns      | 2, 3  |
| SCL Clock High Period<br>(for Pure Bus)                            | $t_{HIGH}$          | <i>Figure 140</i>                      | 24                                                                         | —                             | —                                        | ns      | —     |
|                                                                    | $t_{DIG\_H}$        | <i>Figure 141</i><br><i>Figure 140</i> | 32                                                                         | —                             | —                                        | ns      | 2     |
| Clock in to Data Out for Target                                    | $t_{SCO}$           | <i>Figure 147</i>                      | —                                                                          | —                             | 12                                       | ns      | 7, 8  |
| SCL Clock Rise Time                                                | $t_{CR}$            | <i>Figure 141</i>                      | —                                                                          | —                             | $150e06 * 1 / f_{SCL}$<br>(capped at 60) | ns      | 5     |
| SCL Clock Fall Time                                                | $t_{CF}$            | <i>Figure 141</i>                      | —                                                                          | —                             | $150e06 * 1 / f_{SCL}$<br>(capped at 60) | ns      | 5     |
| SDA Signal Data Hold<br>in Push-Pull Mode                          | Controller          | $t_{HD\_PP}$                           | <i>Figure 146</i>                                                          | $t_{CR} + 3$ and $t_{CF} + 3$ | —                                        | —       | —     |
|                                                                    | Target              | $t_{HD\_PP}$                           | <i>Figure 148</i> <i>Figure 149</i><br><i>Figure 150</i> <i>Figure 151</i> | 0                             | —                                        | —       | —     |
| SDA Signal Data Setup in Push-Pull Mode                            | $t_{SU\_PP}$        | <i>Figure 146</i> <i>Figure 147</i>    | 3                                                                          | —                             | N/A                                      | ns      | —     |
| Clock After Repeated START (Sr) Condition                          | $t_{CASr}$          | <i>Figure 153</i>                      | $t_{CASmin} / 2$                                                           | —                             | N/A                                      | ns      | 9     |
| Clock Before Repeated START (Sr) Condition                         | $t_{CBSr}$          | <i>Figure 153</i>                      | $t_{CASmin} / 2$                                                           | —                             | N/A                                      | ns      | —     |
| Capacitive Load per Bus Line (SDA/SCL)                             | $C_b$               | —                                      | —                                                                          | —                             | 50                                       | pF      | —     |
| HDR-BT SCL Clock Frequency                                         | $t_{BT\_FREQ}$      | —                                      | 0.1                                                                        | 12.5                          | 12.9                                     | MHz     | —     |
| HDR-BT Controller to Target Hand Off Delay                         | $t_{BT\_HO}$        | —                                      | —                                                                          | —                             | 10                                       | $\mu$ S | —     |
| HDR-BT Delay Bytes during Read<br>(for Data-Block Delay mechanism) | $t_{BT\_DBD}$       | —                                      | —                                                                          | —                             | 1024                                     | Bytes   | 10    |

**Note:**

- 1)  $F_{SCL} = 1 / (t_{DIG\_L} + t_{DIG\_H})$
- 2)  $t_{DIG\_L}$  and  $t_{DIG\_H}$  are the clock Low and High periods as seen at the receiver end of the I3C Bus using  $V_{IL}$  and  $V_{IH}$  (see **Figure 140**). The  $t_{DIG\_L}$ ,  $t_{DIG\_H}$ , and  $t_{DIG\_MIXED}$  minimum values of 32 ns are provided to allow an extreme 40/60 duty cycle at typical clock frequency of 12.5 MHz.
- 3) When communicating with an I3C Device on a Mixed Bus, the  $t_{DIG\_H\_MIXED}$  period must be constrained to make sure that I<sup>2</sup>C Devices do not interpret I3C signaling as valid I<sup>2</sup>C signaling. The  $t_{HIGH}$ ,  $t_{LOW}$ , and  $t_{HIGH\_MIXED}$  minimum values of 24 ns are provided as a safe corner case, in order to allow enough time for processing under extreme conditions.
- 4) As both edges are used, the hold time needs to be satisfied for the respective edges; i.e.,  $t_{CF} + 3$  for falling edge clocks, and  $t_{CR} + 3$  for rising edge clocks.
- 5) The clock maximum rise/fall time is capped at 60 ns. For lower frequency rise and fall, the maximum value is limited at 60 ns, and is not dependent upon the clock frequency.
- 6)  $t_{HD\_PP}$  is a Hold time parameter for Push-Pull Mode that has a different value for Controller mode vs. Target mode. Push-Pull Mode includes both SDR Mode and DDR Mode. In SDR Mode the Hold time parameter is referred to as  $t_{HD\_SDR}$ , and in DDR Mode it is referred to as  $t_{HD\_DDR}$ .
- 7) Devices with more than 12 ns of  $t_{SCO}$  delay shall set the limitation bit in the BCR, and shall support the GETMXDS CCC to allow the Controller to read this value and adjust computations accordingly. For purposes of system design and test conformance, this parameter should be considered together with pad delay, Bus capacitance, propagation delay, and clock triggering points.
- 8) Pad delay based on 90 Ω / 4 mA driver and 50 pF load. Note that Controller may be a Target in a Multi-Controller system, and thus shall also adhere to this requirement
- 9) Targets with speed limitations inform the Controller via the Bus Characteristics Register that the minimum may not be acceptable. As a result, if the given SCL HIGH period is 50 ns or greater, then the Controller needs to accommodate for Legacy I<sup>2</sup>C Devices that might see it.
- 10) This parameter represents the maximum number of Delay bytes that a Target may use during HDR-BT Read transfers, at each opportunity where the Target is unable to transmit or chooses to delay transmitting a complete Data Block. This is fundamentally different from Stalling the clock. See **Section 5.2.4.3.4**.

**Note:**

*It is not expected (and it would be unrealistic to expect) that all corner conditions will be present concurrently (i.e., that maximum frequency, worst duty cycle, slower edge, etc., would all occur at the same time).*

The timing diagram in **Figure 140** depicts I3C Legacy Mode for I<sup>2</sup>C Devices. The timing parameters referenced in this timing diagram appear in **Table 85**.



**Figure 140 I3C Legacy Mode Timing**



**Figure 141 t\_DIG\_H and t\_DIG\_L**

The start of a typical I3C communication in SDR Mode is shown in **Figure 142**. The initial communication looks very similar to I<sup>2</sup>C, with additional commands that follow as described in **Section 4**. The key difference is that higher clock speed is supported, up to 12.5 MHz. The higher clock speed allows Legacy I<sup>2</sup>C Devices with 50 ns Spike Filters to ignore the communications. The Controller can then run in SDR Mode for I3C Devices using full 12.5 MHz timing, though it will have to slow down in order to communicate with Legacy I<sup>2</sup>C Devices. **Figure 142** shows the beginning of a transaction, where the Target acknowledges its Address.

**Figure 143** shows the possible continuation of an I3C SDR communication, in the case where the Target does not acknowledge its Address. The Controller may either STOP the communication, or else continue with a Repeated START.



\* $t_{SCO}$  is depicted for informative purposes only

**Figure 142 I3C Write Address ACK**



Figure 143 I3C Write Address NACK

7364  
7365 **Figure 144** shows the timing parameters for an I3C START (not Repeated START), and **Figure 145** shows the timing parameters for an I3C STOP.

7366  
7367 **Figure 144 I3C START Timing**7368  
7369 **Figure 145 I3C STOP Timing**

7370 **Figure 146** and **Figure 147** illustrate the timing parameters that are unique to the Controller Device and to  
 7371 the Target Device, as specified in **Table 87**. The primary difference between the two is that a Controller  
 7372 always transmits the clock (SCL), whereas the Target is receiver-only on the SCL pin.



7373 **Figure 146 I3C Controller Out Timing**

7374



7375 **Figure 147 I3C SDR Target Out Timing**

7376



Figure 148 Controller SDR Timing



Figure 149 Controller DDR Timing



Figure 150 T-Bit When Target Ends Read and Controller Generates STOP



Figure 151 T-Bit When Target Ends Read and Controller Generates Repeated START



Figure 152 T-Bit When Target and Controller Agree to Continue Read Message



**Figure 153 T-Bit When Controller Ends Read with Repeated START and STOP**



Figure 154 T-Bit When Controller Ends Read via Repeated START and Further Transfer



**Figure 155 Controller to Controller Bus Handoff**

7393 **Figure 156** illustrates the I3C timing parameters related to the Spike Filter present on Legacy I<sup>2</sup>C Devices.  
 7394 This Spike Filter suppresses pulses shorter than 50 ns.

7395 I3C Mixed Bus clocking rates are chosen to prevent Legacy I<sup>2</sup>C Devices from seeing I3C Bus  
 7396 communications, by keeping at least the SCL High periods under 50 ns. To a Legacy I<sup>2</sup>C Device, SCL will  
 7397 simply appear to remain Low, i.e., no clock pulses will be received. In other words, I3C Bus communication  
 7398 uses SCL High periods of less than 50 ns, which are invisible to Legacy I<sup>2</sup>C Devices. (Low periods are also  
 7399 generally less than 50 ns, though longer in some cases.)

7400 **Figure 156** details how when the slower Open Drain timing ( $t_{DIG\_H}$ ) is used both I3C Devices (bottom trace)  
 7401 and Legacy I<sup>2</sup>C Devices (middle trace) can see its longer periods, and therefore both can see the Bus traffic.  
 7402 But when I3C's faster Push-Pull timing ( $t_{DIG\_H\_MIXED}$ ) is used, the shorter periods will only reach the I3C  
 7403 Devices and not the Legacy I<sup>2</sup>C Devices, so only I3C Devices can participate in the Bus. I3C Push-Pull  
 7404 timing is specified in **Table 87**.



7405  
 7406 **Figure 156 I<sup>2</sup>C Spike Filter Behavior**

7407  
7408 **Table 88** through **Table 90** detail how timing and drive strength are adjusted during transmission of an I3C Message.

7409 **Table 88 Timing and Drive for Start of New Frame: No Contention on A6**

| S               | Header                  |               |           |           | Data              | P         |
|-----------------|-------------------------|---------------|-----------|-----------|-------------------|-----------|
| START           | Addr[6]<br>(Arbitrated) | Addr[5:0]     | RnW       | ACK       | N Data +<br>T-Bit | STOP      |
| <b>SDA Mode</b> | Open<br>Drain           | Open<br>Drain | Push-Pull | Push-Pull | Open Drain        | Push-Pull |
| <b>Clocks</b>   | 1                       | 1             | 6         | 1         | 1                 | $9 * N$   |

**Note:**  
*No contention on Addr[6], so the Controller may optionally use Push-Pull for Addr[5:0] and RnW, per Section 5.1.2.2.2.*

7410 **Table 89 Timing and Drive for Start of New Frame: With Contention on A6**

| S               | Header                  |                           |                     |               | Data              | P         |
|-----------------|-------------------------|---------------------------|---------------------|---------------|-------------------|-----------|
| START           | Addr[6]<br>(Arbitrated) | Addr[5:0]<br>(Arbitrated) | RnW<br>(Arbitrated) | ACK           | N Data +<br>T-Bit | STOP      |
| <b>SDA Mode</b> | Open<br>Drain           | Open<br>Drain             | Open<br>Drain       | Open<br>Drain | Push-Pull         | Push-Pull |
| <b>Clocks</b>   | 1                       | 1                         | 6                   | 1             | $9 * N$           | 1         |

**Note:**  
*Contention on Addr[6], so Arbitration continues through Addr[5:0] and RnW.*

7411 **Table 90 Timing and Drive for Continuation of Frame Using Repeated START**

| S               | Header /<br>Data... | Sr    | Header    |           | Data              | P         |
|-----------------|---------------------|-------|-----------|-----------|-------------------|-----------|
| START           | ...                 | START | Addr/RnW  | ACK       | N Data +<br>T-Bit | STOP      |
| <b>SDA Mode</b> | Open<br>Drain       | ...   | Push-Pull | Push-Pull | Open<br>Drain     | Push-Pull |
| <b>Clocks</b>   | 1                   | ...   | 1         | 8         | 1                 | $9 * N$   |

**Note:**  
*There may be any number of Repeated STARTs before the STOP.*

This page intentionally left blank.

## Annex A I3C Communication Format Details

### A.1 I3C CCC Transfers



Figure 157 I3C CCC Transfers

7412

7413

## A.2 I3C Private Write and Read Transfers



I3C Private Write Transfer Initiated with START Condition



I3C Private Write Transfer Initiated with Repeated START Condition



I3C Private Read Transfer Initiated with START Condition



I3C Private Read Transfer Initiated with Repeated START Condition



ACK = Acknowledge (SDA Low)  
 NACK = Not Acknowledge (NACK)  
 S = START Condition  
 Sr = Repeated START Condition  
 P = STOP Condition  
 T = Transition Bit alternative to ACK/NACK

7414

7415

Figure 158 I3C Private Write and Read Transfers with 7'h7E Address



I3C Private Write Transfer (from START) without 7'h7E Address



I3C Private Read Transfer (from Repeated START) after Private Write



I3C Private Read Transfer (from START) without 7'h7E Address



ACK = Acknowledge (SDA Low)  
NACK = Not Acknowledge (NACK)  
S = START Condition  
Sr = Repeated START Condition  
P = STOP Condition  
T = Transition Bit alternative to ACK/NACK

7416  
7417

Figure 159 I3C Private Write and Read Transfers without 7'h7E Address

### A.3 Legacy I<sup>2</sup>C Write and Read Transfers on the I3C Bus

Legacy I<sup>2</sup>C Write Transfer Initiated with START ConditionLegacy I<sup>2</sup>C Write Transfer Initiated with Repeated START ConditionLegacy I<sup>2</sup>C Read Transfer Initiated with START ConditionLegacy I<sup>2</sup>C Read Transfer Initiated with Repeated START Condition

ACK = Acknowledge (SDA Low)  
 NACK = Not Acknowledge (NACK)  
 S = START Condition  
 Sr = Repeated START Condition  
 P = STOP Condition

7418

7419

Figure 160 Legacy I<sup>2</sup>C Write and Read Transfers in I3C Bus with 7'h7E Address



Legacy I<sup>2</sup>C Write Transfer (from START) without 7'h7E Address



Legacy I<sup>2</sup>C Read Transfer (from Repeated START) after Write



Legacy I<sup>2</sup>C Read Transfer (from START) without 7'h7E Address



ACK = Acknowledge (SDA Low)  
NACK = Not Acknowledge (NACK)  
S = START Condition  
Sr = Repeated START Condition  
P = STOP Condition

7420  
7421

Figure 161 Legacy I<sup>2</sup>C Write and Read Transfers in I3C Bus without 7'h7E Address

## A.4 Dynamic Address and Enter HDR



7422

7423

**Figure 162 Dynamic Address Allocation ENTDAAC CCC Bus Modal**



7424

7425

Figure 163 Enter HDR Mode CCC Bus Modal

This page intentionally left blank.

## Annex B SDR Mode Error Type Origins

### B.1 Error Types in I3C CCC Transfers



Figure 164 Error Type Origins: I3C CCC Transfers

7426

7427

## B.2 Error Types in I3C Private Read and Write Transfers



7428

7429

**Figure 165 Error Type Origins: I3C Private Write & Read Transfers with 7'h7E Address**



7430

7431

**Figure 166 Error Type Origins: I3C Private Write & Read Transfers without 7'h7E Address**

### B.3 Error Types in Dynamic Address Arbitration



7432

7433

**Figure 167 Error Type Origins: Dynamic Address Arbitration**

## Annex C I3C Controller FSMs

7434  
7435  
7436 **Figure 168** shows the key transmission Modes and their entry, resume, and exit sequences. It includes the SDR transmission states, and differentiates these from other capabilities and Modes. It captures the states at which Arbitration happens as well.



**Figure 168 I3C Primary Controller FSM**

7439 **Figure 169** through **Figure 173** represent I3C features including In-Band Interrupts, Secondary Controller, Dynamic Address Assignment, and Hot-Join.

7440



7441  
7442 **Figure 169 In-Band Interrupt (Target Interrupt) Request FSM**

**Figure 170 Dynamic Address Assignment FSM**

7443

7444





**Figure 172 Controller Role Request FSM**

7447  
7448



Figure 173 Controller Regaining Bus Ownership FSM

7451  
7452 The FSM in **Figure 174** represents the Controller states when in HDR-DDR transmission Mode, including Entry, Restart, and Exit sequence for HDR-DDR Mode.

**Figure 174** HDR-DDR Mode FSM

7453

7454

7455

**Figure 175** is for reference only.**Figure 175 I<sup>2</sup>C Legacy Controller FSM**

7456

7457

## Annex D Typical I3C Protocol Communications

**Figure 176** through **Figure 180** illustrate a typical communication for each of the supported I3C Protocols. While these figures do not exhaustively illustrate all possible I3C communications, they do serve as useful introductions to the signaling and transmission formatting used in each supported I3C Protocol.

### D.1 Typical SDR Private Read

**Figure 176** illustrates example communication using I3C Single Data Rate (SDR) Mode. It shows the Controller reading a byte of data from the Target at Address 0x2B in SDR Mode.

From the Bus Free Condition, the Controller issues a START by driving the SDA line Low while keeping the SCL line High. It then issues the Broadcast Address (7'h7E) followed by RnW (0 for Write). Then the Controller turns on a Pull-Up resistor and goes to Open Drain. All Targets ACK by pulling the SDA line Low (in the Figure, pink fill means the Target is in control of the SDA line at this time). The Controller then issues a Repeated START, then the Address of the Target (0x2B) it wants to read followed by RnW (1 for Read). The Controller then turns on a Pull-Up resistor and goes to Open Drain, allowing the Target to acknowledge by pulling the SDA line Low. At this point, the Controller continues to toggle the SCL line and release the SDA line, allowing the Target to drive SDA to send one byte of data (0x4A) followed by ‘T’. T = 1 informs the Controller that there is additional data, whereas T = 0 signals the end. Here there is additional data, so the Target drives SDA High until SCL goes High, at which time it releases SDA. The Controller has the option of holding SDA High with a weak Pull-Up, which signals to the Target that the Controller allows another byte to be transmitted, or to pull SDA Low (while SCL is High – hence a Repeated START), which would signal to the Target that the Controller has terminated the Read and is taking over.

SDR Mode is backwards compatible with Legacy I<sup>2</sup>C Devices, because the High time of an SCL pulse is always less than 50 ns and therefore SCL will always appear to be Low because of the I<sup>2</sup>C 50 ns Spike Filter.



**Figure 176 Example Communication Using I3C SDR Mode with Private Read**

## D.2 Typical Direct CCC in SDR Mode

**Figure 177** shows the Controller issuing a Direct CCC to a single Target. This particular command (GETPID) reads the Provisioned ID of a Target.

From the Bus Free Condition, the Controller issues a START by driving the SDA line Low while keeping the SCL line High. It then issues the Broadcast Address (7'h7E) followed by RnW (0 for Write). Then the Controller turns on a Pull-Up resistor and goes to Open Drain. All Targets ACK by pulling SDA Low (in the Figure, pink fill means the Targets are in control of SDA at this time). The Controller then issues the Direct Common Command Code for GETPID (0x8D) followed by parity bit 'T' (odd parity = 1 for 0x8D) then the 7-bit Dynamic Address of the Target (chosen arbitrarily here to be 0x2B) followed by a RnW bit (1 for Read). Then the Controller turns on a Pull-Up resistor and goes to Open Drain, allowing the Target at Address 0x2B to ACK by pulling SDA Low, which tells the Controller that the Target Acknowledges the command and will comply. (Alternatively, the Target may NACK by not pulling SDA Low, which would inform the Controller that the Target will not comply – in this case, that an error occurred.) Following the ACK the Target outputs its 48-bit PID one byte at a time, and then the Controller issues a Repeated START (this part of the waveform sequence is not shown in the Figure).



**Figure 177 Example Communication Using I3C SDR Mode with Direct CCC**

### D.3 Typical Broadcast CCC in SDR Mode

**Figure 178** illustrates example SDR communication with a Broadcast CCC. The command used in this example sets the Maximum Read Length of all Targets to 43 bytes (0x002B).

From the Bus Free Condition, the Controller issues a START by driving the SDA line Low while keeping the SCL line High. It then issues the Broadcast Address (7'h7E) followed by RnW (0 for Write). Then the Controller turns on a Pull-Up resistor and goes to Open Drain. All Targets ACK by pulling SDA Low (in the Figure, pink fill means the Targets are in control of SDA at this time). The Controller then issues the Broadcast Common Command Code for SETMRL (0x0A) followed by parity bit 'T' (odd parity = 1 for 0x0A), and then 2 data bytes (MSB first, and MSb first within each byte) to define the maximum number of bytes that can be read from a Target in a single read operation. Each data byte is followed by a 'T' bit (parity bit – odd parity). After this the Controller issues a Repeated START.



**Figure 178 Example Communication Using I3C SDR Mode with Broadcast CCC**

#### D.4 Typical HDR-DDR Read

**Figure 179** illustrates use of the HDR-DDR (Double Data Rate) Mode. It shows how the Controller can change the Mode from SDR (Single Data Rate) Mode to HDR-DDR Mode, and a sample of the HDR-DDR data format.

From the Bus Free Condition, the Controller issues a START by driving the SDA line Low while keeping the SCL line High. The Controller then issues the Broadcast Address (7'h7E) followed by RnW (0 for Write). Then the Controller turns on a Pull-Up resistor and goes to Open Drain. All Targets ‘ACK’ by pulling SDA Low (in the Figure, pink fill means the Targets are in control of SDA at this time). The Controller then issues the Broadcast Common Command Code for ENTHDR0 (0x20), followed by parity bit ‘T’ (odd parity = 0 for 0x20). At this point, the Bus is in HDR-DDR Mode. In the HDR-DDR protocol, the SDA line is sampled on every SCL edge (both Low-to-High and High-to-Low transitions of SCL). The HDR-DDR Word consists of a 2-bit Preamble, followed by two bytes of data, followed by two parity bits. The waveform for the 5-bit CRC and following traffic is not shown in the Figure.

HDR-DDR Mode is backwards-compatible with Legacy I<sup>2</sup>C Devices, because the High time of an SCL pulse is always less than 50 ns and as a result SCL will always appear to be Low because of the I<sup>2</sup>C 50 ns Spike Filter.



**Figure 179 Example Communication Using HDR-DDR Protocol**

#### D.5 Typical HDR-TSL Read

This section is not included in the I3C Basic Specification because I3C Basic does not support HDR-TSL Mode. To gain access to this capability, please contact MIPI Alliance.

#### D.6 Typical HDR-TSP Read

This section is not included in the I3C Basic Specification because I3C Basic does not support HDR-TSP Mode. To gain access to this capability, please contact MIPI Alliance.

## D.7 Typical HDR-BT Read

**Figure 180** illustrates use of the HDR-BT (Bulk Transport) Mode. It shows how the Controller can change the Mode from SDR (Single Data Rate) Mode to HDR-BT Mode, and a sample of the HDR-BT data format using 1-lane configuration (i.e., Coding 0). Note that other ML lane configurations and Codings are possible.

From the Bus Free Condition, the Controller issues a START by driving the SDA line Low while keeping the SCL line High. The Controller then issues the Broadcast Address (7'h7E) followed by RnW (0 for Write). Then the Controller turns on a Pull-Up resistor and goes to Open Drain. All Targets ‘ACK’ by pulling SDA Low (in the Figure, pink fill means the Targets are in control of SDA at this time). The Controller then issues the Broadcast Common Command Code for ENTHDR3 (0x23), followed by parity bit ‘T’ (odd parity = 0 for 0x23). At this point, the Bus is in HDR-BT Mode. In the HDR-BT protocol, the SDA line is sampled on every SCL edge (both Low-to-High and High-to-Low transitions of SCL). Note that this example shows a Read, so the Controller sets up the SDA line appropriately such that the first bit (ADDR[0]) is sampled correctly for a Read transfer (i.e., RnW = 1'b1).

In this example, the Controller starts the transfer by sending the HDR-BT Header Block in 1-lane form, and the Controller drives the SDA line to send the Address and RnW bit, to indicate the addressed Target (0x2B) as well as the direction of transfer; the Cmd0 byte (0x85) and additional Cmd1–Cmd3 bytes, to indicate which data to read; and the additional Control byte for transfer settings. The Controller then uses the Transition byte to set up SDA for the Target to accept, and the Target drives SDA Low to indicate acceptance. The Target then drives the SDA line (and optionally the SCL line, if supported) for one or more HDR-BT Data Blocks and the HDR-BT CRC Block that follows, with up to 32 bytes per Data Block. (The waveforms for the Data Blocks and CRC Block are not shown in the Figure; see [Section 5.2.4.6](#) for reference.)

HDR-BT Mode is backwards compatible with Legacy I<sup>2</sup>C Devices, because the High time of an SCL pulse is always less than 50 ns and as a result SCL will always appear to be Low because of the I<sup>2</sup>C 50 ns Spike Filter.



**Figure 180 Example Communication Using HDR-BT Protocol**

This page intentionally left blank.

## Annex E MIPI I3C Basic Specification Supplemental Patent Licensing Terms

This agreement (the “Agreement”) between MIPI Alliance Inc. (“MIPI”) and each MIPI member or other party that has manifest agreement to these terms (each a “Licensor” and collectively the “Licensors”) is effective as of the date the I3C Basic Specification (defined below) is first approved by the MIPI Board (the “Effective Date”). Capitalized terms used in this Agreement that are not expressly defined here have the meaning identified in the MIPI Membership Agreement or MIPI Bylaws, as applicable. For convenience, key definitions are reproduced in Attachment A. For the avoidance of doubt: (a) in connection with this Agreement, any reference to a “MIPI Specification” means the MIPI I3C Basic Specification as described in Section 2, and (b) any rights or obligations created under this Agreement are independent of any rights or obligations created under the MIPI Membership Agreement, Bylaws or any other agreements, and nothing in this Agreement is intended to alter rights or obligations established elsewhere.

**Background.** Typically, MIPI specifications are implemented only by MIPI members. MIPI members make certain intellectual property licensing commitments to other members under the MIPI Membership Agreement, with different rules applying to “Mobile Terminals” and “Accessories,” in contrast to other types of implementations. The MIPI Board intends to make the MIPI I3C Basic Specification available for implementation by parties who are non-members of MIPI, however. Further, both MIPI members and non-members may use this specification inside and outside of Mobile Terminals or Accessories. The Licensors contributed to the development of the MIPI I3C Basic Specification, and desire to see it widely used. MIPI and the Licensors believe that making licenses available (as set forth in this Agreement) to both member and non-member implementers, for all types of implementations, will facilitate widespread adoption of the MIPI I3C Basic Specification, to the benefit of MIPI, the Licensors, and the broader community that MIPI serves.

**MIPI I3C Basic Specification.** “MIPI I3C Basic Specification” means the specification titled “I3C Basic 1.0” as approved by the MIPI Board, and all subsequent versions of such specification approved by the MIPI Board after the Effective Date. Any party implementing the MIPI I3C Basic Specification, whether or not a MIPI member, is an “Implementer.” For the avoidance of doubt: the MIPI I3C Basic Specification is distinct from the MIPI I3C Specification version 1.0 approved by the MIPI Board on Dec. 31, 2016. The terms of this Agreement apply exclusively to the MIPI I3C Basic Specification.

**License commitment.**

*a. RAND-Z license obligation.* For the MIPI I3C Basic Specification only, Licensor hereby agrees to grant, and to cause its Affiliates to grant, to any requesting Implementer a worldwide, non-exclusive, non-sublicensable license under the Necessary Claims of Licensor or its Affiliates, with zero royalties or other compensation, under terms and conditions that are reasonable and nondiscriminatory, to make, have made, use, import, offer to sell, lease, sell, promote and otherwise distribute Compliant Portions. Licensor shall not be obligated to license any part or function of a product in which a Compliant Portion is incorporated that is not itself a Compliant Portion.

*b. Reciprocity; defensive suspension.* Licensor shall not be obligated to license any Implementer if that Implementer does not agree to make patent licenses available under any Necessary Claims of that Implementer and its Affiliates to Licensors and all other Implementers under terms substantially identical to the terms described in this Agreement. Further, a Licensor may suspend any license granted under this Agreement to any Implementer if that Implementer or its Affiliate initiates against any party litigation that alleges infringement of a Necessary Claim of Implementer or its Affiliate in connection with the MIPI I3C Basic Specification. Additionally, subject to Section 3.1(f) of the MIPI Membership Agreement as between MIPI Members, a Licensor may terminate, ab initio, any license granted pursuant to this Agreement to any Implementer that initiates litigation against the Licensor alleging infringement of any patent claim of the Implementer or its Affiliate. For the purposes of this Agreement, a party that files a suit which is

7601 defensive based on a patent infringement claim or suit by another party will not be deemed to have  
7602 initiated litigation.

7603 *c. Circumvention or transfer.* Licensor agrees that it has not transferred and will not transfer any  
7604 patent having Necessary Claims solely for the purpose of circumventing the obligations described  
7605 in this Agreement. In addition, Licensor agrees that any transfers by Licensor to a third party of a  
7606 patent having relevant Necessary Claims, whether or not recognized as Necessary Claims at the  
7607 time of transfer, shall be subject to (i) the terms and conditions of this Agreement, and (ii) the  
7608 agreement that the third party shall grant licenses under said Necessary Claims to Implementers  
7609 pursuant to the terms of this Agreement in like manner and to the same extent as the third party  
7610 would be required to do if it had executed this Agreement. A transfer of ownership in a business  
7611 entity which owns or has the right to license a patent having Necessary Claims shall be considered  
7612 a transfer of such patent.

7613 **4. Termination of obligation to license future versions.** Each Licensor may terminate its  
7614 participation in this Agreement at any time by providing written notice to the MIPI Managing Director;  
7615 termination will be effective 30 days after such notice is actually received, subject to the survival points  
7616 below. Promptly upon receipt of such notice, the MIPI Managing Director will alert the MIPI Board and will  
7617 use reasonable efforts to notify all Licensors of such termination. After termination, the agreement to grant a  
7618 license as provided in Section 3 shall survive in full force and effect only: (a) for versions of the MIPI I3C  
7619 Basic Specification which the Board had approved before the effective date of termination; (b) for Necessary  
7620 Claims relating to any version of the MIPI I3C Basic Specification approved after the effective date of  
7621 termination that are used in a substantially similar manner and to a substantially similar extent with a  
7622 substantially similar result as the Necessary Claims that were used in a prior version for which the Licensor  
7623 is obligated to grant licenses under this Agreement; and (c) for those Necessary Claims that directly result  
7624 from inclusion of Licensor-provided material in the draft version of the specification that existed immediately  
7625 prior to Licensor's withdrawal. Termination of this Agreement by one Licensor does not impact the  
7626 Agreement among MIPI or the other Licensors, nor does it not impact Licensor's MIPI Membership  
7627 Agreement, which will remain in full force and effect.

7628 **5. Third party beneficiaries.** All Implementers, whether or not they are MIPI members, are intended  
7629 third party beneficiaries of this Agreement.

7630 **6. Counterparts; additional Licensors.** This Agreement may be signed in any number of  
7631 counterparts. If additional parties manifest agreement to terms substantially identical to this Agreement, those  
7632 parties will be deemed Licensors under this Agreement.

## Attachment A

1.3. “**Compliant Portions**” means only those specific portions of products (hardware, software or combinations thereof) that: (i) both implement and are compliant with the relevant portions of the MIPI Specification, (ii) are qualified pursuant to the MIPI qualification process (if available), (iii) meet the requirements set forth in any compliance requirements set forth by the Corporation, applied to all Members on a nondiscriminatory basis, and (iv) are within the bounds of the Scope of IPR (defined below).

7633

1.5 “**Interface**” means the protocols, signaling characteristics, commands, clocking signals, register models, application program interfaces and data structures to the extent they enable interoperation, interconnection or communication between integrated circuits (even if located on the same die).

7634

1.7. “**Necessary Claims**” mean those claims of all patents and patent applications, other than design patents and design registrations, throughout the world which (i) a Member or its Affiliates has the right, at any time during the term of this Agreement, to grant licenses of the nature granted or agreed to be granted herein without such grant resulting in payment of royalties or other consideration to third parties (except for payments to Affiliates or to employees within the scope of their employment); (ii) are within the Scope of IPR; and (iii) are necessarily infringed by an implementation of a MIPI Specification, wherein such infringement could not have been avoided by another commercially reasonable non-infringing implementation of such MIPI Specification. Necessary Claims do not include (i) any claims other than those set forth above even if contained in the same patent as Necessary Claims, or (ii) any claims that read on any implementation of the Specification to the extent that such implementation is not within the bounds of the MIPI Specification.

7635

1.8 “**Scope of IPR**” means Interfaces, solely to the extent disclosed with particularity in a MIPI Specification, where the purpose and sole licensed (under this agreement) use of such disclosure is to define, implement, and utilize an interface that enables interoperation, interconnection or communication in accordance with a MIPI Specification. Notwithstanding the foregoing, the Scope of IPR shall not include (i) any enabling technologies that may be necessary to make or use any product or portion thereof that complies with a MIPI Specification, but are not themselves expressly set forth in a MIPI Specification; (ii) semiconductor manufacturing technology, DSP architecture, processor architecture/microarchitecture, wireless communication technology, compiler technology, integrated circuit packaging technology, security technology, internal architectures of integrated circuits, applications which run on integrated circuits, audio coding technology, video coding technology or basic operating system technology; (iii) SDO Standards, whether in whole or significant part, not developed by or for the Corporation, but referred to or incorporated in a MIPI Specification, or (iv) any portions of any product and any combination except for that portion or portions which are required solely in order to achieve an interface that is compliant with a MIPI specification; (v) any methods or processes practiced, in whole or in part, over an Interface that are not expressly set forth in a MIPI Specification.

7636

“**Affiliate**,” means any corporation, partnership, or other entity that, directly or indirectly, owns, is owned by, or is under common ownership with, such Member hereto, for so long as such ownership exists. For the purposes of the foregoing, “own,” “owned,” or “ownership” shall mean ownership of more than fifty (50%) of the stock or other equity interests entitled to vote for the election of directors or an equivalent governing body of an entity that is directly or indirectly controlled by, under common control with or that controls the subject party.

7637

“**Board**” means the Board of Directors of MIPI.

7638

This page intentionally left blank.

## Annex F I3C Basic Development Companies

- 7639 Analog Devices, Inc.
- 7640 Analogix Semiconductor, Inc.
- 7641 Avery Design Systems, Inc.
- 7642 Cadence Design Systems, Inc.
- 7643 Intel Corporation
- 7644 Introspect Test Technology Inc.
- 7645 InvenSense, Inc.
- 7646 L&T Technology Services
- 7647 Lattice Semiconductor Corp.
- 7648 MediaTek Inc.
- 7649 NXP Semiconductors
- 7650 Qualcomm Incorporated (provided notice of termination effective August 13, 2018)
- 7651 Robert Bosch GmbH
- 7652 SmartDV Technologies India Private Limited
- 7653 STMicroelectronics
- 7654 Synaptics
- 7655 Synopsys, Inc.
- 7656 Toshiba Memory Corporation
- 7657 Valens Semiconductor

This page intentionally left blank.

## Participants

The list below includes those persons who participated in the Ad Hoc Working Group that developed this Specification and who consented to appear on this list.

Rajesh Bhaskar, Intel Corporation  
Anamitra Chakrabarti, Synopsys, Inc.  
Kenneth Foust, Intel Corporation  
Chris Grigg, MIPI Alliance (Team)  
Janusz Jurski, Intel Corporation  
Paul Kimelman, NXP Semiconductors

Tim McKee, Intel Corporation  
Matthew Schnoor, Intel Corporation  
Amit Srivastava, Intel Corporation  
Eyuel Zewdu Teferi, STMicroelectronics  
James Wang, InvenSense, Inc.

Past contributors to v1.0:

Eugen Becker, Robert Bosch GmbH  
Rajesh Bhaskar, Intel Corporation  
Enrico Carrieri, Intel Corporation  
Geraud Cheenne, STMicroelectronics  
Ladvine D Almeida, Synopsys, Inc.  
Kenneth Foust, Intel Corporation  
Chris Grigg, MIPI Alliance (Team)  
Paul Kimelman, NXP Semiconductors  
Abinaya Kubendran, L&T Technology Services

Peter Lefkin, MIPI Alliance (Team)  
Satwant Singh, Lattice Semiconductor Corp.  
Przemyslaw Sroka, Cadence Design Systems, Inc.  
Greg Stewart, Analogix Semiconductor, Inc.  
Eyuel Zewdu Teferi, STMicroelectronics  
Suresh Venkatachalam, Synopsys, Inc.  
James Wang, InvenSense, Inc.  
Miles Williams, Introspect Test Technology Inc.

This page intentionally left blank.