

# 8-Kbit Serial Presence Detect (SPD) EEPROM with Hub and Integrated Temperature Sensor

## 1 Features

- SPD5 Hub Device, JEDEC JESD300-5B.01 Compliant
- Two-wire Programmable I2C or I3C Basic Bus Serial Interface
- Up to 12.5 MHz Transfer Rate
- Power Supply: 1.8V VDDSPD, 1.0V VDDIO Supports 1.0V, 1.1V and 1.2V Push Pull IO Levels
- Supports 1.0V, 1.1V, 1.2V, 1.8V, 2.5V and 3.3V Open Drain IO Levels
- 1024 Bytes of Non-volatile Memory (16 Blocks; 64 Bytes per Block)
- · Write Protection for each Block of NVM
- Hub Function with 3 Address Bits Translation
- Integrated Temperature Sensor: 0.5°C
   Accuracy with 0.25°C Resolution
- Packet Error Check (PEC) Function
- Parity Error Check Function
- Bus Reset Function
- Up to 8 Unique Addressing
- In Band Interrupt (IBI)
- 9-pin Thermally Enhanced DFN Package
- Operating Temperature Range: -40°C to 125°C

# 2 Applications

- DDR5 DIMM Modules, UDIMM, RDIMM, LRDIMM and SODIMM
- PC, Server Platforms
- Industrial Temperature Monitors

# 3 Description

The GD30PD5118 is a SPD5 Hub device Compatible with JEDEC standard JESD300-5B.01. The SPD5 Hub device contains 1024 bytes of non-volatile memory arranged as 16 blocks of 64 bytes per block. Each block may optionally be write-protected via software command. Write protection for each block may be overridden in an offline programmer environment while overrides are prevented in normal use. The SPD5 Hub device operates from 1.8V nominal power supply input. The SPD5 Hub device is intended to operate up to 12.5MHz on a 1.0V I3C Basic bus or up to 1MHz on a 1.0V to 3.3V I²C bus. The SPD5 Hub device is intended to interface to I²C/I3C Basic buses which have multiple devices on a shared bus, and must be uniquely addressed with fixed addressing on the same bus.

The SPD5 Hub device responds to specific pre-defined I<sup>2</sup>C/I3C Basic device select codes on a host interface bus. The SPD5 Hub device also incorporates a second local I<sup>2</sup>C/I3C Basic bus and supports pass through of commands from the host bus onto the local bus for addressing of I<sup>2</sup>C/I3C Basic devices on the local bus (Hub function).

The SPD5 Hub device incorporates thermal sensing capability which is controlled and read over I<sup>2</sup>C/I3C Basic bus.

#### Device Information<sup>1</sup>

| PART NUMBER | PACKAGE | BODY SIZE (NOM) |  |  |  |  |
|-------------|---------|-----------------|--|--|--|--|
| GD30PD5118  | UDFN    | 2.0mm x 3.0mm   |  |  |  |  |

1. For packaging details, see *Package Information* section.



# **Table of Contents**

| 1   | Feat     | ures                                                                            | 1  |
|-----|----------|---------------------------------------------------------------------------------|----|
| 2   | Appl     | lications                                                                       | 1  |
| 3   | Desc     | cription                                                                        | 1  |
| Tal | ole of ( | Contents                                                                        | 2  |
| 4   | Devi     | ce Overview                                                                     | 4  |
|     | 4.1      | Pinout and Pin Assignment                                                       | 4  |
|     | 4.2      | Pin Description                                                                 | 4  |
| 5   | Devi     | ce Power Up, Reset and Initialization                                           | 5  |
|     | 5.1      | Device Power Up                                                                 | 5  |
|     | 5.2      | Device Reset and Initialization                                                 | 5  |
|     | 5.3      | Bus Clear                                                                       | 6  |
|     | 5.4      | Bus Reset                                                                       | 6  |
| 6   | Devi     | ce Interface - IO Voltage Configuration                                         | 7  |
|     | 6.1      | Open Drain Interface w/ Internal On Die Pullup Resistor                         | 7  |
|     | 6.2      | Open Drain Interface w/ External Pullup Resistor                                | 7  |
|     | 6.3      | Push Pull Interface w/ Internal On Die Pullup Resistor                          | 8  |
|     | 6.4      | IO Operation                                                                    | 8  |
| 7   | Devi     | ce Interface - Protocol                                                         | 10 |
|     | 7.1      | I <sup>2</sup> C and I3C Basic Operation                                        | 10 |
|     | 7.2      | Serial Address of the SPD5 Hub Device                                           | 10 |
|     | 7.3      | Serial Address of the Local Devices                                             | 10 |
|     | 7.4      | Switch from I <sup>2</sup> C Mode to I3C Basic Mode                             | 11 |
|     | 7.5      | Switch from I3C Basic Mode to I <sup>2</sup> C Mode                             | 11 |
|     | 7.6      | SPD5 Hub Device Selection                                                       | 11 |
|     | 7.7      | Local Device Selection Through the SPD5 Hub Device (Before SETHID CCC)          | 11 |
|     | 7.8      | Local Device Selection Through the SPD5 Hub Device (After SETHID CCC)           | 14 |
|     | 7.9      | I <sup>2</sup> C Target Protocol - Host to SPD5 Hub Device                      | 14 |
|     | 7.10     | I <sup>2</sup> C Target Protocol - Host to Local Device Through SPD5 Hub Device | 17 |
|     | 7.11     | I3C Basic Target Protocol - Host to SPD5 Hub Device                             | 21 |
|     | 7.12     | I3C Basic Target Protocol - Host to Local Device (Through SPD5 Hub Device)      | 28 |
|     | 7.13     | I3C Basic Common Command Codes (CCC)                                            | 38 |
| 8   | In Ba    | and Interrupt (IBI)                                                             | 51 |
|     | 8.1      | Enabling and Disabling In Band Event Interrupt Function                         | 51 |
|     | 8.2      | Mechanics of Interrupt Generation - SPD5 Hub Device                             | 51 |
|     | 8.3      | Mechanics of Interrupt Generation - Local Target Device                         | 53 |
|     | 8.4      | Interrupt Arbitration; SETHIDD CCC is Not Issued by Host                        | 56 |
|     | 8.5      | Interrupt Arbitration; SETHID CCC is Issued by Host                             | 63 |
|     | 8.6      | Clearing Device Status and IBI Status Registers                                 | 64 |
| 9   | Erro     | r Check Function                                                                | 65 |
|     | 9.1      | Packet Error Check (PEC) Function                                               | 65 |
|     | 9.2      | Parity Error Check Function                                                     | 65 |
|     |          |                                                                                 |    |



|    | 9.3   | Packet Error Check and Parity Error Handling | 65  |
|----|-------|----------------------------------------------|-----|
| 10 | SPD   | 5 Hub Device - Write and Read                | 69  |
|    | 10.1  | Command Truth Table                          | 69  |
|    | 10.2  | Write and Read Access - NVM Memory           | 70  |
|    | 10.3  | Write and Read Access - Register Memory      | 70  |
|    | 10.4  | Write Protection of Non-Volatile Memory      | 70  |
| 11 | Regi  | isters                                       | 72  |
|    | 11.1  | Register Attribute Definition                | 72  |
|    | 11.2  | Register Map                                 | 73  |
|    | 11.3  | Thermal Sensor Registers Read Out Mechanism  | 74  |
|    | 11.4  | Register Description                         | 74  |
| 12 | Elect | trical Specifications                        | 89  |
|    | 12.1  | Absolute Maximum Ratings                     | 89  |
|    | 12.2  | ESD Ratings                                  | 89  |
|    | 12.3  | Operating Condition, Measurement Condition   | 89  |
|    | 12.4  | DC Characteristics                           | 91  |
|    | 12.5  | AC Characteristics                           | 92  |
|    | 12.6  | AC Timing Definition                         | 94  |
|    | 12.7  | Temperature Sensor Performance               | 99  |
| 13 | Pack  | kage Information                             | 100 |
| 14 | Orde  | ering Information                            | 102 |
| 15 | Rovi  | sion History                                 | 103 |



# 4 Device Overview

# 4.1 Pinout and Pin Assignment



# 4.2 Pin Description

| PIN NAME    | PIN# | PIN TYPE <sup>1</sup> | FUNCTION                                                                          |
|-------------|------|-----------------------|-----------------------------------------------------------------------------------|
| VDDSPD      | 5    | Р                     | 1.8 V Input Power Supply. Connect minimum of 1.0 μF capacitor to GND.             |
| GND         | 6    | G                     | GND.                                                                              |
| HSCL        | 3    | I                     | Host Bus - I <sup>2</sup> C/I3C Basic Input Clock.                                |
| HSDA        | 2    | Ю                     | Host Bus - I <sup>2</sup> C/I3C Basic Data.                                       |
| HSA         | 8    | I                     | Host Bus - I <sup>2</sup> C/I3C Basic Address Pin. See Table 1 for ID definition. |
| LSCL        | 4    | 0                     | Local Bus - I <sup>2</sup> C/I3C Basic Output Clock.                              |
| LSDA        | 1    | Ю                     | Local Bus - I <sup>2</sup> C/I3C Basic Data.                                      |
| VDDIO       | 7    | Р                     | 1.0 V Input Power Supply. Connect minimum of 1.0 μF capacitor to GND.             |
| Thermal Pad | 9    | G                     | Connected to GND Plane.                                                           |

<sup>1.</sup> P = power, G = Ground, I = input, IO=input and output.

Table 1. HSA Pin Resistor Value and ID - SPD5 Family

| HSA Pin Connection   | 3-bit HID | Comment                                      |
|----------------------|-----------|----------------------------------------------|
| 10.0 KΩ to GND       | HID = 000 |                                              |
| 15.4 KΩ to GND       | HID = 001 |                                              |
| 23.2 KΩ to GND       | HID = 010 |                                              |
| 35.7 KΩ to GND       | HID = 011 | 1% Resistor                                  |
| 54.9 KΩ to GND       | HID = 100 | 170 Resistor                                 |
| 84.5 KΩ to GND       | HID = 101 |                                              |
| 127 KΩ to GND        | HID = 110 |                                              |
| 196 KΩ to GND        | HID = 111 |                                              |
| Tied directly to GND | HID = 000 | Offline Mode; Write protect override enabled |



# 5 Device Power Up, Reset and Initialization

## 5.1 Device Power Up

The SPD5 Hub device has one VDDSPD supply input.

In order to prevent inadvertent operations during power up, a Power-On Reset (POR) circuit is included. On cold power on, VDDSPD input supply must rise monotonically between VPON and VDDSPD<sub>min</sub> and VDDIO input supply must rise monotonically to VDDIO<sub>min</sub> without ring back to ensure proper startup.

The SPD5 Hub device uses VDDIO supply for its IO levels and it must reach VDDIO<sub>min</sub> to ensure proper operation of I<sup>2</sup>C or I3C Basic bus interface.

Once the VDDSPD and VDDIO supply is valid and stable, the SPD5 Hub device shall:

- Once VDDSPD supply is valid and stable, within t<sub>Sense\_HSA</sub> time, sense its HSA pin to determine if SPD5 Hub
  device is in application environment or in an offline tester program mode. Depending on what it senses on
  HSA pin, the SPD5 Hub device configures its HID code automatically based on what it detects on HSA pin
  at power up.
- 2. Enable I<sup>2</sup>C interface within t<sub>INIT</sub> time and be ready to receive the command from the Host. The SPD5 Hub device is ready for operation after t<sub>INIT</sub> time.

The host interface HSDA and HSCL signal pins are pulled up to a pullup voltage through a pullup resistor on the platform or on the host controller. The pullup voltage can be available before or after VDDSPD or VDDIO is valid and stable. If HSDA and HSCL pullup voltage is available before VDDSPD or VDDIO is available, the HSDA and HSCL signal is high and remains high with no leakage path or damage to the SPD Hub device.



Figure 1. Device Power Up Sequence

#### 5.2 Device Reset and Initialization

At power down (phase during which VDDSPD input supply decreases continuously), as soon as VDDSPD input supply drops below the VDDSPD<sub>min</sub>, the SPD5 Hub device does not guarantee the operation.

On warm power cycling, the VDDSPD and VDDIO input supply must remain below VPOFF for t<sub>POFF</sub> and must meet cold power on reset timing when restoring the power.



#### 5.3 Bus Clear

The SPD Hub device supports the following described Bus Clear feature in I<sup>2</sup>C mode only. Any attempt by Host to perform I<sup>2</sup>C Bus Clear on a Target device in I3C mode may result in an active drive bus contention on the SDA data line.

There may be abnormal circumstances when the Host abruptly stops clocking SCL while the Target device is in the middle of outputting data for read operation. For this type of events, the SDA data line may appear as stuck low as the device is expecting to receive more clock pulses from the Host. Eventually when the Host has control of the SCL clock, the Host may optionally clear the device that is stuck low on the SDA data line by sending continuous 18 clock pulses without driving the SDA data line followed by STOP operation. The device floats the SDA line within 18 clock pulses and returns to the Idle state. The device is ready for normal new transaction with Start condition.

#### 5.4 Bus Reset

To prevent a malfunctioning device from locking up the I<sup>2</sup>C bus or I3C Basic bus, a bus reset mechanism is defined. It uses a timeout mechanism on HSCL as shown in Figure 2 to force a device bus reset. All devices (All SPD5 Hub and all local Target devices behind the hub) on an I<sup>2</sup>C or I3C Basic bus reset simultaneously. Bus reset operation works in the same way regardless of whether the device is operating in I<sup>2</sup>C or I3C basic mode.

To guarantee the device resets I<sup>2</sup>C bus or I3C Basic bus, the HSCL clock input Low time has to be greater than or equal to ttimeout(Max).

The SPD5 Hub device does not reset  $I^2C$  bus or I3C Basic bus if the HSCL clock input Low time is less than  $t_{TIMEOUT(Min)}$ .

If the HSCL clock input Low time is between t<sub>TIMEOUT(Min)</sub> and t<sub>TIMEOUT(Max)</sub>, the SPD5 Hub device does not guarantee and it may or may not reset the I<sup>2</sup>C bus or I3C Basic bus.

When RESET, the SPD5 Hub device takes the following actions:

- 1. Interface and any pending command or transactions are cleared.
- 2. All internal register values are preserved unless noted otherwise in item # 3 below.
- 3. Device returns to I<sup>2</sup>C mode of operation; *MR18*[7:5] resets to '000'; *MR27*[4] resets to '0'; *MR52*[1:0] resets to '00'.
- 4. Device does not re-sample HSA pin.
- 5. Device floats the HSDA such that it gets pulled High by external/other pullup. The device pulls LSDA pin High.
- 6. Device treats bus resets as STOP operation.



Figure 2. I<sup>2</sup>C or I3C Basic Bus Reset - SPD5 Hub Device



# 6 Device Interface - IO Voltage Configuration

The SPD5 Hub device supports configurable Open Drain and Push Pull IO levels to accommodate broad range of DDR5 platform.

## 6.1 Open Drain Interface w/ Internal On Die Pullup Resistor

Figure 3 below shows the SPD5 Hub device configuration options for Open Drain interface for both Host side and Local side of the device. In this configuration, the SPD5 Hub device supports Open Drain IO levels on both Host and Local side. However, the IO voltage levels on Host side and Local side are independent and can be different. On Host side, the SPD5 device can support IO levels from 1.0V to 3.3V depending on the supply rail Host may have pulled up the resistor to. The host side pullup resistor can be on motherboard or on die inside the host logic device.

On Local side, the SPD5 device can support IO levels from 1.0V to 1.2V and register *MR14*[5] must be configured to '0'.



Figure 3. Open Drain Interface; Internal Pullup Resistor

#### 6.2 Open Drain Interface w/ External Pullup Resistor

Figure 4 below shows the SPD5 Hub device configuration options for Open Drain interface for both Host side and local side of the device. In this configuration, the SPD5 device supports Open Drain IO levels on both Host and Local side. However, the IO voltage levels on Host side and Local side are independent and can be different. On Host side, the SPD5 Hub device can support IO levels from 1.0V to 3.3V depending on the supply rail Host may have pulled up the resistor to. The host side pullup resistor can be on motherboard or on die inside the host logic device.

On Local side, the SPD5 device can support IO levels from 1.0V to 3.3V and MR14[5] must be configured to '1'.



Figure 4. Open Drain Interface; External On Board Pullup Resistor



#### 6.3 Push Pull Interface w/ Internal On Die Pullup Resistor

The configuration option shown in Figure 5 is only supported when device is in I3C Basic mode. Figure 5 below shows the SPD5 Hub device configuration options for Push Pull interface for both Host side and Local side of the device. In this configuration, the SPD5 Hub device supports Push Pull IO levels on both Host and Local side. However, the pullup IO voltage levels on Host side and Local side are independent and can be different.

On Host side, the SPD5 Hub device can support IO levels from 1.0 V to 1.2 V. The host side pullup resistor can be on motherboard or on die inside the host logic device.

On Local side, the SPD5 Hub device can support IO levels from 1.0 V to 1.2V and *MR14*[5] can be configured to '0' or '1'.



Figure 5. Push Pull Interface; On Die Pullup

#### 6.4 IO Operation

The SPD5 Hub device supports configurable IO operation scheme of either Open Drain or Push Pull on its Host side of the interface (HSCL and HSDA) and Local side of the interface (LSCL and LSDA). Further, the SPD5 Hub device supports independent IO configuration on Host side and Local side of the interface. The voltage levels for either Open Drain mode or Push Pull mode can also be independently configurable.

At power on, by default, the SPD5 Hub device comes up in legacy I<sup>2</sup>C mode of operation with Open Drain IO for both its Host side and Local side of the interface. The maximum speed is limited to 1 MHz and supported IO voltage levels are from 1.0V to 3.3V.

After power on, the Host may put the SPD5 Hub device in I3C mode of operation.

In I3C mode, the Host may drive the HSCL clock input of the SPD5 device using either push-pull output driver or using the open-drain output driver. It is expected that for all DDR5 DIMM family environment, the Host may always drive the HSCL clock input using a push-pull output driver.

To support in band interrupt, the SPD5 device supports dynamic switching between Open Drain mode and Push Pull mode on its HSDA and LSDA bus for various events. The Table 2 below describes the different mode of operation by the SPD5 device for each cycle.



# Table 2. SPD5 Hub Device Dynamic IO Operation Mode Switching

| Features                                         | Open Drain Mode | Push Pull Mode |
|--------------------------------------------------|-----------------|----------------|
| START + Device Select Code                       | Yes             | No             |
| START + 7'h7E IBI Header Byte                    | Yes             | No             |
| REPEAT START + Device Select Code                | No              | Yes            |
| REPEAT START + 7'h7E Header Byte                 | No              | Yes            |
| CCC Bytes (i.e after 7'h7E+W=0+ACK)              | No              | Yes            |
| STOP                                             | No              | Yes            |
| ACK/NACK Responses                               | Yes             | No             |
| Command, Block Address, Address Operation        | No              | Yes            |
| Interrupt Request by Target + Device Select Code | Yes             | No             |
| IBI Payload                                      | No              | Yes            |
| Write Data, T-bit sequence                       | No              | Yes            |
| Read Data, T-bit sequence                        | No              | Yes            |
| PEC, T-bit sequence                              | No              | Yes            |



#### 7 Device Interface - Protocol

## 7.1 I<sup>2</sup>C and I3C Basic Operation

At power on, by default, the SPD5 Hub device comes up in I<sup>2</sup>C mode of operation. Following applies in I<sup>2</sup>C mode:

- 1. The maximum operation speed is limited to 1MHz.
- 2. In-band interrupts are not supported.
- 3. Bus reset is supported.
- Parity check is not supported except for supported CCCs.
- 5. Packet Error check is not supported.

The SPD5 Hub device shall operate in the I<sup>2</sup>C mode until put into I<sup>3</sup>C Basic mode via command. The host may put the SPD5 Hub device in I3C Basic mode by issuing SETAASA CCC. Following applies in I3C mode:

- 1. The maximum operation speed is up to 12.5MHz.
- 2. In-band interrupts are supported.
- 3. Bus reset is supported.
- 4. Parity check is always enabled by default.
- 5. Packet error check is supported and by default is disabled.

#### 7.2 Serial Address of the SPD5 Hub Device

The 7-bit serial address of the SPD5 Hub device and all local devices behind the SPD5 Hub applies to both I<sup>2</sup>C and I3C Basic mode of operation identically.

The SPD5 Hub device type ID is 4-bit binary value of 1010b.

The SPD5 Hub device samples the status of the HSA pin on power up. The sampled status of the HSA pin determines the unique host ID (HID) of the device. The host identifier value (HID) is merged with the SPD5 Hub device type 1010xxxb to establish the 7-bit address (SPD5 Hub DevID[6:0]) for the device on the I<sup>2</sup>C or I3C Basic bus as shown in Table 3. For example, if the value sensed on HSA pin identifier is 2 (010 binary), then the unique 7-bit address for this device is 1010 010b.

Table 3. 7-bit Address of SPD5 Hub Device

| Bit 7 | Bit 6         | Bit 5           | Bit 4 | Bit 3  | Bit 2         | Bit 1  | Bit 0      |
|-------|---------------|-----------------|-------|--------|---------------|--------|------------|
| 1     | 0             | 1               | 0     | HID[2] | HID[1]        | HID[0] | R/W        |
|       | SPD5 Hub Devi | ce Type ID (LID | )     |        | Host ID (HID) | ı      | Read/Write |

## 7.3 Serial Address of the Local Devices

Each local device behind the SPD5 Hub device has a unique 4 bit local device ID (LID) code. For example, the PMIC local device type ID is 4-bit binary value of 1001b.

The 3 HID bits of the local device type has a default value of '111' and is merged with its unique 4 bit local ID code to establish the 7-bit address (DevID[6:0]) for the local device on the I<sup>2</sup>C or I3C Basic bus as shown in Table 4. For example, the PMIC local device behind the SPD5 Hub has 7-bit address of 1001 111b.



Table 4. 7-bit Address of the Local Devices (e.g. PMIC Device)

| Bit 7 | Bit 6        | Bit 5         | Bit 4 | Bit 3 | Bit 2         | Bit 1 | Bit 0      |
|-------|--------------|---------------|-------|-------|---------------|-------|------------|
| 1     | 0            | 0             | 1     | 1     | 1             | 1     | R/W        |
|       | Local Device | Type ID (LID) |       |       | Host ID (HID) | )     | Read/Write |

#### 7.4 Switch from I<sup>2</sup>C Mode to I3C Basic Mode

By default when SPD5 Hub first powers on, it operates in I<sup>2</sup>C mode. The SPD5 Hub device shall operate in I<sup>2</sup>C mode until put into I3C Basic mode via command.

In I<sup>2</sup>C mode, the Host is allowed to issue only 3 CCCs (DEVCTRL, SETHID, SETAASA). All other CCCs are not supported and the SPD5 Hub device may simply ignore it. The Host must issue DEVCTRL and SETHID CCC first (if required) followed by SETAASA CCC.

The Host puts the SPD5 Hub device in I3C Basic mode by issuing SETAASA CCC.

When SETAASA CCC is registered by the SPD5 Hub device, it updates the MR18[5] to '1'.

When SETHID CCC is registered by the SPD5 Hub device, it stops the 3-bit HID translation for the local Target device as explained in Section 7.7.

#### 7.5 Switch from I3C Basic Mode to I2C Mode

The Host can put the SPD5 Hub device back in I<sup>2</sup>C mode from I3C mode at any time by issuing RSTDAA CCC. When RSTDAA CCC is registered by the SPD5 Hub device, it updates the *MR18*[5] to '0'.

#### 7.6 SPD5 Hub Device Selection

The Host can access any SPD5 Hub device as shown in Table 5 below in both I<sup>2</sup>C mode and I3C Basic mode. The last 3 bits represent the HID bits.

Table 5. 7-bit Address of Each Hub Devices on I2C / I3C Bus

| Host Access to | 7-bit Address         |
|----------------|-----------------------|
| DIMM 0 SPD Hub | 1010 000              |
| DIMM 1 SPD Hub | 1010 001              |
| DIMM 2 SPD Hub | 1010 010              |
| DIMM 3 SPD Hub | 1010 <mark>011</mark> |
| DIMM 4 SPD Hub | 1010 100              |
| DIMM 5 SPD Hub | 1010 101              |
| DIMM 6 SPD Hub | 1010 110              |
| DIMM 7 SPD Hub | 1010 <mark>111</mark> |

# 7.7 Local Device Selection Through the SPD5 Hub Device (Before SETHID CCC)

By default, the SPD5 Hub device and all local Target devices power up in I<sup>2</sup>C mode of operation, prior to Host issuing SETHID CCC, the Host can access any local device behind the SPD5 Hub device. To access the local device, the Host sends 7-bit address that is made up of 4 bits of local device code (LID) followed by the 3 bits of HID code. The LID code represents which local device the Host is intended to target. The HID code represents which DIMM the local device resides on. The Table 6 below shows an example of four different local device address codes behind SPD5 Hub on each DIMM.



Table 6. 7-bit Address of Each Hub Devices on I2C / I3C Bus

| Host Access to:     | 7-bit Address<br>LID = 1011 | 7-bit Address<br>LID = 1001 | 7-bit Address<br>LID = 0010 | 7-bit Address<br>LID = 0110 |
|---------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
|                     | (RCD)                       | (PMIC)                      | (TS0)                       | (TS1)                       |
| DIMM 0 Local Device | 1011 000                    | 1001 000                    | 0010 000                    | 0110 000                    |
| DIMM 1 Local Device | 1011 001                    | 1001 001                    | 0010 001                    | 0110 001                    |
| DIMM 2 Local Device | 1011 010                    | 1001 010                    | 0010 010                    | 0110 010                    |
| DIMM 3 Local Device | 1011 <mark>011</mark>       | 1001 <mark>011</mark>       | 0010 011                    | 0110 011                    |
| DIMM 4 Local Device | 1011 100                    | 1001 100                    | 0010 100                    | 0110 100                    |
| DIMM 5 Local Device | 1011 101                    | 1001 101                    | 0010 101                    | 0110 101                    |
| DIMM 6 Local Device | 1011 110                    | 1001 110                    | 0010 110                    | 0110 110                    |
| DIMM 7 Local Device | 1011 111                    | 1001 111                    | 0010 111                    | 0110 111                    |

The SPD5 Hub Device monitors the LID code coming from the Host. When it detects the Host access is for the Target device, it compares the last 3 bits of the HID information (shown in Red) coming from the Host against its own unique HID code that it has stored at power on. It compares each 3 bits one at a time. If there is a match, the SPD5 Hub device substitutes that bit with '1' and forwards it to the local device interface. If there is a mismatch, the SPD5 Hub device substitutes that bit with '0' and forwards it to the local device interface. As a result, only the targeted local device will see its last three HID bits as '111' and all non-targeted local devices will see their last three HID bits as anything other than '111' which is not a valid code as shown in Table 4.

There are two exceptions when SPD5 Hub device does not substitute its own HID code when it forwards it to the local Target interface:

- Host issues Start followed by 7'h7E with W=0 (or Host issues Start followed by 0xFC).
- 2. After SPD5 Hub executes SETHID CCC command that Host issues. See Section 7.8.

Figure 6 gives an example of Host accessing local RCD Device on DIMM0. The figure shows Host sends 7-bit address '1011 000'. Each SPD5 Hub device receives this address. Each SPD5 Hub device forwards first four bits of binary address '1011' (LID) on the local device interface. Each SPD5 Hub compares last 3 bits of binary address '000' from the Host against its own unique HID code and substitutes the bits on the local device interface.

Figure 7 gives another example of Host accessing local Temperature Sensor 0 device on DIMM3. The figure shows Host sends 7-bit address '0010 011'. Each SPD5 Hub device receives this address. Each SDP5 Hub device forwards first four bits of binary address '0010' (LID) on the local device interface. Each SPD5 Hub compares last 3 bits of binary address '011' from the Host against its own unique HID code and substitutes the bits on the local device interface.



## Figure 6. Example: Host Accessing RCD on DIMM 0

|            | Hub SPD  |    | RCD      |    | PMIC0    |    | PMIC1    |    | PMIC2    |    | TS0      |    | TS1      |    |
|------------|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|
| DIMM0      | 101 0000 | 50 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1111 | 5F |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM1      | 101 0001 | 51 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1110 | 5E |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM2      | 101 0010 | 52 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1101 | 5D |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM3      | 101 0011 | 53 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1100 | 5C |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM4      | 101 0100 | 54 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1011 | 5B |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM5      | 101 0101 | 55 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1010 | 5A |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM6      | 101 0110 | 56 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          | ,  | 101 1001 | 59 | 101 1001 | 59 | 101 1001 | 59 | 101 1001 | 59 | 101 1001 | 59 | 101 1001 | 59 |
|            |          |    |          |    |          | L  |          | L  |          |    |          | L  |          |    |
| DIMM7      | 101 0111 | 57 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 101 1000 | 58 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 101 1000 | 58 | 101 1000 | 58 | 101 1000 | 58 | 101 1000 | 58 | 101 1000 | 58 | 101 1000 | 58 |

Figure 7. Example: Host Accessing Temperature Sensor 0 on DIMM 3

|            | Hub SPD  |    | RCD      |    | PMIC0    |    | PMIC1    |    | PMIC2    |    | TS0      |    | TS1      |    |
|------------|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|----------|----|
| DIMM0      | 101 0000 | 50 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0100 | 14 | 001 0100 | 14 | 001 0100 | 14 | 001 0100 | 14 | 001 0100 | 14 | 001 0100 | 14 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM1      | 101 0001 | 51 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0101 | 15 | 001 0101 | 15 | 001 0101 | 15 | 001 0101 | 15 | 001 0101 | 15 | 001 0101 | 15 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM2      | 101 0010 | 52 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0110 | 16 | 001 0110 | 16 | 001 0110 | 16 | 001 0110 | 16 | 001 0110 | 16 | 001 0110 | 16 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM3      | 101 0011 | 53 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0111 | 17 | 001 0111 | 17 | 001 0111 | 17 | 001 0111 | 17 | 001 0111 | 17 | 001 0111 | 17 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM4      | 101 0100 | 54 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0000 | 10 | 001 0000 | 10 | 001 0000 | 10 | 001 0000 | 10 | 001 0000 | 10 | 001 0000 | 10 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM5      | 101 0101 | 55 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0001 | 11 | 001 0001 | 11 | 001 0001 | 11 | 001 0001 | 11 | 001 0001 | 11 | 001 0001 | 11 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM6      | 101 0110 | 56 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0010 | 12 | 001 0010 | 12 | 001 0010 | 12 | 001 0010 | 12 | 001 0010 | 12 | 001 0010 | 12 |
|            |          |    |          |    |          |    |          |    |          |    |          |    |          |    |
| DIMM7      | 101 0111 | 57 | 101 1111 | 5F | 100 1111 | 4F | 100 0111 | 47 | 110 0111 | 67 | 001 0111 | 17 | 011 0111 | 37 |
| Host Sends | 001 0011 | 13 |          |    |          |    |          |    |          |    |          |    |          |    |
| Hub Sends  |          |    | 001 0011 | 13 | 001 0011 | 13 | 001 0011 | 13 | 001 0011 | 13 | 001 0011 | 13 | 001 0011 | 13 |



## 7.8 Local Device Selection Through the SPD5 Hub Device (After SETHID CCC)

When SETHID CCC is registered by the SPD5 Hub device, it stops the 3-bit HID translation for the local Target device as explained in Section 7.7. After Host sends SETHID CCC, the Host still accesses all local Target devices behind the SPD5 Hub as shown in Table 6. There is no change in how Host accesses the SPD5 Hub device and all local Target devices behind the SPD5 Hub device before or after SETHID CCC.

## 7.9 I<sup>2</sup>C Target Protocol - Host to SPD5 Hub Device

The SPD5 Hub devices operate on a standard I<sup>2</sup>C serial interface. Transactions where the SPD5 Hub device is the targeted Target device begin with the Host issuing a START condition followed by a 7-bit SPD5 Hub device address then a read or write bit, R/W. All data are transmitted with the most significant bit MSB first. During the address followed by R/W bit transmission, the SPD5 Hub device typically replies with an ACK unless there are conditions when it may passively assert a NACK.

The SPD5 Hub device does not allow any read or write operations to its non-volatile memory when it is busy with internal write operation to non-volatile memory. The Host should either check *MR48*[3] register status or ensure that Write time (tw) parameter is satisfied prior to performing another write or read operations to non-volatile memory. If Host violates this and performs either write or read operation to non-volatile memory, the SPD5 Hub device ACKs the address byte to allow possible volatile register access. However, the SPD5 Hub device NACKs the subsequent write or read operation if MemReg = '1' and sets the *MR52*[7] = '1'.

The SPD5 Hub device does allow any read or write operation to its volatile memory (i.e. MemReg = '0') when it is busy with internal write operation to non-volatile memory.

To allow compatibility with legacy I<sup>2</sup>C host controller, the SPD5 Hub device offers two ways to address 1024 bytes of non-volatile memory when it is operating in I<sup>2</sup>C mode only. By default, the SPD5 Hub device accepts 1 byte of address which covers first 128 bytes of non-volatile memory. The Host must select the page pointer through volatile register *MR11*[2:0] to address the entire 1024 bytes of non-volatile memory.

Alternatively, at initial power on, the Host can set the *MR11*[3] = '1' to address the entire 1024 bytes of non-volatile memory with 2 bytes of address and hence not required to go through page selection to address entire non-volatile memory.

This two byte address mode is only applicable to SPD5 Hub device and it is not applicable to PMIC or TS or RCD device in I<sup>2</sup>C mode.

The SPD5 Hub device volatile register space does not require the page selection process as all volatile registers are within first 128 bytes.



#### 7.9.1 Write Operation - Data Packet

The MemReg bit determines if the target of the transaction is an NVM location (MemReg = '1') or an internal register (MemReg = '0'). When MemReg = '0', there is no concept of "Block Address"; Block Address bits are treated simply Upper Address bits.

| Start                | Bit 7  | Bit 6        | Bit 5         | Bit 4     | Bit 3 Bit 2 Bit 1 |  | Bit 0 | A/N | Stop |         |
|----------------------|--------|--------------|---------------|-----------|-------------------|--|-------|-----|------|---------|
| S or Sr <sup>1</sup> | 1      | 0            | 1             | 0 HID W=0 |                   |  |       | Α   |      |         |
|                      | MemReg | Blk Addr [0] | Address [5:0] |           |                   |  |       |     | Α    |         |
|                      |        |              | D             | Data      |                   |  |       |     |      |         |
|                      |        |              |               |           |                   |  |       |     |      |         |
|                      |        |              | D             | ata       |                   |  |       |     | Α    | Sr or P |

Table 7. Write Command Data Packet; MR11[3] = '0'

In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

|                      |        |              |       |               | ,                           |       |       |       |         |      |
|----------------------|--------|--------------|-------|---------------|-----------------------------|-------|-------|-------|---------|------|
| Start                | Bit 7  | Bit 6        | Bit 5 | Bit 4         | Bit 3                       | Bit 2 | Bit 1 | Bit 0 | A/N     | Stop |
| S or Sr <sup>1</sup> | 1      | 0            | 1     | 0             |                             | HID   |       | W=0   | Α       |      |
|                      | MemReg | Blk Addr [0] |       | Address [5:0] |                             |       |       |       | Α       |      |
|                      | 0      | 0            | 0     | 0             | Blk Addr [4:1] <sup>2</sup> |       |       |       | Α       |      |
|                      |        |              | D     | ata           |                             |       |       |       | Α       |      |
|                      |        |              |       |               |                             |       |       | Α     |         |      |
|                      |        |              | Data  |               |                             |       |       | Α     | Sr or P |      |

Table 8. Write Command Data Packet; MR11[3] = '1'

#### 7.9.2 Read Operation - Data Packet

The MemReg bit determines if the target of the transaction is an NVM location (MemReg = '1') or an internal register (MemReg = '0'). When MemReg = '0', there is no concept of "Block Address"; Block Address bits are treated simply Upper Address bits.

|                      |        |              | ,     |       |         |          |       |       |       |         |  |  |
|----------------------|--------|--------------|-------|-------|---------|----------|-------|-------|-------|---------|--|--|
| Start                | Bit 7  | Bit 6        | Bit 5 | Bit 4 | Bit 3   | Bit 2    | Bit 1 | Bit 0 | A/N   | Stop    |  |  |
| S or Sr <sup>1</sup> | 1      | 0            | 1     | 0     |         | HID      |       | W=0   | Α     |         |  |  |
|                      | MemReg | Blk Addr [0] |       |       | Addres  | ss [5:0] |       |       | Α     |         |  |  |
| Sr                   | 1      | 0            | 1     | 0     | HID R=1 |          |       |       | $A^2$ |         |  |  |
|                      |        |              | D     | ata   |         |          |       |       | Α     |         |  |  |
|                      |        |              |       |       |         |          |       |       | Α     |         |  |  |
|                      |        |              | D     | ata   |         |          |       |       | N     | Sr or P |  |  |

Table 9. Read Command Data Packet; MR11[3] = '0'

- 1. In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.
- If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. The device may eventually ACK.

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

<sup>2.</sup> The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.

Table 10. Read Command Data Packet: MR11[3] = '1'



**Start** 

S or Sr1

|       | Tubio Ioi Itouu | • • • • • • • • • • • • • • • • • • • |       |       |       |       |       |     |
|-------|-----------------|---------------------------------------|-------|-------|-------|-------|-------|-----|
| Bit 7 | Bit 6           | Bit 5                                 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N |
| 1     | 0               | 1                                     | 0     |       | HID   |       | W=0   | Α   |
| _     |                 |                                       | •     |       |       |       | •     |     |

Stop Address [5:0] MemReg Blk Addr [0]

|    | 0 | 0 | 0  | 0   | Blk Addr [4:1] <sup>2</sup> | Blk Addr [4:1] <sup>2</sup> |       |    |  |
|----|---|---|----|-----|-----------------------------|-----------------------------|-------|----|--|
| Sr | 1 | 0 | 1  | 0   | HID                         | R=1                         | $A^3$ |    |  |
|    |   |   | D  | ata |                             |                             | Α     |    |  |
|    |   |   |    |     |                             |                             | Α     |    |  |
|    |   |   | D. | ata |                             |                             | N     | Sr |  |

- In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.
- The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. The device may eventually ACK.

#### **Default Read Address Pointer Mode**

During normal operation of the DDR5 DIMM, the Host periodically may poll critical information from the same location. An example may be the SPD5 Hub device's temperature readout. To help improve the efficiency of the I2C bus protocol, the SPD5 Hub offers a default read address pointer mode so that whenever the SPD5 Hub device sees the STOP operation on its HSCL and HSDA bus, its read address pointer always resets to default address. The default read pointer address mode is enabled through register MR18[4] and default starting address for read operation is selectable through register MR18[3:2]. This allows Host to read the read command data packet as shown in Table 11 compared to as shown in Table 10. The default read address pointer reduces the packet overhead by 3 bytes. The Host typically enables this mode when the normal operation of the DDR5 DIMM begins. The default read address pointer mode is only applicable to volatile register space (i.e. MemReg = '0').

Table 11. Read Command Data Packet w/ Default Address Pointer Mode

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N | Stop    |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|-----|---------|
| S or Sr | 1     | 0     | 1     | 0     |       | HID   |       | R=1   | Α   |         |
|         |       | Α     |       |       |       |       |       |       |     |         |
|         |       |       |       |       |       |       |       |       | Α   |         |
|         |       |       |       | Da    | ata   |       |       |       | N   | Sr or P |



## 7.10 I<sup>2</sup>C Target Protocol - Host to Local Device Through SPD5 Hub Device

## 7.10.1 Write Operation - Data Packet

Table 12. Write Command Data Packet (e.g. TS)

| Start    | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3    | Bit 2 | Bit 1   | Bit 0 | A/N | Stop |
|----------|-------|-------|-------|--------|----------|-------|---------|-------|-----|------|
| S or Sr1 | 0     | 0     | 1     | 0      |          | HID   |         | W=0   | Α   |      |
|          |       |       |       | Addres | ss [7:0] | Α     |         |       |     |      |
|          |       |       |       | Da     | ata      | Α     |         |       |     |      |
|          |       |       |       | Da     | ata      |       |         |       | Α   |      |
|          |       |       |       |        |          | Α     |         |       |     |      |
|          |       |       |       | Da     | ata      | Α     | Sr or P |       |     |      |

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

Table 13. Write Command Data Packet (e.g. PMIC)

| Start                | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3           | Bit 2 | Bit 1 | Bit 0 | A/N | Stop    |  |  |
|----------------------|-------|-------|-------|-------|-----------------|-------|-------|-------|-----|---------|--|--|
| S or Sr <sup>1</sup> | 1     | 0     | 0     | 1     |                 | HID   |       | W=0   | Α   |         |  |  |
|                      |       |       |       | Addre | Address [7:0] A |       |       |       |     |         |  |  |
|                      |       | Data  |       |       |                 |       |       |       |     |         |  |  |
|                      |       |       |       | Da    | Data            |       |       |       |     |         |  |  |
|                      |       |       |       |       |                 |       |       |       | Α   |         |  |  |
|                      |       |       |       | Da    | ata             |       |       |       | Α   | Sr or P |  |  |

In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

When Host makes any write request to the RCD device, the RCD protocol has PEC check in the last byte. The SPD simply treats the last byte as Data like any other bytes as shown in Table 15. The RCD device requires valid stable input clock (DCK\_t, DCK\_c), Reset\_n and DCS\_n to allow any read or write access on its I<sup>2</sup>C interface.

Table 14. Write Command Data Packet (e.g. RCD; PEC Disabled)

| Start    | Bit 7                | Bit 6                  | Bit 5 | Bit 4                 | Bit 3      | Bit 2 | Bit 1   | Bit 0 | A/N | Stop |
|----------|----------------------|------------------------|-------|-----------------------|------------|-------|---------|-------|-----|------|
| S or Sr1 | 1                    | 0                      | 1     | 1                     |            | Α     |         |       |     |      |
|          |                      | Data (I2C Bus Command) |       |                       |            |       |         |       | Α   |      |
|          |                      |                        |       | Data (Byte            | Α          |       |         |       |     |      |
|          |                      |                        | Ι     | Data (Rese            | rved; 0x00 | )     |         |       | Α   |      |
|          |                      | Data (Dev/Channel Num) |       |                       |            |       |         |       |     |      |
|          |                      |                        | I     | Data (Page            | Num [7:0]  | )     |         |       | Α   |      |
|          |                      |                        |       | Data (Reg             | Num [7:0]) | ı     |         |       | Α   |      |
|          |                      | Data (Wr Data [31:24]) |       |                       |            |       | Α       |       |     |      |
|          |                      | Data (Wr Data [23:16]) |       |                       |            |       |         |       | Α   |      |
|          |                      |                        |       | Data (Wr Data [15:8]) |            |       |         |       |     |      |
|          | Data (Wr Data [7:0]) |                        |       |                       |            | Α     | Sr or P |       |     |      |

In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.



Table 15. Write Command Data Packet (e.g. RCD; PEC Enabled)

| Start                | Bit 7                 | Bit 6               | Bit 5 | Bit 4       | Bit 3       | Bit 2 | Bit 1 | Bit 0 | A/N | Stop    |
|----------------------|-----------------------|---------------------|-------|-------------|-------------|-------|-------|-------|-----|---------|
| S or Sr <sup>1</sup> | 1                     | 0                   | 1     | 1           |             | HID   | Α     |       |     |         |
|                      |                       |                     | Da    | ata (I²C Bu | s Commar    | ıd)   |       |       | Α   |         |
|                      |                       | Data (Byte Count=8) |       |             |             |       |       |       |     |         |
|                      |                       |                     | [     | Data (Rese  | rved; 0x00  | )     |       |       | Α   |         |
|                      |                       |                     | D     | ata (Dev/C  | hannel Nui  | n)    |       |       | Α   |         |
|                      |                       |                     | I     | Data (Page  | Num [7:0]   | )     |       |       | Α   |         |
|                      |                       |                     |       | Data (Reg   | Num [7:0])  | )     |       |       | Α   |         |
|                      |                       |                     | [     | Data (Wr D  | ata [31:24] | )     |       |       | Α   |         |
|                      |                       |                     | [     | Data (Wr D  | ata [23:16] | )     |       |       | Α   |         |
|                      | Data (Wr Data [15:8]) |                     |       |             |             |       |       |       | Α   |         |
|                      |                       |                     |       | Data (Wr    | Data [7:0]) | Α     |       |       |     |         |
|                      |                       |                     |       | Data (Pl    | EC [7:0])   |       |       |       | Α   | Sr or P |

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

#### 7.10.2 Read Operation - Data Packet

When Host makes any read request to the RCD device, the RCD protocol has PEC check for the RCD address information as well as data returned by the RCD. The SPD5 Hub simply treats the PEC information as data byte like any other data byte as shown in Table 19. The SPD5 Hub device does not check for the PEC. The RCD device requires valid stable input clock (DCK\_t, DCK\_c), Reset\_n and DCS\_n to allow any read or write access on its I<sup>2</sup>C interface.

Table 16. Read Command Data Packet (e.g. TS)

| Start                | Bit 7 | Bit 6         | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N            | Stop    |
|----------------------|-------|---------------|-------|-------|-------|-------|-------|-------|----------------|---------|
| S or Sr <sup>1</sup> | 0     | 0             | 1     | 0     |       | HID   |       | W=0   | Α              |         |
|                      |       | Address [7:0] |       |       |       |       |       |       | Α              |         |
| Sr                   | 0     | 0             | 1     | 0     |       | HID   |       | R=1   | A <sup>2</sup> |         |
|                      |       |               |       | Da    | ata   |       |       |       | Α              |         |
|                      |       |               |       | Da    | ata   |       |       |       | Α              |         |
|                      |       |               |       |       |       |       | Α     |       |                |         |
|                      |       |               |       | Da    | ata   |       |       |       | N              | Sr or P |

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

<sup>2.</sup> If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire.



| Start                | Bit 7 | Bit 6 | Bit 5         | Bit 4  | Bit 3    | Bit 2 | Bit 1          | Bit 0   | A/N | Stop |
|----------------------|-------|-------|---------------|--------|----------|-------|----------------|---------|-----|------|
| S or Sr <sup>1</sup> | 1     | 0     | 0 1 HID W=0 A |        |          |       |                |         |     |      |
|                      |       |       |               | Addres | ss [7:0] | Α     |                |         |     |      |
| Sr                   | 1     | 0     | 0             | 1      |          | HID   | A <sup>2</sup> |         |     |      |
|                      |       |       |               | Da     | ata      |       | Α              |         |     |      |
|                      |       |       |               | Da     | ata      |       |                |         | Α   |      |
|                      |       |       |               |        |          | Α     |                |         |     |      |
|                      |       |       |               | Da     | ata      |       | N              | Sr or P |     |      |

- 1. In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.
- 2. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire.

Table 18. Read Command Data Packet (e.g. RCD; PEC Disabled; Legacy Format)

| Start                | Bit 7                  | Bit 6 | Bit 5 | Bit 4       | Bit 3       | Bit 2                 | Bit 1 | Bit 0 | A/N            | Stop    |  |  |  |  |                       |  |  |  |  |
|----------------------|------------------------|-------|-------|-------------|-------------|-----------------------|-------|-------|----------------|---------|--|--|--|--|-----------------------|--|--|--|--|
| S or Sr <sup>1</sup> | 1                      | 0     | 1     | 1           |             | HID                   |       | W=0   | Α              |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       | Da    | ata (I²C Bu | s Comman    | d)                    |       |       | Α              |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       |       | Data (Byte  | Count=4)    |                       |       |       | Α              |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       | [     | Data (Rese  | rved; 0x00  | )                     |       |       | Α              |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       |       | Α           |             |                       |       |       |                |         |  |  |  |  |                       |  |  |  |  |
|                      | Data (Page Num [7:0])  |       |       |             |             | Data (Page Num [7:0]) |       |       |                |         |  |  |  |  | Data (Page Num [7:0]) |  |  |  |  |
|                      |                        |       |       | Α           | Р           |                       |       |       |                |         |  |  |  |  |                       |  |  |  |  |
| S                    | 1                      | 0     | 1     | 1           |             | Α                     |       |       |                |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       | Da    | ata (I2C Bu | ıs Commar   | nd)                   |       |       | Α              |         |  |  |  |  |                       |  |  |  |  |
| Sr                   | 1                      | 0     | 1     | 1           |             | HID                   |       | R=1   | A <sup>2</sup> |         |  |  |  |  |                       |  |  |  |  |
|                      | Data (Byte Count)      |       |       |             |             |                       | Α     |       |                |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       |       | Data (      | Status)     |                       |       |       | Α              |         |  |  |  |  |                       |  |  |  |  |
|                      | Data (Rd Data [31:24]) |       |       |             |             |                       | Α     |       |                |         |  |  |  |  |                       |  |  |  |  |
|                      | Data (Rd Data [23:16]) |       |       |             |             |                       |       |       |                |         |  |  |  |  |                       |  |  |  |  |
|                      | Data (Rd Data [15:8])  |       |       |             |             |                       |       |       |                |         |  |  |  |  |                       |  |  |  |  |
|                      |                        |       |       | Data (Rd    | Data [7:0]) |                       |       |       | Α              | Sr or P |  |  |  |  |                       |  |  |  |  |

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

<sup>2.</sup> If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire.



Table 19. Read Command Data Packet (e.g. RCD; PEC Enabled; Legacy Format)

| Start                | Bit 7                | Bit 6                 | Bit 5 | Bit 4       | Bit 3       | Bit 2 | Bit 1 | Bit 0 | A/N            | Stop    |  |
|----------------------|----------------------|-----------------------|-------|-------------|-------------|-------|-------|-------|----------------|---------|--|
| S or Sr <sup>1</sup> | 1                    | 0                     | 1     | 1           |             | HID   |       | W=0   | Α              |         |  |
|                      |                      |                       | D     | ata (I²C Bu | s Comman    | ıd)   |       |       | Α              |         |  |
|                      |                      |                       |       | Data (Byte  | Count=4)    |       |       |       | Α              |         |  |
|                      |                      |                       | I     | Data (Rese  | rved; 0x00  | )     |       |       | Α              |         |  |
|                      |                      |                       |       | Α           |             |       |       |       |                |         |  |
|                      |                      | Α                     |       |             |             |       |       |       |                |         |  |
|                      |                      | Α                     |       |             |             |       |       |       |                |         |  |
|                      |                      |                       |       | Α           | Р           |       |       |       |                |         |  |
| S                    | 1                    | 0                     | 1     | 1           |             | Α     |       |       |                |         |  |
|                      |                      |                       | D     | ata (I²C Bu | s Comman    | ıd)   |       |       | Α              |         |  |
| Sr                   | 1                    | 0                     | 1     | 1           |             | HID   |       | R=1   | A <sup>2</sup> |         |  |
|                      |                      |                       |       | Data (By    | te Count)   |       |       |       | Α              |         |  |
|                      |                      |                       |       | Data (      | Status)     |       |       |       | Α              |         |  |
|                      |                      |                       | I     | Data (Rd D  | ata [31:24] | )     |       |       | Α              |         |  |
|                      |                      |                       |       | Α           |             |       |       |       |                |         |  |
|                      |                      | Data (Rd Data [15:8]) |       |             |             |       |       |       |                |         |  |
|                      | Data (Rd Data [7:0]) |                       |       |             |             |       |       |       |                |         |  |
|                      |                      |                       |       | Data (Pl    | EC [7:0])   |       |       |       | Α              | Sr or P |  |

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

Table 20. Read Command Data Packet (e.g. RCD; PEC Disabled; Optimized Format)

| Start                | Bit 7                  | Bit 6                 | Bit 5 | Bit 4       | Bit 3       | Bit 2 | Bit 1 | Bit 0 | A/N   | Stop    |
|----------------------|------------------------|-----------------------|-------|-------------|-------------|-------|-------|-------|-------|---------|
| S or Sr <sup>1</sup> | 1                      | 0                     | 1     | 1           |             | HID   |       | W=0   | Α     |         |
|                      |                        |                       | Da    | ata (I²C Bu | s Comman    | d)    |       |       | Α     |         |
|                      |                        | Data (Byte Count=4)   |       |             |             |       |       |       |       |         |
|                      |                        | Data (Reserved; 0x00) |       |             |             |       |       |       |       |         |
|                      | Data (Dev/Channel Num) |                       |       |             |             |       |       |       |       |         |
|                      | Data (Page Num [7:0])  |                       |       |             |             |       |       |       |       |         |
|                      |                        | Data (Reg Num [7:0])  |       |             |             |       |       |       | Α     | Р       |
| Sr                   | 1                      | 0                     | 1     | 1           |             | HID   |       | R=1   | $A^2$ |         |
|                      |                        |                       |       | Data (By    | te Count)   |       |       |       | Α     |         |
|                      |                        |                       |       | Data (      | Status)     |       |       |       | Α     |         |
|                      | Data (Rd Data [31:24]) |                       |       |             |             | Α     |       |       |       |         |
|                      |                        |                       |       | Α           |             |       |       |       |       |         |
|                      |                        |                       |       | Α           |             |       |       |       |       |         |
|                      |                        |                       |       | Data (Rd l  | Data [7:0]) |       |       |       | Α     | Sr or P |

<sup>1.</sup> In I<sup>2</sup>C mode, Start or Repeat Start operation followed by 7'h7E with W=0 is only allowed for the purpose of issuing CCCs that are allowed in I<sup>2</sup>C mode. Any other operation including another Repeat Start is considered an illegal operation.

<sup>2.</sup> If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire.

If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire.



## 7.11 I3C Basic Target Protocol - Host to SPD5 Hub Device

# 7.11.1 Write Operation Data Packet

The SPD5 Hub devices operate on a standard I3C serial interface. Transactions where the SPD5 Hub device is the targeted Target device begin with the Host issuing a START condition followed by a 7-bit SPD5 Hub device address then a write bit, R/W. All data are transmitted with the most significant bit MSB first. During the address followed by R/W bit transmission, the SPD5 Hub device typically replies with an ACK unless there are conditions when it may passively assert a NACK. The 'T' bit carries Parity information from the Host for each byte.

The SPD5 Hub device does not allow any read or write operations to its non-volatile memory when it is busy with internal write operation to non-volatile memory. The Host should either check MR48[3] register status or ensure that Write time ( $t_W$ ) parameter is satisfied prior to performing another write or read operations to non-volatile memory. If Host violates this and performs either write or read operation to non-volatile memory, the SPD5 Hub device always ACKs the address byte. In a subsequent byte, the device ignores the write operation if MemReg = '1' and sets the MR52[7] = '1' and requests IBI if IBI function is enabled. Subsequently, if Host continues to do the read operation with Repeat Start, the SPD5 Hub device NACKs.

The SPD5 Hub device does allow any read or write operation to its volatile memory (i.e. MemReg = '0') when it is busy with internal write operation to non-volatile memory.

The Packet Error Code (PEC) function is disabled by default when the SPD5 Hub device is put in I3C Basic mode. The Host may enable this function through DEVCTRL CCC (RegMod = '0'). If enabled, the PEC is appended at the end of all transactions. If PEC is enabled, the Host must complete the burst length as indicated in CMD field. In other words, the Host must not interrupt the burst length pre-maturely for Write operation.

The MemReg bit determines if the target of the transaction is an NVM location (MemReg = '1') or an internal register (MemReg = '0'). When MemReg = '0', there is no concept of "Block Address"; Block Address bits are treated simply Upper Address bits.

| Start   | Bit 7  | Bit 6        | Bit 5                           | Bit 4 | Bit 3   | Bit 2    | Bit 1 | Bit 0 | A/N/T              | Stop |  |
|---------|--------|--------------|---------------------------------|-------|---------|----------|-------|-------|--------------------|------|--|
| S or Sr | 1      | 0            | 1                               | 0     | HID W=0 |          |       |       | A <sup>1,2,3</sup> |      |  |
|         | MemReg | Blk Addr [0] |                                 |       | Т       |          |       |       |                    |      |  |
|         | 0      | 0            | 0 0 Blk Addr [4:1] <sup>4</sup> |       |         |          |       |       | Т                  |      |  |
|         |        |              | Da                              | ata   |         |          |       |       | Т                  |      |  |
|         |        |              |                                 |       |         |          |       |       |                    |      |  |
|         |        |              | Da                              | ata   | Т       | Sr⁵ or P |       |       |                    |      |  |

Table 21. Write Command Data Packet; PEC Disabled

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 3. The SPD5 Hub device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 4. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 5. Repeat Start or Repeat Start with 7'h7E.



| Table 22. Write | e Comn | nand Da | ta Pack | et; PEC | Enable | d |
|-----------------|--------|---------|---------|---------|--------|---|
|                 |        |         |         |         |        |   |

| Start   | Bit 7  | Bit 7 Bit 6 Bit 5 |     |        |     | Bit 2 | Bit 1 | Bit 0              | A/N/T | Stop     |
|---------|--------|-------------------|-----|--------|-----|-------|-------|--------------------|-------|----------|
| S or Sr | 1      | 0                 | 0   |        | HID |       | W=0   | A <sup>1,2,3</sup> |       |          |
|         | MemReg | Blk Addr [0]      |     | Addres |     | Т     |       |                    |       |          |
|         |        | CMD               | W=0 |        |     | Т     |       |                    |       |          |
|         |        |                   | Da  | ata    |     |       |       |                    | Т     |          |
|         |        |                   |     |        |     |       |       |                    | Т     |          |
|         | Data   |                   |     |        |     |       |       | Т                  |       |          |
|         | PEC    |                   |     |        |     |       |       |                    | Т     | Sr⁵ or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- 2. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The SPD5 Hub device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 4. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 5. Repeat Start or Repeat Start with 7'h7E.

The Host may optionally allow SPD5 Hub device to request IBI. For this case, the transactions to the SPD5 Hub device begin with the I3C Basic Host issuing a START condition followed by 7'h7E and then write bit. If SPD5 Hub device has a pending IBI, it transmits its 7-bit device select code followed by R=1. If SPD5 Hub device has no pending IBI, there is no action taken by SPD5 Hub. The Table 23 and Table 24 show the I3C Basic bus write command data packet with optional IBI header for PEC disabled and PEC enabled cases respectively. Note that in Table 24, PEC calculation does not include IBI header byte (7'h7E followed by W=0).

Table 23. Write Command Data Packet w/ IBI Header; PEC Disabled

| Start | Bit 7  | Bit 6        | Bit 5                | Bit 4 | A/N/T              | Stop |   |     |                  |  |  |
|-------|--------|--------------|----------------------|-------|--------------------|------|---|-----|------------------|--|--|
| S     | 1      | 1            | 1                    | 1     | 1                  | 1    | 0 | W=0 | A <sup>1,3</sup> |  |  |
| Sr    | 1      | 0            | 1                    | 0     | A <sup>2,3,4</sup> |      |   |     |                  |  |  |
|       | MemReg | Blk Addr [0] |                      |       | Т                  |      |   |     |                  |  |  |
|       | 0      | 0            | 0                    | 0     | Т                  |      |   |     |                  |  |  |
|       |        |              | Da                   | ata   |                    |      |   |     | Т                |  |  |
|       |        |              |                      |       |                    |      |   |     |                  |  |  |
|       |        | Т            | Sr <sup>6</sup> or P |       |                    |      |   |     |                  |  |  |

- See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (Repeat Start).
- 2. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK) and Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 4. The SPD5 Hub device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 5. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 6. Repeat Start or Repeat Start with 7'h7E.



| Table 24. Write Command Data Packet w/ IBI Header: PEC Ena |
|------------------------------------------------------------|
|------------------------------------------------------------|

| Start | Bit 7  | Bit 6        | Bit 5         | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop                 |
|-------|--------|--------------|---------------|-------|-------|-------|-------|-------|--------------------|----------------------|
| S     | 1      | 1            | 1             | 1     | 1     | 1     | 0     | W=0   | A <sup>1,3</sup>   |                      |
| Sr    | 1      | 0            | 1             | 0     |       | HID   |       | W=0   | A <sup>2,3,4</sup> |                      |
|       | MemReg | Blk Addr [0] | Address [5:0] |       |       |       |       |       |                    |                      |
|       |        | CMD          |               | W=0   |       | Т     |       |       |                    |                      |
|       |        |              | Da            | ata   |       |       |       |       | Т                  |                      |
|       |        |              |               |       |       |       |       |       | Т                  |                      |
|       | Data   |              |               |       |       |       |       |       | Т                  |                      |
|       | PEC    |              |               |       |       |       |       |       | Т                  | Sr <sup>6</sup> or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (Repeat Start).
- 2. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK) and Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- 3. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 4. The SPD5 Hub device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 5. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 6. Repeat Start or Repeat Start with 7'h7E.

#### 7.11.2 Read Operation Data Packet

The transactions to SPD5 Hub Target device begin with the I3C Basic Host issuing a START condition followed by a 7-bit SPD5 Hub device type identifier then a write bit. All I3C Basic bus data are transmitted with the most significant bit MSB first. During select code transmission, the SPD5 Hub device typically replies with an ACK unless there are exceptional conditions when it may passively assert a NACK. See Table 25. The 'T' bit carries Parity information from the Host prior to Repeated START. After Repeated START, 'T' bit carries information from SPD5 Hub device to Host indicating Continuous ('1') or Stop ('0') whether it is transmitting the last byte or not.

The Packet Error Code (PEC) function is disabled by default when SPD5 Hub device is put in I3C Basic mode. The Host may enable this function through DEVCTRL CCC (RegMod = '0'). If enabled, the PEC is appended as shown in Table 26. If PEC is enabled, the Host must complete the burst length as indicated in CMD field. In other words, the Host must not interrupt the burst length pre-maturely for Read operation.

The MemReg bit determines if the target of the transaction is an NVM location (MemReg = '1') or an internal register (MemReg = '0'). When MemReg = '0', there is no concept of "Block Address"; Block Address bits are treated simply Upper Address bits.



#### Table 25. Read Command Data Packet; PEC Disabled

| Start   | Bit 7  | Bit 6        | Bit 5                           | Bit 4     | Bit 3 Bit 2 Bit 1 Bit 0 |  |  |  | A/N/T              | Stop                 |
|---------|--------|--------------|---------------------------------|-----------|-------------------------|--|--|--|--------------------|----------------------|
| S or Sr | 1      | 0            | 1                               | 0         | HID W=0                 |  |  |  | A <sup>1,2,3</sup> |                      |
|         | MemReg | Blk Addr [0] |                                 |           | Т                       |  |  |  |                    |                      |
|         | 0      | 0            | 0 0 Blk Addr [4:1] <sup>4</sup> |           |                         |  |  |  | Т                  |                      |
| S or Sr | 1      | 0            | 1                               | 0 HID R=1 |                         |  |  |  | A/N <sup>5,6</sup> |                      |
|         |        |              | Da                              | ata       |                         |  |  |  | T=1                |                      |
|         |        |              |                                 |           |                         |  |  |  |                    |                      |
|         | Data   |              |                                 |           |                         |  |  |  |                    | Sr <sup>9</sup> or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The SPD5 Hub device does not check for parity error in subsequent bytes when it determines 7-bit device select code
  issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP
  or next Repeat Start operation.
- 4. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 5. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity errors the SPD5 Hub may eventually ACK.
- 6. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 7. See Figure 11 to see how Host ends Target device operation.
- 8. For NVM read memory access (i.e. MemReg = '1'), when last byte is reached (1024 Byte) or for volatile memory access (i.e. MemReg = '0'), when last byte (i.e. MR255) is reached (extreme rare case), the Target device sends T = '0'. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 9. Repeat Start or Repeat Start with 7'h7E.

Table 26. Read Command Data Packet; PEC Enabled

| Start   | Bit 7                               | Bit 6           | Bit 5 | Bit 4       | Bit 3 | Bit 2 | Bit 1 | Bit 0              | A/N/T | Stop |
|---------|-------------------------------------|-----------------|-------|-------------|-------|-------|-------|--------------------|-------|------|
| S or Sr | 1                                   | 0               | 1     | 1 0 HID W=0 |       |       |       |                    |       |      |
|         | MemReg                              | Blk Addr [0]    |       |             | Т     |       |       |                    |       |      |
|         | CMD R=1 Blk Addr [4:1] <sup>4</sup> |                 |       |             |       |       |       |                    | Т     |      |
|         |                                     | PEC             |       |             |       |       |       |                    |       |      |
| S or Sr | 1                                   | 1 0 1 0 HID R=1 |       |             |       |       |       | A/N <sup>5,6</sup> |       |      |
|         |                                     |                 | Da    | ata         |       |       |       |                    | T=1   |      |
|         |                                     |                 |       |             |       |       |       |                    | T=1   |      |
|         | Data                                |                 |       |             |       |       |       |                    | T=1   |      |
|         |                                     | PEC             |       |             |       |       |       |                    |       |      |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The SPD5 Hub device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 4. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 5. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to PEC error parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity or PEC errors, the SPD5 Hub may eventually ACK. The PEC calculation by the Target device only includes device select code of the ACK response of the Repeat start operation. In other words, if there are more than one Repeat Start operation, the Target device includes device select code of only the last Repeat Start from the Host when it ACKs in PEC calculation and all other NACK

T=18,9

Sr10 or P



responses of the device select code of the Repeat Start are not included in PEC calculation.

- 6. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 7. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 8. Repeat Start or Repeat Start with 7'h7E.

The Host may optionally allow SPD5 Hub device to request IBI. For this case, the transactions to the SPD5 Hub device begin with the I3C Basic Host issuing a START condition followed by 7'h7E and then write bit. If SPD5 Hub device has a pending IBI, it transmits its 7-bit device select code followed by R=1. If SPD5 Hub device has no pending IBI, there is no action taken by SPD5 Hub. The Table 27 and Table 28 show the I3C Basic bus read command data packet with optional IBI header for PEC disabled and PEC enabled cases respectively. Note that in Table 28, PEC calculation (from Host to SPD5 Hub) does not include IBI header byte (7'h7E followed by W=0).

Bit 7 Bit 6 Bit 5 Bit 4 **Start** Bit 3 Bit 2 Bit 1 Bit 0 A/N/T Stop S 1 1 1 1 0 W=0 A1,3 1 1 1 0 1 HID W=0  $A^{2,3,4}$ Sr 0 MemReg Blk Addr [0] Address [5:0] Т 0 0 0 0 Blk Addr [4:1]5 Т 0 0 HID R=1 A/N<sup>6,7</sup> Sr 1 1 T=1 Data T=1 . . .

Table 27. Read Command Data Packet w/ IBI Header; PEC Disabled

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (Repeat Start).
- 2. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK) and Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- 3. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 4. The SPD5 Hub does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub ignores the entire packet until STOP or next Repeat Start operation.
- 5. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.

Data

- 6. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 7. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity errors, the SPD5 Hub may eventually ACK.
- 8. See Figure 11 to see how Host ends Target device operation.
- 9. For NVM read memory access (i.e. MemReg = '1'), when last byte is reached (1024 Byte) or for volatile memory access (i.e. MemReg = '0'), when last byte (i.e. MR255) is reached (extreme rare case), the Target device sends T = '0'. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 10. Repeat Start or Repeat Start with 7'h7E.

T=08

Sr9 or P



| Start | Bit 7                               | Bit 6   | Bit 5 | Bit 4 | Bit 3     | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop |  |  |  |
|-------|-------------------------------------|---------|-------|-------|-----------|-------|-------|-------|--------------------|------|--|--|--|
| S     | 1                                   | 1       | 1     | 1     | 1         | 1     | 0     | W=0   | A <sup>1,3</sup>   |      |  |  |  |
| Sr    | 1                                   | 1 0 1 0 |       |       |           | HID   |       | W=0   | A <sup>2,3,4</sup> |      |  |  |  |
|       | MemReg                              |         |       |       |           |       |       | Т     |                    |      |  |  |  |
|       | CMD R=1 Blk Addr [4:1] <sup>5</sup> |         |       |       |           |       |       | Т     |                    |      |  |  |  |
|       |                                     |         | PI    | EC    |           |       |       |       | Т                  |      |  |  |  |
| Sr    | 1                                   | 0       | 1     | 0     | 0 HID R=1 |       |       |       |                    |      |  |  |  |
|       |                                     |         | Da    | ata   |           |       |       |       | T=1                |      |  |  |  |
|       |                                     |         |       |       |           |       |       |       | T=1                |      |  |  |  |
|       |                                     |         | Da    | ata   |           |       |       |       | T=1                |      |  |  |  |
|       |                                     |         |       |       |           |       |       |       |                    |      |  |  |  |

Table 28. Read Command Data Packet w/ IBI Header; PEC Enabled

1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (Repeat Start).

PEC

- 2. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK) and See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (MemReg bit).
- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 4. The SPD5 Hub does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match its own device code. The SPD5 Hub ignores the entire packet until STOP or next Repeat Start operation.
- 5. The memory size of SPD5 Hub device is limited to 1024 Bytes. SPD5 Hub device ignores Blk Addr [4] bit.
- 6. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 7. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do Repeat Start as many times it may desire. If Target device NACKs due to PEC error or parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there was no parity or PEC error, the SPD5 Hub may eventually ACK. The PEC calculation by the Target device only includes device select code of the ACK response of the Repeat Start operation. If there are more than one Repeat Start operation, the Target device includes device select of only the last Repeat Start from the Host when it ACKs in PEC calculation and all other NACK responses of the device select code of the Repeat Start are not included in PEC calculation.
- 8. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 9. Repeat Start or Repeat Start with 7'h7E.

#### 7.11.3 Default Read Address Pointer Mode

This mode works the same exact way as explained in Section 7.9.3. Table 29 and Table 30 show the read command data packet for PEC function disabled and enabled respectively. When PEC function is enabled, *MR18*[1] sets the number of bytes that SPD5 Hub device sends out followed by the PEC calculation. If PEC is enabled, the Host must complete the burst length as indicated in *MR18*[1] register. In other words, the Host must not interrupt the burst length pre-maturely for default address pointer read operation. The default read address pointer mode is only applicable to volatile register space (i.e. MemReg = '0').

Table 29. Read Command Data Packet w/ Read Address Pointer Mode; PEC Disabled

| Start   | Bit 7 | Bit 6                   | Bit 5 | Bit 4 | Bit 3     | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop     |
|---------|-------|-------------------------|-------|-------|-----------|-------|-------|-------|-------|----------|
| S or Sr | 1     | 0                       | 1     | 0     | 0 HID R=1 |       |       |       |       |          |
|         |       | Data -                  |       |       |           |       |       |       |       |          |
|         |       |                         |       |       |           |       |       |       | T=1   |          |
|         |       | Data T=1 <sup>2,3</sup> |       |       |           |       |       |       |       | Sr⁴ or P |

<sup>1.</sup> The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.



- 2. See Figure 11 to see how Host ends Target device operation.
- 3. When last byte (i.e. MR255) is reached (extreme rare case), the Target device sends T = '0'. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 4. Repeat Start or Repeat Start with 7'h7E.

Table 30. Read Command Data Packet w/ Read Address Pointer Mode; PEC Enabled

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2            | Bit 1                | Bit 0 | A/N/T | Stop |
|---------|-------|-------|-------|-------|-------|------------------|----------------------|-------|-------|------|
| S or Sr | 1     | 0     | 1     | 0     |       | HID              |                      | R=1   | $A^1$ |      |
|         |       |       |       | Da    | ata   |                  |                      |       | T=1   |      |
|         |       |       |       |       |       |                  |                      |       | T=1   |      |
|         |       |       |       | Da    | ata   | T=1              |                      |       |       |      |
|         |       |       |       | PE    | EC    | T=0 <sup>2</sup> | Sr <sup>3</sup> or P |       |       |      |

- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 2. See Figure 12 to see how Target device ends the operation followed by STOP operation.
- 3. Repeat Start or Repeat Start with 7'h7E.

Table 31. Read CMD Data Packet w/ Read Address Pointer Mode and IBI Header; PEC Disabled

| Start | Bit 7 | Bit 6 | Bit 5 | Bit 4              | Bit 3                | Bit 2 | Bit 1 | Bit 0 | A/N/T            | Stop |
|-------|-------|-------|-------|--------------------|----------------------|-------|-------|-------|------------------|------|
| S     | 1     | 1     | 1     | 1                  | 1                    | 1     | 0     | W=0   | A <sup>1,2</sup> |      |
| Sr    | 1     | 0     | 1     | 0                  |                      | HID   |       | R=1   | A <sup>2,3</sup> |      |
|       |       |       |       | Da                 | ata                  |       |       |       | T=1              |      |
|       |       |       |       |                    |                      |       |       |       | T=1              |      |
|       |       |       |       | T=1 <sup>4,5</sup> | Sr <sup>6</sup> or P |       |       |       |                  |      |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (Repeat Start).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 3. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 4. See Figure 11 to see how Host ends Target device operation.
- 5. When last byte (i.e. MR255) is reached (extreme rare case), the Target device sends T = '0'. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 6. Repeat Start or Repeat Start with 7'h7E.

Table 32. Read CMD Data Packet w/ Read Address Pointer Mode and IBI Header; PEC Enabled

| Start | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2            | Bit 1 | Bit 0 | A/N/T            | Stop     |
|-------|-------|-------|-------|-------|-------|------------------|-------|-------|------------------|----------|
| S     | 1     | 1     | 1     | 1     | 1     | 1                | 0     | W=0   | A <sup>1,2</sup> |          |
| Sr    | 1     | 0     | 1     | 0     |       | A <sup>2,3</sup> |       |       |                  |          |
|       |       |       |       | T=1   |       |                  |       |       |                  |          |
|       |       |       |       |       |       |                  |       |       | T=1              |          |
|       |       |       |       | T=1   |       |                  |       |       |                  |          |
|       | PEC   |       |       |       |       |                  |       |       | T=0 <sup>4</sup> | Sr⁵ or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (Repeat Start).
- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 3. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 4. See Figure 12 to see how Target device ends the operation followed by STOP operation.
- 5. Repeat Start or Repeat Start with 7'h7E.



## 7.12 I3C Basic Target Protocol - Host to Local Device (Through SPD5 Hub Device)

## 7.12.1 Write Operation - Data Packet

Table 33 to Table 38 shows examples of write command data packet for different types of local devices behind the SPD5 Hub. These examples do not show the optional IBI header byte that Host may choose to use. All local devices behind SPD5 Hub device also support the IBI header byte similar to as shown in Table 23 and Table 24.

Table 33. Write Command Data Packet (e.g. TS); PEC Disabled

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3           | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop |  |  |
|---------|-------|-------|-------|--------|-----------------|-------|-------|-------|--------------------|------|--|--|
| S or Sr | 0     | 0     | 1     | 0      |                 | HID   |       | W=0   | A <sup>1,2,3</sup> |      |  |  |
|         |       |       |       | Addres | Address [7:0] T |       |       |       |                    |      |  |  |
|         |       |       |       | Da     | ata             |       |       |       | Т                  |      |  |  |
|         |       |       |       | Da     | ata             |       |       |       | Т                  |      |  |  |
|         |       |       |       |        | Т               |       |       |       |                    |      |  |  |
|         |       |       |       | Da     | Data T          |       |       |       |                    |      |  |  |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr; bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The TS device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.

Table 34. Write Command Data Packet (e.g. TS); PEC Enabled

| Start   | Bit 7 | Bit 6         | Bit 5 | Bit 4  | Bit 3    | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop |
|---------|-------|---------------|-------|--------|----------|-------|-------|-------|--------------------|------|
| S or Sr | 0     | 0             | 1     | 0      |          | HID   |       | W=0   | A <sup>1,2,3</sup> |      |
|         |       |               |       | Addres | ss [7:0] |       |       |       | Т                  |      |
|         |       | CMD W=0 0 0 0 |       |        |          |       |       | Т     |                    |      |
|         |       |               |       | Da     | ata      |       |       |       | Т                  |      |
|         |       |               |       |        |          |       |       |       | Т                  |      |
|         |       |               | Т     |        |          |       |       |       |                    |      |
|         |       | Data T PEC T  |       |        |          |       |       |       |                    |      |

- See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr; bit [7]).
- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The TS device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.



| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3           | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop |  |  |
|---------|-------|-------|-------|--------|-----------------|-------|-------|-------|--------------------|------|--|--|
| S or Sr | 1     | 0     | 0     | 1      |                 | HID   |       | W=0   | A <sup>1,2,3</sup> |      |  |  |
|         |       |       |       | Addres | Address [7:0] T |       |       |       |                    |      |  |  |
|         |       |       |       | Da     | ata             |       |       |       | Т                  |      |  |  |
|         |       |       |       | Da     | ata             |       |       |       | Т                  |      |  |  |
|         |       |       |       |        | Т               |       |       |       |                    |      |  |  |
|         |       |       |       | Da     | Data T          |       |       |       |                    |      |  |  |

- See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr; bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The PMIC device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The PMIC device ignores the entire packet until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.

Table 36. Write Command Data Packet (e.g. PMIC); PEC Enabled

| Start   | Bit 7 | Bit 6           | Bit 5 | Bit 4  | Bit 3           | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop |  |
|---------|-------|-----------------|-------|--------|-----------------|-------|-------|-------|--------------------|------|--|
| S or Sr | 1     | 0               | 0     | 1      |                 | HID   |       | W=0   | A <sup>1,2,3</sup> |      |  |
|         |       |                 |       | Addres | Address [7:0] T |       |       |       |                    |      |  |
|         |       | CMD W=0 0 0 0 0 |       |        |                 |       |       |       | Т                  |      |  |
|         |       |                 |       | Da     | ata             |       |       |       | Т                  |      |  |
|         |       |                 |       |        |                 |       |       |       | Т                  |      |  |
|         |       | Data T          |       |        |                 |       |       |       |                    |      |  |
|         |       | PEC T           |       |        |                 |       |       |       |                    |      |  |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr; bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The PMIC device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.

The RCD device requires valid stable input clock (DCK\_t, DCK\_c), Reset\_n and DCS\_n to allow any read or write access on its I3C Basic interface.



Table 37. Write Command Data Packet (e.g. RCD); PEC Disabled

| Start   | Bit 7 | Bit 6                  | Bit 5 | Bit 4      | Bit 3       | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop     |
|---------|-------|------------------------|-------|------------|-------------|-------|-------|-------|--------------------|----------|
| S or Sr | 1     | 0                      | 1     | 1          |             | HID   |       | W=0   | A <sup>1,2,3</sup> |          |
|         |       | Data (I3C Bus Command) |       |            |             |       |       |       |                    |          |
|         |       |                        |       | Data (Byte | Count=8)    | 1     |       |       | Т                  |          |
|         |       | Data (Reserved; 0x00)  |       |            |             |       |       |       |                    |          |
|         |       | Data (Dev/Channel Num) |       |            |             |       |       |       |                    |          |
|         |       |                        |       | ata (Page  | Num [7:0]   | )     |       |       | Т                  |          |
|         |       |                        | I     | Data (Reg  | Num [7:0]   | )     |       |       | Т                  |          |
|         |       |                        |       | ata (Wr D  | ata [31:24] | ])    |       |       | Т                  |          |
|         |       |                        |       | ata (Wr D  | ata [23:16] | ])    |       |       | Т                  |          |
|         |       | Data (Wr Data [15:8])  |       |            |             |       |       |       | Т                  |          |
|         |       | Data (Wr Data [7:0])   |       |            |             |       |       |       |                    | Sr⁴ or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Data, bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 3. The RCD device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The RCD device ignores the entire packet until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.

Table 38. Write Command Data Packet (e.g. RCD); PEC Enabled

| Start   | Bit 7 | Bit 6                  | Bit 5 | Bit 4       | Bit 3       | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop     |
|---------|-------|------------------------|-------|-------------|-------------|-------|-------|-------|--------------------|----------|
| S or Sr | 1     | 0                      | 1     | 1           |             | HID   |       | W=0   | A <sup>1,2,3</sup> |          |
|         |       |                        | Da    | ita (I3C Bu | s Commar    | nd)   |       |       | Т                  |          |
|         |       |                        |       | Data (Byte  | Count=8)    | ı     |       |       | Т                  |          |
|         |       | Data (Reserved; 0x00)  |       |             |             |       |       |       |                    |          |
|         |       | Data (Dev/Channel Num) |       |             |             |       |       |       | Т                  |          |
|         |       |                        |       | Data (Page  | Num [7:0]   | J)    |       |       | Т                  |          |
|         |       |                        | 1     | Data (Reg   | Num [7:0]   | )     |       |       | Т                  |          |
|         |       | Data (Wr Data [31:24]) |       |             |             |       |       | Т     |                    |          |
|         |       |                        |       | Data (Wr D  | ata [23:16] | ])    |       |       | Т                  |          |
|         |       | Data (Wr Data [15:8])  |       |             |             |       |       |       |                    |          |
|         |       | Data (Wr Data [7:0])   |       |             |             |       |       |       | Т                  |          |
|         |       |                        |       | Data (Pl    | EC [7:0])   |       |       |       | Т                  | Sr⁴ or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Data, bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 3. The RCD device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The RCD device ignores the entire packet until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.



#### 7.12.2 Read Operation - Data Packet

Table 39 to Table 44 shows examples of read command data packet for different types of local devices behind the SPD5 Hub. These examples do not show the optional IBI header byte that Host may choose to use. All local devices behind SPD5 Hub device also support the IBI header byte similar to as shown in Table 27 and Table 28.

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3    | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop                 |
|---------|-------|-------|-------|--------|----------|-------|-------|-------|--------------------|----------------------|
| S or Sr | 0     | 0     | 1     | 0      |          | HID   |       | W=0   | A <sup>1,2,3</sup> |                      |
|         |       |       |       | Addres | ss [7:0] | Т     |       |       |                    |                      |
| Sr      | 0     | 0     | 1     | 0      |          | HID   |       | R=1   | A/N <sup>4,5</sup> |                      |
|         | Data  |       |       |        |          |       |       |       | T=1                |                      |
|         |       |       |       |        |          |       |       |       | T=1                |                      |
|         | Data  |       |       |        |          |       |       |       | T=1 <sup>6,7</sup> | Sr <sup>8</sup> or P |

Table 39. Read Command Data Packet (e.g. TS); PEC Disabled

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr, bit [7]).
- The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The TS device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat Start operation.
- 4. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity errors, the device may eventually ACK.
- 5. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 6. See Figure 11 to see how Host ends Target device operation.
- 7. For volatile register access, when last byte (MR255) is reached (extreme rare case), the Target device sends T = '0'. See Figure 12 to see how Host ends Target device operation.
- 8. Repeat Start or Repeat Start with 7'h7E.

Table 40. Read Command Data Packet (e.g. TS); PEC Enabled

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3    | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop                 |
|---------|-------|-------|-------|--------|----------|-------|-------|-------|--------------------|----------------------|
| S or Sr | 0     | 0     | 1     | 0      |          | HID   |       | W=0   | A <sup>1,2,3</sup> |                      |
|         |       |       |       | Addres | ss [7:0] | Т     |       |       |                    |                      |
| Sr      | 0     | 0     | 1     | 0      | HID R=1  |       |       |       | A/N <sup>4,5</sup> |                      |
|         | Data  |       |       |        |          |       |       |       |                    |                      |
|         |       |       |       |        |          |       |       |       |                    |                      |
|         | Data  |       |       |        |          |       |       |       |                    |                      |
|         | PEC   |       |       |        |          |       |       |       |                    | Sr <sup>7</sup> or P |

- See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr, bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The TS device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat Start operation.
- 4. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to PEC error or parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity or PEC errors, the device may eventually ACK. The PEC calculation by the Target device only includes device select code of the ACK



response of the Repeat start operation. In other words, if there are more than one Repeat Start operation, the Target device includes device select of only the last Repeat Start from the Host when it ACKs in PEC calculation and all other NACK responses of the device select code of the Repeat Start are not included in PEC calculation.

- 5. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 6. See Figure 11 to see how Target device ends the operation followed by Host STOP operation.
- 7. Repeat Start or Repeat Start with 7'h7E.

Table 41. Read Command Data Packet (e.g. PMIC); PEC Disabled

| Start   | Bit 7         | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop                 |
|---------|---------------|-------|-------|-------|-------|-------|-------|-------|--------------------|----------------------|
| S or Sr | 1             | 0     | 0     | 1     | HID W |       |       |       | A <sup>1,2,3</sup> |                      |
|         | Address [7:0] |       |       |       |       |       |       |       | Т                  |                      |
| Sr      | 1             | 0     | 0     | 1     |       | HID   |       | R=1   | A/N <sup>4,5</sup> |                      |
|         | Data          |       |       |       |       |       |       |       |                    |                      |
|         |               |       |       |       |       |       |       |       |                    |                      |
|         | Data          |       |       |       |       |       |       |       | T=1 <sup>6,7</sup> | Sr <sup>8</sup> or P |

- See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr, bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The PMIC device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued
  by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat
  Start operation.
- 4. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity errors, the device may eventually ACK
- 5. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 6. See Figure 11 to see how Host ends Target device operation.
- 7. For volatile register access, when last byte is reached within the region (either Host region or DIMM Vendor region), it will continue to return the data but returned data is 0x00 if there is no valid password for DIMM vendor region or device vendor specific region. Once the address counter reaches R255, it resets to address R00 and it continues to return the data. Only Host can perform the STOP operation.
- 8. Repeat Start or Repeat Start with 7'h7E.

Table 42. Read Command Data Packet (e.g. PMIC); PEC Enabled

| Start   | Bit 7         | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2 | Bit 1 | Bit 0 | A/N/T              | Stop                 |
|---------|---------------|-------|-------|-------|---------|-------|-------|-------|--------------------|----------------------|
| S or Sr | 1             | 0     | 0     | 1     |         | HID   |       | W=0   | A <sup>1,2,3</sup> |                      |
|         | Address [7:0] |       |       |       |         |       |       | Т     |                    |                      |
| Sr      | 1             | 0     | 0     | 1     | HID R=1 |       |       |       | A/N <sup>4,5</sup> |                      |
|         | Data          |       |       |       |         |       |       |       |                    |                      |
|         |               |       |       |       |         |       |       |       |                    |                      |
|         | Data          |       |       |       |         |       |       |       |                    |                      |
|         | PEC           |       |       |       |         |       |       |       |                    | Sr <sup>7</sup> or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Addr, bit [7]).
- 2. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The PMIC device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The TS device ignores the entire packet until STOP or next Repeat Start operation.
- 4. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to PEC error or parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity or PEC errors, the



device may eventually ACK. The PEC calculation by the Target device only includes device select code of the ACK response of the Repeat start operation. In other words, if there are more than one Repeat Start operation, the Target device includes device select of only the last Repeat Start from the Host when it ACKs in PEC calculation and all other NACK responses of the device select code of the Repeat Start are not included in PEC calculation.

- 5. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 6. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 7. Repeat Start or Repeat Start with 7'h7E.

The RCD device requires valid stable input clock (DCK\_t, DCK\_c), Reset \_n and Chip Select input (DCS\_n) to allow any read or write access on its I3C Basic interface.

Table 43. Read Command Data Packet (e.g. RCD); PEC Disabled

| Start   | Bit 7                  | Bit 6 | Bit 5 | Bit 4       | Bit 3       | Bit 2 | Bit 1 | Bit 0              | A/N/T              | Stop                 |
|---------|------------------------|-------|-------|-------------|-------------|-------|-------|--------------------|--------------------|----------------------|
| S or Sr | 1                      | 0     | 1     | 1           |             | HID   |       | A <sup>1,2,3</sup> |                    |                      |
|         |                        |       | Da    | ata (I²C Bu | s Commar    | nd)   |       |                    | Т                  |                      |
|         |                        |       |       | Data (Byte  | Count=4)    | 1     |       |                    | Т                  |                      |
|         |                        |       |       | Data (Rese  | rved; 0x00  | ))    |       |                    | Т                  |                      |
|         |                        |       | Da    | ata (Dev/C  | hannel Nu   | m)    |       |                    | Т                  |                      |
|         |                        |       | Г     | Data (Page  | Num [7:0]   | ])    |       |                    | Т                  |                      |
|         |                        |       |       | Data (Reg   | Num [7:0]   | )     |       |                    | Т                  |                      |
| Sr      | 1                      | 0     | 1     | 1           |             | HID   |       | R=1                | A/N <sup>4,5</sup> |                      |
|         |                        |       |       | Data (By    | te Count)   |       |       |                    | T=1                |                      |
|         | Data (Status)          |       |       |             |             |       |       |                    |                    |                      |
|         | Data (Rd Data [31:24]) |       |       |             |             |       |       |                    |                    |                      |
|         | Data (Rd Data [23:16]) |       |       |             |             |       |       |                    |                    |                      |
|         | Data (Rd Data [15:8])  |       |       |             |             |       |       |                    |                    |                      |
|         |                        |       |       | Data (Rd    | Data [7:0]) |       |       |                    | T=0 <sup>6</sup>   | Sr <sup>7</sup> or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Data).
- 2. The RCD NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The RCD device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued
  by the Host does not match with its own device code. The RCD device ignores the entire packet until STOP or next Repeat
  Start operation.
- 4. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity errors, the device may eventually ACK
- See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 6. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 7. Repeat Start or Repeat Start with 7'h7E.



#### Table 44. Read Command Data Packet (e.g. RCD); PEC Disabled

| Start   | Bit 7                  | Bit 6 | Bit 5 | Bit 4       | Bit 3       | Bit 2 | Bit 1 | Bit 0              | A/N/T              | Stop                 |
|---------|------------------------|-------|-------|-------------|-------------|-------|-------|--------------------|--------------------|----------------------|
| S or Sr | 1                      | 0     | 1     | 1           |             | HID   |       | A <sup>1,2,3</sup> |                    |                      |
|         |                        |       | Da    | ata (I²C Bu | s Commar    | nd)   |       |                    | Т                  |                      |
|         |                        |       |       | Data (Byte  | Count=4)    | )     |       |                    | Т                  |                      |
|         |                        |       |       | ata (Rese   | rved; 0x00  | ))    |       |                    | Т                  |                      |
|         |                        |       | Da    | ata (Dev/C  | hannel Nu   | m)    |       |                    | Т                  |                      |
|         |                        |       |       | Data (Page  | Num [7:0]   | ])    |       |                    | Т                  |                      |
|         | Data (Reg Num [7:0])   |       |       |             |             |       |       |                    | Т                  |                      |
| Sr      | 1                      | 0     | 1     | 1           |             | HID   |       | R=1                | A/N <sup>4,5</sup> |                      |
|         |                        |       |       | Data (By    | te Count)   |       |       |                    | T=1                |                      |
|         |                        |       |       | Data (      | Status)     |       |       |                    | T=1                |                      |
|         | Data (Rd Data [31:24]) |       |       |             |             |       |       |                    | T=1                |                      |
|         | Data (Rd Data [23:16]) |       |       |             |             |       |       |                    |                    |                      |
|         | Data (Rd Data [15:8])  |       |       |             |             |       |       |                    |                    |                      |
|         |                        |       |       | Data (Rd    | Data [7:0]) |       |       |                    | T=1                |                      |
|         |                        |       |       | Data (Pl    | EC [7:0])   |       |       |                    | T=0 <sup>6</sup>   | Sr <sup>7</sup> or P |

- 1. See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation (1st bit of Data).
- 2. The RCD NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The RCD device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code
  issued by the Host does not match with its own device code. The RCD device ignores the entire packet until STOP or
  next Repeat Start operation.
- 4. If Target device NACKs during Repeat Start for any reason, the Host may re-try Repeat Start again. The Host can do the Repeat Start as many times it may desire. If Target device NACKs due to parity error in previous bytes, it will always NACK regardless of how many times the Host tries Repeat Start. If there were no parity or PEC errors, the device may eventually ACK. The PEC calculation by the Target device only includes device select code of the ACK response of the Repeat start operation. In other words, if there are more than one Repeat Start operation, the Target device includes device select of only the last Repeat Start from the Host when it ACKs in PEC calculation and all other NACK responses of the device select code of the Repeat Start are not included in PEC calculation.
- 5. See Figure 10 to see how the transition occurs from Host Push Pull Operation to Target Open Drain (ACK).
- 6. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.
- 7. Repeat Start or Repeat Start with 7'h7E.





Figure 8. Target Open Drain to Host Push Pull Hand Off Operation



Figure 9. Controller Open Drain (ACK) to Target Push Pull Hand Off Operation





Figure 10. Controller Push Pull to Target Open Drain Hand Off Operation





Figure 11. T = 1; Host Ends Read with Repeated START and STOP Waveform



Figure 12. T = 0; Target Ends Read; Host Generates STOP



### 7.13 I3C Basic Common Command Codes (CCC)

The I3C Basic specification lists large number of Common Command Codes (CCC). Not all CCC are required to be supported. The SPD5 Hub device NACKs for all unsupported CCC. The SPD5 Hub supports CCC as listed in Table 45 below.

The SPD5 Hub device requires STOP operation in between when switching from CCC operation to private device specific Write or Read or Default Read Address Pointer mode operation and vice versa. In other words, any CCC operation must be followed by STOP operation before continuing to any device specific Write or Read or Default Read Address Pointer mode operation. Similarly, any device specific Write or Read or Default Read Address Pointer mode operation must be followed by STOP operation before continuing to any CCC operation. The SPD5 Hub device also requires STOP operation between any direct CCC to broadcast CCC.

The SPD5 Hub device does allow Repeat Start operation between any direct CCC to any other direct CCC or between any broadcast CCC to any other broadcast CCC or between any private Write or Read or Default Read Address Pointer mode operation to any other private Write or Read or Default Read Address Pointer mode operation.

CCC is an I3C concept by definition, and shall always conform to I3C SDR timings, irrespective of whether the device has switched from I<sup>2</sup>C mode or not.

Prior to dynamic address assignment (SETAASA/P), the Target device(s) may drive the ACK/NACK past the Open Drain SCL rising but before the next SCL falling transition, as a longer overlap in Open Drain is harmless. Immediately after the Open Drain ACK (upon the next SCL falling edge), the bus should transition to Push Pull mode (though still at 1 Mhz) as described in the MIPI *I3C Basic Specification V1.0, Section 5.1.2.3 "Handoff from Address ACK to SDR Controller Write Data" and Figure 32 "I3C Data Transfer - ACK by Target"*.

For additional details on how to handle the ACK transition, please refer to the MIPI I3C Basic Specification V1.0, Section 5.1.2.3.1 "Transition from Address ACK to SDR Controller Write Data".

| CCC                                 | Mode                 | Code  | Description                                                                     |  |  |  |  |
|-------------------------------------|----------------------|-------|---------------------------------------------------------------------------------|--|--|--|--|
| ENEC                                | Broadcast            | 0x00  | Finally Franklistensints                                                        |  |  |  |  |
| ENEC                                | Direct               | 0x80  | Enable Event Interrupts                                                         |  |  |  |  |
| DISEC                               | DISEC Broadcast 0x01 |       | Disable Front Interrupts                                                        |  |  |  |  |
| DISEC                               | Direct               | 0x81  | Disable Event Interrupts                                                        |  |  |  |  |
| RSTDAA                              | Broadcast            | 0x06  | Put the device in I <sup>2</sup> C Mode (aka: Reset Dynamic Address Assignment) |  |  |  |  |
| SETAASA                             | OFTAACA Burdent 0:00 |       | Put the device in I3C Basic Mode (aka: Set All Addresses to Static              |  |  |  |  |
| SETAASA                             | Broadcast            | 0x29  | Address)                                                                        |  |  |  |  |
| GETSTATUS                           | Direct               | 0x90  | Get Device Status                                                               |  |  |  |  |
| DEVCAP <sup>1</sup>                 | Direct               | 0xE0  | Get Device Capability                                                           |  |  |  |  |
| SETHID <sup>1</sup>                 | Broadcast            | 0x61  | SPD5 Hub updates 3-bit HID field, updates 'T' bit with updated parity           |  |  |  |  |
| SETHID. Bloadcast 0x61              |                      | 0.001 | calculation for all devices behind Hub and stops 3-bit HID translation.         |  |  |  |  |
| DEVCTRL <sup>1</sup> Broadcast 0x62 |                      |       | Configure SPD5 Hub and all devices behind Hub                                   |  |  |  |  |

Table 45. SPD5 Hub CCC Support Requirement

<sup>1.</sup> JEDEC specific CCC.



#### **7.13.1 ENEC CCC**

The ENEC CCC is only supported after device is put in I3C Basic mode. In I2C mode, it is illegal for Host to issue this CCC. When ENEC CCC is registered by the SPD5 Hub, it updates *MR27*[4] = '1' and it takes in effect at the next Start operation (i.e. after STOP condition). Table 46 to Table 49 shows an example of a single ENEC CCC. Table 50 shows the encoding definition for ENEC CCC.

If PEC function is enabled, the PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3                | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|---------|-------|-------|-------|-------|----------------------|-------|-------|-------|-------|------|
| S or Sr | 1     | 1     | 1     | 1     | 1                    | 1     | 0     | W=0   | $A^1$ |      |
|         |       |       | Т     |       |                      |       |       |       |       |      |
|         |       |       | ENINT | Т     | Sr <sup>2</sup> or P |       |       |       |       |      |

Table 46. ENEC CCC - Broadcast

2. Repeat Start or Repeat Start with 7'h7E.

Table 47. ENEC CCC - Broadcast w/ PEC

| Start   | Bit 7 | Bit 6 | Bit 5          | Bit 4                | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|---------|-------|-------|----------------|----------------------|-------|-------|-------|-------|-------|------|
| S or Sr | 1     | 1     | A <sup>1</sup> |                      |       |       |       |       |       |      |
|         |       |       | Т              |                      |       |       |       |       |       |      |
|         |       |       | Т              |                      |       |       |       |       |       |      |
|         |       |       | Т              | Sr <sup>2</sup> or P |       |       |       |       |       |      |

The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.

2. Repeat Start or Repeat Start with 7'h7E.

Table 48. ENEC CCC - Direct

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4      | Bit 3 | Bit 2 | Bit 1                | Bit 0 | A/N/T            | Stop |
|---------|-------|-------|-------|------------|-------|-------|----------------------|-------|------------------|------|
| S or Sr | 1     | 1     | $A^1$ |            |       |       |                      |       |                  |      |
|         |       |       | T     |            |       |       |                      |       |                  |      |
| Sr      |       |       |       | DevID[6:0] | ]     |       |                      | W=0   | A <sup>1,2</sup> |      |
|         |       |       |       |            | ENINT | Т     | Sr <sup>3</sup> or P |       |                  |      |

<sup>1.</sup> The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.

3. Repeat Start or Repeat Start with 7'h7E.

<sup>1.</sup> The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.

The SPD5 Hub device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.



#### Table 49. ENEC CCC - Direct w/ PEC

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4                | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T            | Stop |
|---------|-------|-------|-------|----------------------|-------|-------|-------|-------|------------------|------|
| S or Sr | 1     | 1     | 1     | 1                    | 1     | 1     | 0     | W=0   | A <sup>1</sup>   |      |
|         |       |       | Т     |                      |       |       |       |       |                  |      |
|         |       |       | Т     |                      |       |       |       |       |                  |      |
| Sr      |       |       |       | DevID[6:0]           | ]     |       |       | W=0   | A <sup>1,2</sup> |      |
|         |       |       | Т     |                      |       |       |       |       |                  |      |
|         |       |       | Т     | Sr <sup>3</sup> or P |       |       |       |       |                  |      |

- 1. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The SPD5 Hub device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 3. Repeat Start or Repeat Start with 7'h7E.

### Table 50. ENEC CCC Byte Encoding

| Bit     | Encoding                 | Notes                                                         |  |  |  |  |
|---------|--------------------------|---------------------------------------------------------------|--|--|--|--|
| ENIINIT | 0 = No Action            | It is illegal for Host to issue ENEC CCC with ENINT bit = '0' |  |  |  |  |
| ENINT   | 1 = Enable IBI Interrupt | It is illegal for most to issue ENEC CCC with ENINT bit - 0   |  |  |  |  |

### **7.13.2 DISEC CCC**

The DISEC CCC is only supported after device is put in I3C Basic mode. In  $I^2C$  mode, it is illegal for Host to issue this CCC. When DISEC CCC is registered by the SPD5 Hub, it updates MR27[4] = 0 and it takes in effect at the next Start operation (i.e. after STOP condition). Table 51 to Table 54 shows an example of a single DISEC CCC. Table 55 shows the encoding definition for DISEC CCC.

If PEC function is enabled, the PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.

Table 51. DISEC CCC - Broadcast

| Start   | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3                | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|---------|-------|-------|--------|-------|----------------------|-------|-------|-------|-------|------|
| S or Sr | 1     | 1     | 1      | 1     | 1                    | 1     | 0     | W=0   | $A^1$ |      |
|         |       |       | Т      |       |                      |       |       |       |       |      |
|         |       |       | DISINT | Т     | Sr <sup>2</sup> or P |       |       |       |       |      |

- The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 2. Repeat Start or Repeat Start with 7'h7E.

Table 52. DISEC CCC - Broadcast w/ PEC

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4                | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|---------|-------|-------|-------|----------------------|-------|-------|-------|-------|-------|------|
| S or Sr | 1     | 1     | $A^1$ |                      |       |       |       |       |       |      |
|         |       |       | T     |                      |       |       |       |       |       |      |
|         |       |       | Т     |                      |       |       |       |       |       |      |
|         |       |       | Т     | Sr <sup>2</sup> or P |       |       |       |       |       |      |

- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- Repeat Start or Repeat Start with 7'h7E.



#### Table 53. DISEC CCC - Direct

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2            | Bit 1                | Bit 0 | A/N/T | Stop |
|---------|-------|-------|-------|-------|-------|------------------|----------------------|-------|-------|------|
| S or Sr | 1     | 1     | W=0   | $A^1$ |       |                  |                      |       |       |      |
|         |       |       |       | Т     |       |                  |                      |       |       |      |
| Sr      |       |       |       |       | W=0   | A <sup>1,2</sup> |                      |       |       |      |
|         |       |       |       |       | ENINT | Т                | Sr <sup>3</sup> or P |       |       |      |

- 1. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- The SPD5 Hub device does not check for parity error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 3. Repeat Start or Repeat Start with 7'h7E.

#### Table 54. DISEC CCC - Direct w/ PEC

| Start   | Bit 7             | Bit 6 | Bit 5  | Bit 4                | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T            | Stop |
|---------|-------------------|-------|--------|----------------------|-------|-------|-------|-------|------------------|------|
| S or Sr | 1 1 1 1 1 1 0 W=0 |       |        |                      |       |       |       |       |                  |      |
|         |                   |       | Т      |                      |       |       |       |       |                  |      |
|         |                   |       | Т      |                      |       |       |       |       |                  |      |
| Sr      |                   |       |        | DevID[6:0            | ]     |       |       | W=0   | A <sup>1,2</sup> |      |
|         |                   |       | DISINT | Т                    |       |       |       |       |                  |      |
|         |                   |       | Т      | Sr <sup>3</sup> or P |       |       |       |       |                  |      |

- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 2. The SPD5 Hub device does not check for parity or PEC error in subsequent bytes when it determines 7-bit device select code issued by the Host does not match with its own device code. The SPD5 Hub device ignores the entire packet until STOP or next Repeat Start operation.
- 3. Repeat Start or Repeat Start with 7'h7E.

### Table 55. DISEC CCC Byte Encoding

| Bit     | Encoding                  | Notes                                                            |
|---------|---------------------------|------------------------------------------------------------------|
| DICINIT | 0 = No Action             | It is illegal for Lloot to issue DISEC CCC with DISINT hit = '0' |
| DISINT  | 1 = Disable IBI Interrupt | It is illegal for Host to issue DISEC CCC with DISINT bit = '0'  |

### 7.13.3 RSTDAA CCC

The RSTDAA CCC is only supported after device is put in I3C Basic mode. In I2C mode, this CCC is ignored. When RSTDAA CCC is registered by the SPD5 Hub, it updates MR18[5] = '0' and it takes in effect at the next Start operation (i.e. after STOP condition). Further it disables IBI and PEC function (*MR27*[4] = '0', *MR18*[7] = '0' respectively) and clears parity function (MR18[6] = '0'). Table 56 to Table 57 shows an example of a single RSTDAA CCC.

If PEC function is enabled, the PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.



#### Table 56. RSTDAA CCC - Broadcast

| Start   | Bit 7 | Bit 6 | Bit 5                | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|---------|-------|-------|----------------------|-------|-------|-------|-------|-------|----------------|------|
| S or Sr | 1     | 1     | 1                    | 1     | 1     | 1     | 0     | W=0   | A <sup>1</sup> |      |
|         |       | Т     | Sr <sup>2</sup> or P |       |       |       |       |       |                |      |

- The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 2. Repeat Start or Repeat Start with 7'h7E.

Table 57. RSTDAA CCC - Broadcast w/ PEC

| Start   | Bit 7             | Bit 6 | Bit 5 | Bit 4                | Bit 3 | Bit 2 | Bit 1 | Bit 0          | A/N/T | Stop |
|---------|-------------------|-------|-------|----------------------|-------|-------|-------|----------------|-------|------|
| S or Sr | 1 1 1 1 1 1 0 W=0 |       |       |                      |       |       |       | A <sup>1</sup> |       |      |
|         |                   |       | Т     |                      |       |       |       |                |       |      |
|         |                   |       | Т     | Sr <sup>2</sup> or P |       |       |       |                |       |      |

- The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 2. Repeat Start or Repeat Start with 7'h7E.

#### 7.13.4 SETAASA CCC

The SETAASA CCC is only supported when device is in I<sup>2</sup>C mode; however, it still follows I3C SDR timings compliant to CCC definitions. In I<sup>2</sup>C mode, when the Host issues this CCC, to guarantee that this CCC is registered by the device without any error, the Host shall limit the maximum speed operation for this CCC to 1 MHz. In I3C Basic mode, this CCC is ignored. When SETAASA CCC is registered by the SPD5 Hub, it updates MR18[5] = '1'and it takes in effect at the next Start operation (i.e. after STOP condition). Table 58 shows an example of a single SETAASA CCC.

SETAASA CCC does not support PEC function as device is in I<sup>2</sup>C mode and there is no PEC function in I<sup>2</sup>C mode.

Table 58. SETAASA CCC - Broadcast

| Start   | Bit 7            | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|---------|------------------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| S or Sr | 1                | 1     | 1     | 1     | 1     | 1     | 0     | W=0   | Α     |      |
|         | 0x29 (Broadcast) |       |       |       |       |       |       |       | Т     | Р    |

### 7.13.5 GETSTATUS CCC

The GETSTATUS CCC is supported in I3C Basic mode. In I2C mode, this CCC is ignored (i.e. it is not executed internally and GETSTATUS CCC code is not acknowledged and Host must do STOP operation). Table 59 to Table 60 shows an example of a single GETSTATUS CCC. Table 61 shows the encoding definition for GETSTATUS CCC.

If PEC function is enabled, the PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.

When the SPD5 Hub device responds to GETSTATUS CCC, after it completes the response, the PEC\_Err, P\_Err and Pending Interrupt Bits [3:0] do not automatically get cleared. The Host must explicitly clear the appropriate status register through Clear command by writing '1' to corresponding register or by issuing Global Clear command. Once the SPD5 Hub device clears the appropriate status register, the PEC\_Err, P\_err and Pending Interrupt Bits [3:0] get cleared.



After Host issues Clear command, if the condition is still present, the device will again set the appropriate status register, sets the IBI status register to '1' and Pending Interrupt Bits [3:0] to '0001'.

### Table 59. GETSTATUS CCC - Direct

| Start   | Bit 7                 | Bit 6 | Bit 5 | Bit 4      | Bit 3 | Bit 2  | Bit 1 | Bit 0                | A/N/T          | Stop |
|---------|-----------------------|-------|-------|------------|-------|--------|-------|----------------------|----------------|------|
| S or Sr | 1                     | 1     | 1     | 1          | 1     | 1      | 0     | W=0                  | A <sup>1</sup> |      |
|         |                       |       | Т     |            |       |        |       |                      |                |      |
| Sr      |                       |       |       | DevID[6:0] | ]     |        |       | R=1                  | A <sup>1</sup> |      |
|         | PEC_Err 0 0 0 0 0 0 0 |       |       |            |       |        |       |                      |                |      |
|         | 0                     | 0     | P_Err | 0          |       | Pendin | T=0   | Sr <sup>2</sup> or P |                |      |

The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.

2. Repeat Start or Repeat Start with 7'h7E.

### Table 60. GETSTATUS CCC - Direct w/ PEC1

| Start   | Bit 7                         | Bit 6 | Bit 5 | Bit 4      | Bit 3                | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|---------|-------------------------------|-------|-------|------------|----------------------|-------|-------|-------|----------------|------|
| S or Sr | 1                             | 1     | 1     | 1          | 1                    | 1     | 0     | W=0   | $A^2$          |      |
|         |                               |       |       | Т          |                      |       |       |       |                |      |
|         |                               |       |       | Т          |                      |       |       |       |                |      |
| Sr      |                               |       |       | DevID[6:0] | ]                    |       |       | R=1   | A <sup>1</sup> |      |
|         | PEC_Err                       | 0     | 0     | 0          | 0                    | 0     | 0     | 0     | T=1            |      |
|         | 0 0 P_Err 0 Pending Interrupt |       |       |            |                      |       |       |       |                |      |
|         |                               |       |       | T=0        | Sr <sup>3</sup> or P |       |       |       |                |      |

<sup>1.</sup> GETSTATUS CCC with PEC check is only supported in I3C Basic mode.

3. Repeat Start or Repeat Start with 7'h7E.

Table 61. GETSTATUS CCC Byte Encoding

| Bit       | Encoding                                  | Notes                                                              |  |  |  |  |
|-----------|-------------------------------------------|--------------------------------------------------------------------|--|--|--|--|
| DEC Err   | 0 = No Error                              | This register is cleared when Host issues clear command to         |  |  |  |  |
| PEC_Err   | 1 = PEC Error occurred                    | MR20[1] for PEC error.                                             |  |  |  |  |
| D. Cer    | 0 = No Error                              | This register is cleared when Host issues clear command to         |  |  |  |  |
| P_Err     | 1 = Protocol Error; Parity Error occurred | MR20[0] for Parity error.                                          |  |  |  |  |
| Donding   | 0000 = No Pending Interrupt               | This register is cleared when Host issues clear command to any     |  |  |  |  |
| Pending   | 0001 = Pending Interrupt                  | appropriate device status register that causes IBI status register |  |  |  |  |
| Interrupt | All other encodings are reserved          | to get cleared.                                                    |  |  |  |  |

The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.



#### 7.13.6 DEVCAP CCC

The DEVCAP CCC is only supported after device is put in I3C Basic mode. In I2C mode, it is illegal for Host to issue this CCC. Table 62 to Table 63 shows an example of a single DEVCAP CCC. Table 64 shows the encoding definition for DEVCAP CCC.

If PEC function is enabled, the PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.

| Table ( | 62. D | <b>EVCAP</b> | CCC - | <b>Direct</b> |
|---------|-------|--------------|-------|---------------|
|---------|-------|--------------|-------|---------------|

| Start   | Bit 7 | Bit 6                                 | Bit 5 | Bit 4      | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|---------|-------|---------------------------------------|-------|------------|-------|-------|-------|-------|----------------|------|
| S or Sr | 1     | 1                                     | 1     | 1          | 1     | 1     | 0     | W=0   | A <sup>1</sup> |      |
|         |       |                                       | Т     |            |       |       |       |       |                |      |
| Sr      |       |                                       |       | DevID[6:0] |       |       |       | R=1   | A <sup>1</sup> |      |
|         |       |                                       | T=1   |            |       |       |       |       |                |      |
|         |       | LSB (Each bit defines capability) T=0 |       |            |       |       |       |       |                |      |

The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.

2. Repeat Start or Repeat Start with 7'h7E.

Table 63. DEVCAP CCC - Direct w/ PEC

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4      | Bit 3      | Bit 2     | Bit 1 | Bit 0 | A/N/T          | Stop                 |
|---------|-------|-------|-------|------------|------------|-----------|-------|-------|----------------|----------------------|
| S or Sr | 1     | 1     | 1     | 1          | 1          | 1         | 0     | W=0   | A <sup>1</sup> |                      |
|         |       |       | Т     |            |            |           |       |       |                |                      |
|         |       |       | Т     |            |            |           |       |       |                |                      |
| Sr      |       |       |       | DevID[6:0] |            |           |       | R=1   | A <sup>1</sup> |                      |
|         |       |       | MSB   | (Each bit  | defines ca | pability) |       |       | T=1            |                      |
|         |       |       | T=1   |            |            |           |       |       |                |                      |
|         |       | PEC   |       |            |            |           |       |       |                | Sr <sup>3</sup> or P |

The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.

2. Repeat Start or Repeat Start with 7'h7E.

Table 64. DEVCAP CCC Byte Encoding

| Bit      | Encoding                             | Notes                      |
|----------|--------------------------------------|----------------------------|
| MSB[7]   | RFU                                  | Coded as '0'               |
| MSB[6]   | RFU                                  | Coded as '0'               |
| MSB[5]   | RFU                                  | Coded as '0'               |
| MSB[4]   | RFU                                  | Coded as '0'               |
| MSB[3]   | RFU                                  | Coded as '0'               |
| MCDIOI   | 0 = No Support for Timer based Reset | SPD5 Hub hard codes to '1' |
| MSB[2]   | 1 = Supports Timer based Reset       | SPD3 Hub Hald codes to 1   |
| MSB[1:0] | RFU                                  | Coded as '0'               |
| LSB[7:0] | RFU                                  | Coded as '0'               |



#### 7.13.7 SETHID CCC

The SETHID CCC is supported only when device is in I<sup>2</sup>C mode. In I<sup>2</sup>C mode, when the Host issues this CCC, to guarantee that this CCC is registered by the device without any error, the Host shall limit the maximum speed operation for this CCC to 1 MHz. In I3C Basic mode, it is illegal for Host to issue this CCC. When SETHID CCC is registered by the SPD5 Hub, it stops 3-bit HID translation. Table 65 shows an example of a single SETHID CCC. The Host must send all '0' in the data byte followed by 'T' bit. The SPD5 Hub device forwards bits [7:4, 0] to local devices behind the SPD5 Hub as it receives from the Host. The SPD5 Hub device substitutes its own 3-bit HID code in bits [3:1] and forwards it to the local devices behind the SPD5 Hub. The SPD5 Hub device also re-calculates the parity information and forwards the updated parity information in 'T' bit. As the device is in I<sup>2</sup>C mode when SETHID CCC is issued, the PEC function is not supported.

The Host may issue SETHID CCC more than one time.

| Start   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| S or Sr | 1     | 1     | 1     | 1     | 1     | 1     | 0     | W=0   | Α     |      |
|         |       |       | Т     |       |       |       |       |       |       |      |
|         | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | Т     | Р    |

Table 65. SETHID CCC - Broadcast

#### 7.13.8 DEVCTRL CCC

On a typical I3C Basic bus there can be up to 120 devices. For DDR5 DIMM application environment, there are up to 8 SPD5 Hub devices and behind each SPD5 Hub device, there are 4 local Target devices totaling up to 40 or more devices on I3C Basic bus. For certain operation such as enable or disable functions that are common to all devices (i.e. Packet Error Check), the Host must go through one device at a time which takes significant amount of time at initial power up. Further, it requires additional complexity on the Host because it must speak different protocol depending on how it may access the device until all devices are configured identically.

To help expedite this configuration operation and to simplify the Host complexity, the device supports the DEVCTRL CCC. The DEVCTRL CCC is supported either in I<sup>2</sup>C mode or I3C Basic mode of operation. In I<sup>2</sup>C mode, when the Host issues this CCC, to guarantee that this CCC is registered by the device without any error, the Host shall limit the maximum speed operation for this CCC to 1 MHz. Table 66 to Table 67 shows an example of a single DEVCTRL CCC.

If PEC function is enabled, the PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.

The Host shall pay attention to DEVCTRL CCC. The DEVCTRL CCC is limited to SPD5 Hub device's volatile register space only and should not be used for SPD5 Hub's NVM operation. If DEVCTRL CCC is used to access device specific registers (e.g. RegMod = '1'), the Host shall still follow any device specific register restriction. For example, if device specific register requires STOP operation for device to take in the effect of the setting, the Host must also use STOP operation when using DEVCTRL CCC to access device specific register.

In I2C mode, DEVCTRL CCC must be limited to 1 byte addressing mode for SPD5 Hub device (i.e. MR11[3] = '0').



#### Table 66. DEVCTRL CCC - Broadcast

| Start   | Bit 7               | Bit 6     | Bit 5 | Bit 4    | Bit 3      | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop                 |
|---------|---------------------|-----------|-------|----------|------------|-------|-------|-------|----------------|----------------------|
| S or Sr | 1                   | 1         | 1     | 1        | 1          | 1     | 0     | W=0   | A <sup>1</sup> |                      |
|         |                     |           |       | Т        |            |       |       |       |                |                      |
|         | Ad                  | ddrMask[2 | Т     |          |            |       |       |       |                |                      |
|         | DevID[6:0] 0        |           |       |          |            |       |       |       |                |                      |
|         |                     |           |       | Byte 0 D | ata Payloa | ad    |       |       | Т              |                      |
|         |                     |           |       | Byte 1 D | ata Payloa | ad    |       |       | Т              |                      |
|         | Byte 2 Data Payload |           |       |          |            |       |       |       |                |                      |
|         | Byte 3 Data Payload |           |       |          |            |       |       |       |                | Sr <sup>3</sup> or P |

- 1. The SPD5 Hub NACKs if there is a parity error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 2. An exception is made for DEVCTRL CCC where device does report a parity error when it determines 7-bit device select code issued by the Host does not match with its own device code. If 7-bit device select code does not match but if parity is still valid, the device does not check for parity error in subsequent bytes; ignores the entire packet and waits until STOP or next Repeat Start operation.
- 3. Repeat Start or Repeat Start with 7'h7E.

Table 67. DEVCTRL CCC - Broadcast w/ PEC1

| Start   | Bit 7 | Bit 6     | Bit 5          | Bit 4    | Bit 3      | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop                 |
|---------|-------|-----------|----------------|----------|------------|-------|-------|-------|-------|----------------------|
| S or Sr | 1     | 1         | 1              | 1        | 1          | 1     | 0     | W=0   | $A^2$ |                      |
|         |       |           | Т              |          |            |       |       |       |       |                      |
|         | Ad    | ddrMask[2 | Т              |          |            |       |       |       |       |                      |
|         |       |           | T <sup>3</sup> |          |            |       |       |       |       |                      |
|         |       |           |                | Byte 0 D | ata Payloa | ad    |       |       | Т     |                      |
|         |       |           |                | Byte 1 D | ata Payloa | ad    |       |       | Т     |                      |
|         |       |           | Т              |          |            |       |       |       |       |                      |
|         |       |           | Т              |          |            |       |       |       |       |                      |
|         | PEC   |           |                |          |            |       |       |       |       | Sr <sup>4</sup> or P |

- 1. DEVCTRL CCC with PEC check is only supported in I3C Basic mode.
- 2. The SPD5 Hub NACKs if there is a parity or PEC error in a previous transaction when Host performs consecutive transactions with Repeat Start.
- 3. An exception is made for DEVCTRL CCC where device does report a parity error when it determines 7-bit device select code issued by the Host does not match with its own device code. The device does not check for PEC as all subsequent bytes are discarded due to parity error. If 7-bit device select code does not match but if parity is still valid, the device does not check for parity error in subsequent bytes; ignores the entire packet and waits until STOP or next Repeat Start operation.
- 4. Repeat Start or Repeat Start with 7'h7E.



## **Table 68. DEVCTRL CCC Command Definition**

| Parameter        | Definition                                                                                               |
|------------------|----------------------------------------------------------------------------------------------------------|
|                  | Broadcast, Unicast or Multicast Command Selection                                                        |
|                  | 000 = Unicast Command; SPD5 Hub device responds if DevID[6:0] field matches with SPD5 Hub                |
|                  | device's own 7-bit address (4-bit LID + 3-bit HID)                                                       |
| AddrMask[2:0]    | 011 = Multicast Command; SPD5 Hub device and possible other device respond if DevID[6:3] field           |
|                  | matches with SPD5 Hub device's own 4-bit LID address                                                     |
|                  | 111 = Broadcast Command; All devices respond to this command                                             |
|                  | All other encodings are reserved.                                                                        |
|                  | Only applicable if RegMod = '0'                                                                          |
|                  | Identifies the starting Byte (Byte 0 or Byte 1 or Byte 2 or Byte 3) for DEVCTRL CCC. Host can start at   |
|                  | any Byte (from Byte 0 to Byte 3) and has continuous access to next byte until STOP operation. If Byte    |
| StartOffset[1:0] | 3 is reached, the Host is responsible for applying STOP operation.                                       |
| StartOllset[1.0] | 00 = Byte 0                                                                                              |
|                  | 01 = Byte 1                                                                                              |
|                  | 10 = Byte 2                                                                                              |
|                  | 11 = Byte 3                                                                                              |
|                  | Only applicable if RegMod = '0' and PEC function is enabled.                                             |
|                  | Identifies the burst length just for this DEVCTRL CCC. The device uses the setting in this field to know |
|                  | when the PEC byte is expected after the data bytes.                                                      |
| PEC BL[1:0]      | 00 = 1 Byte                                                                                              |
|                  | 01 = 2 Byte                                                                                              |
|                  | 10 = 3 Byte                                                                                              |
|                  | 11 = 4 Byte                                                                                              |
|                  | Identifies if DEVCTRL is going to be used for General Registers as identified in Byte 0 to Byte 3 or     |
|                  | device specific address offset register.                                                                 |
| RegMod           | 0 = Access to General Registers in Byte 0 to Byte 3 (i.e. StartOffset[1:0] = Valid)                      |
| rtegiviou        | 1 = Device Specific Offset Address (i.e. StartOffset[1:0] and PECBL[1:0] is a don't care and does not    |
|                  | apply). The Host shall NOT use RegMod = '1' with Broadcast Command if there are different types of       |
|                  | devices on the I3C Basic bus.                                                                            |
|                  | Identifies 7-bit device address. Device responds to DEVCTRL CCC data packet depending on                 |
|                  | AddrMask[2:0].                                                                                           |
| DevID[6:0]       | If AddrMask[2:0] = '111', DevID[6:0] is a don't care and device always responds.                         |
| D011D[0.0]       | If AddrMask[2:0] = '000', DevID[6:0] must match for device to respond.                                   |
|                  | If AddrMask[2:0] = '011', DevID[6:3] must match for device to respond. DevID[2:0] is don't care.         |
|                  | For any other codes for AddrMask[2:0], the device always NACKs.                                          |



### Table 69. DEVCTRL CCC Data Payload Definition

| Byte # | Bit#  | Function              | Definition                                       | Comment                                  |
|--------|-------|-----------------------|--------------------------------------------------|------------------------------------------|
|        | [7]   | PEC Enable            | 0 = Disable                                      | <i>MR18</i> [7] is updated               |
|        | [7]   | FEO Ellable           | 1 = Enable                                       | With ro[r] is updated                    |
|        | [6]   | Parity Disable        |                                                  | MD49[6] is undeted                       |
| Duto 0 | [6]   | Panty Disable         | 1 = Enable                                       | MR18[6] is updated                       |
| Byte 0 | [5:2] | RFU                   | RFU                                              |                                          |
|        | [4]   | RSVD                  | 0 = RSVD                                         | SDD5 Hub davias always ignores this bit  |
|        | [1]   | KOVD                  | 1 = RSVD                                         | SPD5 Hub device always ignores this bit. |
|        | [0]   | RFU                   | RFU                                              |                                          |
|        | [7:4] | RFU                   | RFU                                              |                                          |
| Duto 1 | [2]   | Global and IBI Clear  | 0 = No Action                                    | MP27[7] is undated                       |
| Byte 1 | [3]   | Global allu ibi Cleal | 1 = Clear All Event and pending IBI <sup>1</sup> | MR27[7] is updated.                      |
|        | [2:0] | RFU                   | RFU                                              |                                          |
| Byte 2 | [7:0] | RFU                   | RFU                                              |                                          |
| Byte 3 | [7:0] | RFU                   | RFU                                              |                                          |

After Target device clears the event, the device can still have certain registers set to '1' if the event is still present in which case, the device will generate an IBI again at the next opportunity.

### DEVCTRL CCC Examples - RegMod = '0'

Table 70 shows an example of DEVCTRL CCC data packet. It assumes that all devices on the bus are already in I3C Basic mode with PEC function disabled and parity function enabled. In this example, the Host uses DEVCTRL CCC as Multicast command. Host sends Multicast command to all devices with 4-bit LID code of '1001' on I3C Basic bus to do VR Enable followed by all devices with 4-bit LID code of '0110' to disable parity function. The Host sends AddrMask = '011' to indicate Multicast command with DevID[6:3] match; StartOffset = '00' to indicate starting Byte 0 and RegMod = '0' to indicate general register. Upon receiving this command, all devices with DevID[6:3] that matches to '1001' will do the VR Enable command and DevID[6:3] that matches to '0110' with disable the parity function.

Table 70. DEVCTRL CCC Example - Multicast Command to '1001' and '0110' Devices

| Start | Bit 7       | Bit 6      | Bit 5 | Bit 4   | Bit 3      | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|-------|-------------|------------|-------|---------|------------|-------|-------|-------|----------------|------|
| S     | 1           | 1          | 1     | 1       | 1          | 1     | 0     | W=0   | A <sup>1</sup> |      |
|       |             |            |       | 0x62 (E | Broadcast) | )     |       |       | Т              |      |
|       |             | 011        |       | 0       | 0          | 0     | 0     | 0     | Т              |      |
|       |             | 1001 000 0 |       |         |            |       |       |       | Т              |      |
|       |             |            |       | 000     | 0 0010     |       |       |       | Т              |      |
| Sr    | 1           | 1          | 1     | 1       | 1          | 1     | 0     | W=0   | A <sup>1</sup> |      |
|       |             |            |       | 0x62 (I | Broadcast) | )     |       |       | Т              |      |
|       | 011 00 00 0 |            |       |         |            |       |       | Т     |                |      |
|       | 0110 000 0  |            |       |         |            |       |       | 0     | Т              |      |
|       |             | 0100 0000  |       |         |            |       |       |       |                | Р    |

<sup>1.</sup> See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation.

Table 71 shows an example of DEVCTRL CCC data packet. It assumes that all devices on the bus are already in I3C Basic mode with PEC function disabled and parity function enabled. In this example, the Host uses DEVCTRL CCC as Broadcast



command to enable PEC function. The Host sends AddrMask = '111' to indicate Broadcast command; StartOffset = '00' to indicate starting Byte 0 and RegMod = '0' to indicate general register. Upon receiving this command, all devices will enable PEC function.

Table 71. DEVCTRL CCC Example - Broadcast Command to all Devices

| Start | Bit 7      | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|-------|------------|-------|-------|-------|-------|-------|-------|-------|----------------|------|
| S     | 1          | 1     | 1     | 1     | 1     | 1     | 0     | W=0   | A <sup>1</sup> |      |
|       |            |       | Т     |       |       |       |       |       |                |      |
|       |            | 111   |       | 0     | 0     | 0     | 0     | 0     | Т              |      |
|       | 0000 000 0 |       |       |       |       |       |       |       |                |      |
|       | 1000 0000  |       |       |       |       |       |       |       |                | Р    |

<sup>1.</sup> See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation.

Table 72 shows an example of DEVCTRL CCC data packet. It assumes that all devices on the bus are already in I3C Basic mode with PEC function disabled and parity function enabled. In this example, the Host uses DEVCTRL CCC as Unitcast command to enable VR on DIMM5. The Host sends AddrMask = '000' to indicate Unicast command; StartOffset = '00' to indicate starting Byte 0 and RegMod = '0' to indicate general register. Upon receiving this command, PMIC on DIMM5 will enable its regulator.

Table 72. DEVCTRL CCC Example - Unicast Command to PMIC on DIMM5

| Start | Bit 7       | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|-------|-------------|-------|-------|-------|-------|-------|-------|-------|----------------|------|
| S     | 1           | 1     | 1     | 1     | 1     | 1     | 0     | W=0   | A <sup>1</sup> |      |
|       |             |       | Т     |       |       |       |       |       |                |      |
|       | 000 00 00 0 |       |       |       |       |       |       |       | Т              |      |
|       | 1001 101 0  |       |       |       |       |       |       |       |                |      |
|       | 0000 0010   |       |       |       |       |       |       |       |                | Р    |

<sup>1.</sup> See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation.

### DEVCTRL CCC Examples - RegMod = '1'

Table 73 shows an example of DEVCTRL CCC data packet for the purpose of configuring device specific address offset register. It assumes that all devices on the bus are already in I3C Basic mode with PEC function enabled and parity function enabled. In this example, the Host sends Multicast command to all devices with 4-bit LID code of '0010' on the I3C Basic bus to write to address offset of 0x1C and 0x1D with data 0xFF and 0x55 respectively followed by all devices with 4-bit LID of '1001' on the I3C Basic bus to write to address offset of 0x15 with data 0x78.

The PEC calculation starts with Start or Repeat Start operation but does not include 7'h7E with W=0 byte in PEC calculation.



Table 73. DEVCTRL CCC Example - Multicast Command to '0010' and '1001' Devices

| Start | Bit 7 | Bit 6 | Bit 5 | Bit 4    | Bit 3      | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|-------|-------|-------|-------|----------|------------|-------|-------|-------|----------------|------|
| S     | 1     | 1     | 1     | 1        | 1          | 1     | 0     | W=0   | A <sup>1</sup> |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       | 011   |       | 0        | 0          | 0     | 00    | 1     | Т              |      |
|       |       |       |       | 0010 000 |            |       |       | 0     | Т              |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | ı        | PEC        |       |       |       | Т              |      |
| Sr    | 1     | 1     | 1     | 1        | 1          | 1     | 0     | W=0   | A <sup>1</sup> |      |
|       |       |       |       | 0x62 (I  | Broadcast) | )     |       |       | Т              |      |
|       |       | 011   |       | 0        | 0          | 0     | 00    | 1     | Т              |      |
|       |       |       |       | 1001 000 |            |       |       | 0     | Т              |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | Т        |            |       |       |       |                |      |
|       |       |       |       | I        | PEC        |       |       |       | Т              | Р    |

Table 74 shows an example of DEVCTRL CCC data packet for the purpose of configuring device specific address offset register. It assumes that all devices on the bus are already in I3C Basic mode with PEC function disabled and parity function enabled. In this example, the Host sends Multicast command to all devices with 4-bit LID code of '1001' on the I3C Basic bus to write to address offset of 0x13 with data 0xFF and it continues to write data 0x01 to the next address.

Table 74. DEVCTRL CCC Example - Multicast Command to '1001' Devices

| Start | Bit 7            | Bit 6            | Bit 5 | Bit 4      | Bit 3      | Bit 2    | Bit 1 | Bit 0 | A/N/T          | Stop |
|-------|------------------|------------------|-------|------------|------------|----------|-------|-------|----------------|------|
| S     | 1                | 1                | 1     | 1          | 1          | 1        | 0     | W=0   | A <sup>1</sup> |      |
|       |                  | 0x62 (Broadcast) |       |            |            |          |       |       |                |      |
|       | 011 00 00 1      |                  |       |            |            |          |       | Т     |                |      |
|       |                  |                  |       | 1001 000   |            |          |       | 0     | Т              |      |
|       |                  |                  | 000   | 1 0011 (ad | dress offs | et 0x13) |       |       | Т              |      |
|       | 1111 1111 (data) |                  |       |            |            |          |       |       | Т              |      |
|       | 0000 0001 (data) |                  |       |            |            |          |       |       | Т              | Р    |

<sup>1.</sup> See Figure 8 to see how the transition occurs from Target Open Drain (ACK) to Host Push Pull Operation.



# 8 In Band Interrupt (IBI)

In I<sup>2</sup>C mode, in band interrupt function is not supported. Only I3C Basic mode supports in band interrupt function.

## 8.1 Enabling and Disabling In Band Event Interrupt Function

By default, all interrupt sources are disabled (i.e. set to '0'). The Host may enable following interrupts in the SPD5 Hub device. Once enabled, the SPD5 Hub device sends an IBI when that event occurs.

- 1. Error Interrupt Enable in MR27[4]:
- When MR27[4] = '1', the device sends the IBI at next available opportunity when any of the register bit in MR52[7:5, 1:0] is set to '1' and sets MR48[7] = '1' and updates Pending Interrupt Bits [3:0] = '0001' for GETSTATUS CCC.
- When MR27[4] = '0', the device does not send the IBI regardless of the register bit status in MR52[7:5, 1:0].
   However, the device does set MR48[7] = '1' and updates Pending Interrupt Bits [3:0] = '0001' for GETSTATUS CCC.
- 2. Temperature Sensor Interrupt Enable in MR27[3:0]: The Host can set any combination of register bits to '1':
- When any of the register bits in MR27[3:0] = '1' and if MR27[4] = '1', the device sends the IBI at next available opportunity when the corresponding register bit in MR51[3:0] is set to '1' and sets MR48[7] = '1' and updates Pending Interrupt Bits [3:0] = '0001' for GETSTATUS CCC.
- When any of the register bits in *MR27*[3:0] = '0' or *MR27*[4] = '0', the device does not send the interrupt regardless of the corresponding register bit status in *MR51*[3:0]. However, the device does set *MR48*[7] = '1' and updates Pending Interrupt Bits [3:0] = '0001' for GETSTATUS CCC if any of the bits in *MR27*[3:0] = '1' and *MR27*[4] = '0'.

### 8.2 Mechanics of Interrupt Generation - SPD5 Hub Device

Event interrupts may be generated by the SPD5 Hub device if IBI is enabled. When there is a pending interrupt (i.e. *MR48*[7] = '1 and *MR27*[4] = '1'), the SPD5 Hub requests an interrupt after detecting START condition by transmitting its 7-bit binary address (LID bits followed by HID bits) followed by R/W = '1' on the SDA bus serially (synchronized by SCL falling transitions).

If the SPD5 Hub detects no START condition but if the Host to the SPD5 Hub device bus (HSDA and HSCL) has been inactive (no edges seen) for  $t_{AVAL}$  period, then the SPD5 Hub device may assert HSDA low by  $t_{IBI\_ISSUE}$  time to request an interrupt. When the SPD5 Hub device requests an interrupt, the Host toggles the HSCL. The SPD5 Hub device transmits its 7-bit binary address, '1010' followed by 3 HID bits, and then sets the R/W bit = '1'. When the SPD5 Hub device requests an interrupt, the Host may take one of the two actions below.

• The Host sends ACK on 9<sup>th</sup> bit to accept the interrupt request. At this point, if the SPD5 Hub confirms that it has won the arbitration, the SPD5 Hub device transmits the IBI payload as shown in Table 75 and Table 76 for PEC disabled and PEC enabled configuration, respectively. See Figure 13. It just shows only first two data bits of the MDB byte to illustrate the timing. The interrupt payload contains MDB followed by 8-bit register contents of *MR51* and *MR52* in order. The Host then issues the STOP command. Note the timing waveform in Figure 13. The Host then accepts the IBI payload if it sends an ACK on 9<sup>th</sup> bit to accept the interrupt request. The Host can interrupt the IBI payload at 'T'. If Host stops the IBI payload at 'T' bit in the middle of payload, the SPD5 Hub device retains the IBI status flag *MR48*[7] = '1' and Pending Interrupt Bits [3:0] internally and waits for the next opportunity to request an interrupt. If the SPD5 Hub device successfully transmits the entire

 $T=0^{2}$ 

Ρ



- IBI payload, it then clears IBI status flag MR48[7] = '0' and Pending Interrupt Bits [3:0] = '0000' on its own and does not request for an IBI again unless there is another different event occurs; for another same event, the device does not request for an IBI.
- The Host sends NACK on the 9<sup>th</sup> bit as shown in Figure 14 followed by a STOP command. In this case, the SPD5 Hub device does not transmit the IBI payload and waits for the next opportunity to request an interrupt. At this point, though Host sent a NACK, it does have a knowledge of which SPD5 Hub device sent the IBI request. The SPD5 Hub retains the IBI status flag MR48[7] = '1' and Pending Interrupt Bits [3:0] = '0001'.

| Start | Bit 7 | Bit 6 | Bit 5 | Bit 4     | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T          | Stop |
|-------|-------|-------|-------|-----------|-------|-------|-------|-------|----------------|------|
| S     | 1     | 0     | 1     | 0         |       | HID   |       | R=1   | A <sup>1</sup> |      |
|       |       |       | MDB   | 0B = 0x00 |       |       |       |       |                |      |
|       |       | T=1   |       |           |       |       |       |       |                |      |

Table 75. Hub IBI Payload Packet; PEC is Disabled

- 1. See Figure 8. Target Open Drain to Host Push Pull Hand Off Operation
- 2. to see how the transition occurs from Host Open Drain (ACK) to Target Push Pull Operation (1st bit of MDB, bit [7]).

MR52 [7:0]

3. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.

Table 76. Hub IBI Payload Packet; PEC is Enabled

| Start | Bit 7      | Bit 6      | Bit 5 | Bit 4       | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T | Stop |
|-------|------------|------------|-------|-------------|-------|-------|-------|-------|-------|------|
| S     | 1          | 0          | 1     | 1 0 HID R=1 |       |       |       |       |       |      |
|       |            | T=1        |       |             |       |       |       |       |       |      |
|       |            | MR51 [7:0] |       |             |       |       |       |       |       |      |
|       | MR52 [7:0] |            |       |             |       |       |       |       |       |      |
|       | PEC        |            |       |             |       |       |       |       |       | Р    |

- 1. See Figure 8. Target Open Drain to Host Push Pull Hand Off Operation
- 2. to see how the transition occurs from Host Open Drain (ACK) to Target Push Pull Operation (1st bit of MDB, bit [7]).
- 3. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.



Figure 13. SPD5 Hub Interrupt; Host Ack Followed by SPD5 Hub Device IBI Payload





Figure 14. SPD5 Hub Interrupt; Host NACK followed by STOP

### 8.3 Mechanics of Interrupt Generation - Local Target Device

Event interrupts may be generated by the local device if IBI is enabled. When there is a pending interrupt in any local device and if IBI is enabled, the local device requests an interrupt after detecting START condition by transmitting its 7-bit binary address (LID bits followed by HID bits) followed by R/W = '1' on the SDA bus serially (synchronized by SCL falling transitions).

If the local device detects no START condition but if the Host to the local Target device (through the SPD5 Hub device) bus (LSDA and LSCL) has been inactive (no edges seen) for t<sub>AVAL</sub> period, then any local device may assert LSDA low by t<sub>IBI\_ISSUE</sub> time to request an interrupt. When the local device requests an interrupt, the SPD5 Hub device propagates the LSDA to HSDA to Host. The Host toggles the HSCL. The local device transmits its 7-bit binary address (LID bits followed by HID bits) followed by R/W bit = '1' to the SPD5 Hub device. This is shown in Figure 15 top waveform.

The SPD5 Hub device forwards LID bits it receives from the local device to the Host. The SPD5 Hub device substitutes its own HID code in place of the HID bits it receives from the local device and sends to the Host if Host has not issued SETHID CCC previously. This is shown in Figure 15 middle waveform. The SPD5 Hub device forwards HID bits it receives from the local device to the Host if Host has issued SETHID CCC previously. This is shown in Figure 15 bottom waveform. The SPD5 Hub device forwards the R/W bit = '1' to the Host.

When the local device requests an interrupt, the Host may take one of the two actions below.

- The Host sends ACK on 9th bit to accept the interrupt request. At this point, if the local device confirms that it has won the arbitration, the local device transmits the IBI payload as shown in Table 77 and Table 78 for PEC disabled and PEC enabled configuration respectively. See Figure 15. It just shows only first two data bits of MDB byte to illustrate the timing. The interrupt payload contains MDB followed by appropriate Target device error register contents in order. The Host then issues the STOP command. Note the timing waveform in Figure 15. The Host then accepts the IBI payload if it sends an ACK on 9th bit to accept the interrupt request. The Host can interrupt the IBI payload at 'T' bit. If Host stops the IBI payload at 'T' bit in the middle of payload, the local device retains the IBI status flag and Pending Interrupt Bits [3:0] internally and waits for the next opportunity to request an interrupt. If the local device successfully transmits the entire IBI payload, it then clears IBI status flag and Pending Interrupt Bits [3:0] = '0000' on its own and does not request for an IBI again unless there is another different event occurs; for another same event, the device does not request for an IBI
- The Host sends NACK on the 9th bit as shown in Figure 16 followed by a STOP command. In this case, the



local device does not transmit the IBI payload and waits for the next opportunity to request an interrupt. At this point, though Host sent a NACK, it does have a knowledge of which local device sent the IBI request. The local device retains the IBI status flag and Pending Interrupt Bits [3:0] = '0001'.

Table 77. Target Device IBI Payload Packet; PEC is Disabled

| Start | Bit 7                  | Bit 6       | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0            | A/N/T          | Stop |
|-------|------------------------|-------------|-------|-------|-------|-------|-------|------------------|----------------|------|
| S     |                        | LID HID R=1 |       |       |       |       |       |                  | A <sup>1</sup> |      |
|       | MDB = 0x00             |             |       |       |       |       |       |                  | T=1            |      |
|       | First Error Code Byte  |             |       |       |       |       |       |                  | T=1            |      |
|       | Second Error Code Byte |             |       |       |       |       |       |                  | T=1            |      |
|       |                        |             |       |       |       |       |       | T=0 <sup>2</sup> | Р              |      |

- 1. See Figure 8. Target Open Drain to Host Push Pull Hand Off Operation
- 2. to see how the transition occurs from Host Open Drain (ACK) to Target Push Pull Operation (1st bit of MDB, bit [7]).
- 3. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.

Table 78. Target Device IBI Payload Packet; PEC is Enabled

| Start | Bit 7                  | Bit 6      | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | A/N/T            | Stop |
|-------|------------------------|------------|-------|-------|-------|-------|-------|-------|------------------|------|
| S     |                        | LID        |       |       |       | HID   |       | R=1   | A <sup>1</sup>   |      |
|       |                        | MDB = 0x00 |       |       |       |       |       |       |                  |      |
|       | First Error Code Byte  |            |       |       |       |       |       |       |                  |      |
|       | Second Error Code Byte |            |       |       |       |       |       |       |                  |      |
|       |                        |            |       |       |       |       |       |       |                  |      |
|       | PEC                    |            |       |       |       |       |       |       | T=0 <sup>2</sup> | Р    |

- 1. See Figure 8. Target Open Drain to Host Push Pull Hand Off Operation
- 2. to see how the transition occurs from Host Open Drain (ACK) to Target Push Pull Operation (1st bit of MDB, bit [7]).
- 3. See Figure 12 to see how Target device ends the operation followed by Host STOP operation.





Figure 15. Local Device Interrupt, Host Ack followed by Target Device IBI Payload





Figure 16. Local Device Interrupt; Host NACK followed by STOP

## 8.4 Interrupt Arbitration; SETHIDD CCC is Not Issued by Host

As there are multiple local Target devices behind the SPD5 Hub and there are multiple SPD5 Hub devices on I3C Basic bus, multiple devices may request an interrupt when the I3C Basic bus is inactive for t<sub>AVAL</sub> period. Arbitration process is required.

## 8.4.1 Interrupt Arbitration - Among SPD5 Hub Devices

This section explains the interrupt arbitration among the SPD5 Hub devices only. There are up to 8 SPD5 Hub devices on the I3C Basic bus.

As all SPD5 Hub devices have the same 4-bit LID code of '1010', the arbitration is always won by the lower HID code. For example, if one SPD5 Hub device has HID code of '000' and other SPD5 Hub device has a HID code



of '011', through the arbitration process, the HID code of '000' wins. The SPD5 Hub device with a HID code of '011 must release the bus and wait for next opportunity to request an interrupt. Table 79 shows the arbitration priority based on the HID code for the SPD5 Hub device.

Table 79. Interrupt Arbitration - Among SPD5 Hub Devices

| Hub Device LID Code | Hub Device HID Code | Arbitration Priority |
|---------------------|---------------------|----------------------|
| 1010                | 000                 | 1                    |
| 1010                | 001                 | 2                    |
| 1010                | 010                 | 3                    |
| 1010                | 011                 | 4                    |
| 1010                | 100                 | 5                    |
| 1010                | 101                 | 6                    |
| 1010                | 110                 | 7                    |
| 1010                | 111                 | 8                    |

### 8.4.2 Interrupt Arbitration - Among Local Target Devices behind one SPD5 Hub Devices

This section explains the interrupt arbitration among the local devices only behind the SPD5 Hub. There are up to 13 local devices behind the SPD5 Hub.

As all local Target devices behind the SPD5 Hub devices have the same 3-bit HID code, hence the arbitration is always won by the 4-bit LID code. For example, if one local Target device has LID code of '1001' and other local Target device has a LID code of '0010', through the arbitration process, the LID code of '0010' wins. The local device with a LID code of '1001' must release the bus and wait for next opportunity to request an interrupt. Table 80 shows the arbitration priority based on the LID code for the local devices. The Green color cells in Table 80 are the likely devices that will be on a standard DDR5 RDIMM or DDR5 LRDIMM.

During the interrupt arbitration phase, the SPD5 Hub device forwards the winning 4-bit LID code one digit at a time that it receives from the local Target devices to the Host.

The SPD5 Hub device discards the 3-bit '111' HID code received from the local Target device. Instead the SPD5 Hub device forwards its own unique 3-bit HID code one digit at a time to the Host. As a result, the Host can identify the winning device based on the 4-bit LID code (Local Target device) and 3-bit HID code (the DIMM). Also, when the SPD5 Hub device substitutes its own unique 3-bit HID code to the Host, its own receiver will see that at the input and it compares each 3 bits one at a time as it if the Host sent those 3 bits. If there is a match, the SPD5 Hub device forwards '1' to the local device interface and if there is a mismatch, the SPD5 Hub device forwards '0' to the local device interface. Because the local Target device sends '111' as its 3 bit HID code, the local device knows that it won the arbitration.



**Table 80. Interrupt Arbitration - Among Local Target Devices** 

| Device  | Target Device LID Code | Target Device HID Code | Arbitration Priority |
|---------|------------------------|------------------------|----------------------|
| N/A     | 0000                   | N/A                    | N/A                  |
| RFU     | 0001                   | 111                    | 1                    |
| TS0     | 0010                   | 111                    | 2                    |
| RFU     | 0011                   | 111                    | 3                    |
| RFU     | 0100                   | 111                    | 4                    |
| RFU     | 0101                   | 111                    | 5                    |
| TS1     | 0110                   | 111                    | 6                    |
| RFU     | 0111                   | 111                    | 7                    |
| PMIC1   | 1000                   | 111                    | 8                    |
| PMIC0   | 1001                   | 111                    | 9                    |
| SPD Hub | 1010                   | HID                    | N/A                  |
| RCD     | 1011                   | 111                    | 10                   |
| PMIC2   | 1100                   | 111                    | 11                   |
| RFU     | 1101                   | 111                    | 12                   |
| RFU     | 1110                   | 111                    | 13                   |
| N/A     | 1111                   | N/A                    | N/A                  |

### 8.4.3 Interrupt Arbitration - Between SPD5 Hub and Local Target Devices behind the Hub

This section explains the interrupt arbitration among the SPD5 Hub device and all local devices behind that SPD5 Hub. There are up to 13 local devices behind each SPD5 Hub.

As the SPD5 Hub device LID code of '1010', any local Target devices with a lower LID code always wins the arbitration process as shown in Table 80. The local Target devices with a higher LID code than '1010', the SPD5 Hub device wins the arbitration process. As an example, for a typical DDR5 RDIMM/LRDIMM, the RCD always has the lowest priority for winning the interrupt arbitration.

### 8.4.4 Interrupt Arbitration - Among Local Target Devices behind Different SPD5 Hub Devices

This section explains the interrupt arbitration among the SPD5 Hub devices and all local devices behind any SPD5 Hub devices. There are up to 8 SPD5 Hub devices on the I3C bus and up to 13 local devices behind each SPD5 Hub.

The arbitration process is hybrid of Section 8.4.1to Section 8.4.3. The device with the lowest 4 bit LID code across all local Target devices and across all SPD5 Hub devices always wins the arbitration process. The HID code for that lowest LID code represents the SPD5 Hub device code.

Table 81 shows four examples. In each example, the Target LID code column represents local Target device behind Hub which has HID code value of '111'; the Hub HID code column represents the SPD5 Hub device which has LID code of '1010' followed by its own unique HID code; the winning device column represent the final winner among all devices (either SPD Hub device or local Target devices) during the arbitration phase.

#### Example 1:

There are total 5 devices (4 local Target devices and 1 Hub device) that are requesting an interrupt. These 5 devices are shown in the RED color text. The devices that are in the Black color text are not requesting an interrupt.



The winning device is the local device LID code of '0010' and HID code of '111'. This is because the LID code of '0010' is the lowest among three other local Target device code and its HID code is '111'.

#### Example 2:

There are total 4 devices (2 local Target devices and 2 Hub devices) that are requesting an interrupt. These 4 devices are shown in the RED color text. The devices that are in the Black color text are not requesting an interrupt. The winning device is the local device LID code of '1001' and HID code of '100'. This is because the LID code of '1001' is the lowest among one other local Target device code and its HID code is '100'.

#### Example 3:

There are total of 3 devices (2 local Target devices and 1 Hub device) that are requesting an interrupt. These 3 devices are shown in the RED color text. The devices that are in Black color text are not requesting an interrupt. The wining device is the Hub device on DIMM0 with LID code of '1010' and HID code of '000'. This is because LID code '1010' is lower than two other local Target device code and its HID code is '000'.

## Example 4:

There are total of 2 devices (2 local Target devices) that are requesting an interrupt. These 2 devices are shown in RED color text. The devices that are in Black color text are not requesting an interrupt. This example is unique as two identical Target devices across two different DIMM devices are requesting an interrupt. The winning device is the local Target device on DIMM 0 with LID code of '0010' and DIMM 0 HID code of '000'. This is because DIMM0 HID code '000' is lower than DIMM2 HID code of '010'. See Section 8.4.2.



Table 81. Interrupt Arbitration - Among Local Target and SPD5 Hub Devices

| E                     | Example 1 Example 2 |                   |                       | Example 3          |                   |                       | Example 4          |                   |                       |                    |                   |
|-----------------------|---------------------|-------------------|-----------------------|--------------------|-------------------|-----------------------|--------------------|-------------------|-----------------------|--------------------|-------------------|
| Target<br>LID<br>Code | Hub<br>HID<br>Code  | Winning<br>Device | Target<br>LID<br>Code | Hub<br>HID<br>Code | Winning<br>Device | Target<br>LID<br>Code | Hub<br>HID<br>Code | Winning<br>Device | Target<br>LID<br>Code | Hub<br>HID<br>Code | Winning<br>Device |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 000                 |                   | 0110                  | 000                |                   | 0110                  | 000                | 1010              | 0110                  | 000                | 0010              |
| 1001                  | 000                 |                   | 1001                  | 000                |                   | 1001                  | 000                | 000               | 1001                  | 000                | 000               |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 001                 |                   | 0110                  | 001                |                   | 0110                  | 001                |                   | 0110                  | 001                |                   |
| 1001                  | 001                 |                   | 1001                  | 001                |                   | 1001                  | 001                |                   | 1001                  | 001                |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 010                 |                   | 0110                  | 010                |                   | 0110                  | 010                |                   | 0110                  | 010                |                   |
| 1001                  | 010                 |                   | 1001                  | 010                |                   | 1001                  | 010                |                   | 1001                  | 010                |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 011                 |                   | 0110                  | 011                |                   | 0110                  | 011                |                   | 0110                  | 011                |                   |
| 1001                  | 011                 |                   | 1001                  |                    |                   | 1001                  |                    |                   | 1001                  |                    |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 100                 |                   | 0110 100              | 1001               | 0110              | 100                   |                    | 0110              | 100                   |                    |                   |
| 1001                  | 100                 |                   | 1001                  | 100                | 100               | 1001                  | 100                |                   | 1001                  | 100                |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 101                 |                   | 0110                  | 101                |                   | 0110                  | 101                |                   | 0110                  | 101                |                   |
| 1001                  | 101                 |                   | 1001                  | 101                |                   | 1001                  | 101                |                   | 1001                  | 101                |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     |                   | 0010                  |                    |                   | 0010                  |                    |                   | 0010                  |                    |                   |
| 0110                  | 110                 |                   | 0110                  | 110                |                   | 0110                  | 110                |                   | 0110                  | 110                |                   |
| 1001                  | 110                 | 1001              | 110                   |                    | 1001              | '''                   |                    | 1001              | '''                   |                    |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |
| 0010                  |                     | 0010              |                       |                    | 0010              |                       | 0010               |                   |                       |                    |                   |
| 0110                  | 111                 | 0010              | 0110                  | 111                |                   | 0110                  | 111                | 0110              | 111                   |                    |                   |
| 1001                  |                     | 111               | 1001                  |                    |                   | 1001                  |                    |                   | 1001                  |                    |                   |
| 1011                  |                     |                   | 1011                  |                    |                   | 1011                  |                    |                   | 1011                  |                    |                   |

## 8.4.5 Interrupt Arbitration - Between Host and Any SPD5 Hub or Local Target Devices

When the bus is idle for  $t_{AVAL}$  time, any SPD5 Hub device or any local device behind the Hub can request an interrupt by pulling the SDA bus low.

In an uncommon but possible scenario would be that at the exact same time as when the SPD5 Hub or local



Target devices are requesting an interrupt, the Host is starting an operation to the Hub or local Target devices. When this happens, Host also gets involved in the arbitration process along with the Hub or the local Target devices. During the arbitration phase, there will be always only one winning device and it could be either the Hub or the local Target device or the Host.

If the Host wins during the arbitration phase, it continues with normal operation. The losing Hub or local Target device waits for next opportunity to send an interrupt.

If the Host loses during the arbitration phase, it must let go of the bus. When the Host loses during the arbitration, the Host must let the Hub or local Target device finish sending its 4-bit LID code followed by 3-bit HID code followed by R/W = '1'. At this point, during the 9<sup>th</sup> bit, the Host has two options to take the action as noted below:

- Host sends an ACK to accept the interrupt and hence accepts the IBI payload from the winning SDP5 Hub
  or local Target device. After the IBI payload, the Host issues STOP operation.
- Host sends an NACK followed by STOP operation.

In a rare but still possible scenario would be that at the exact same time as when the Hub or local Target device is requesting an interrupt, the Host is starting an operation to that same exact Hub or local Target device. When this happens, neither Host nor the Hub or local Target device knows it is a winner until the 8<sup>th</sup> bit and Host always wins. This is because, the Hub or local Target device sends R=1 (8<sup>th</sup> bit) during the interrupt. The Host sets W=0 (8<sup>th</sup> bit) during the operation. As a result, the Host wins and the Hub or local Target device must let go of the bus and wait for the next opportunity to send an interrupt. This is shown as example 3 in Table 82.

Table 82 shows three examples. In each example, the Target LID code column represents local Target device behind Hub which has HID code value of '111'; the Hub HID code column represents the SPD5 Hub device which has LID code of '1010' followed by its own unique HID code; the winning device column represents the final winner among all devices (either Host or SPD5 Hub device or local Target devices) during the arbitration phase. In example 1, there are total of 5 devices (1 Hub device and 4 local Target devices) are requesting an interrupt at

exactly same time as when the Host is starting an operation to hub device on DIMM 3 (1010 011). The winning device is local Target device '0010 111' because it has the lower 4-bit LID code.

In example 2, there are total of 4 devices (2 Hub devices 2 local Target devices) are requesting an interrupt at exactly same time as when the Host is requesting an operation to the local Target device on DIMM5 (0110 101). The Host is the winner because its intended target device has the lower 4-bit LID code than devices that are requesting an interrupt.

In example 3, there is one 1 hub device on DIMM 2 is requesting an interrupt at exactly the same time as when Host is requesting an operation to the same exact Hub device on DIMM2. In this case, the Host is the winner because the 8-bit will be driven low by the Host (W=0) while the Hub device drives it high (R=1) during the interrupt. In an extreme rare but still possible scenario would be that at the exact same time as when the Hub or local Target device is requesting an interrupt, the Host is requesting a read operation with default read address pointer mode to the same exact Hub or local Target device. When this happens, there is no winning device. This is the only time there is no winning device. This is because, the Hub or local Target device sends R=1 (8<sup>th</sup> bit) during the interrupt and Host also sends R=1 for read request with default read address pointer mode. As a result, there is no winner because all devices, i.e. the Host or the Hub or the local Target devices, are waiting for other device to ACK. In this case, no devices will ACK. Since there is no ACK by any device, the Host must time out and repeats the read request with Repeat Start. When it repeats the read request with Repeat Start, the Hub or local Target device does not send an interrupt because of Repeat Start.



Table 82. Interrupt Arbitration - Between Host and Local Target and SPD5 Hub Devices

|        | Example 1        |      |         | Example 2 |        |      |          | Example 3 |           |      |           |      |     |  |  |      |     |  |
|--------|------------------|------|---------|-----------|--------|------|----------|-----------|-----------|------|-----------|------|-----|--|--|------|-----|--|
| Host   | Target           | Hub  | Winning | Host      | Target | Hub  | Winning  | Host      | Target    | Hub  | Winning   |      |     |  |  |      |     |  |
| Target | LID              | HID  | Device  | Target    | LID    | HID  | Device   | Target    | LID       | HID  | Device    |      |     |  |  |      |     |  |
| Device | Code             | Code | Device  | Device    | Code   | Code | Device   | Device    | Code      | Code | Device    |      |     |  |  |      |     |  |
|        | 0010             |      |         |           | 0010   |      |          |           | 0010      |      |           |      |     |  |  |      |     |  |
|        | 0110             | 000  | 000     | 000       | 000    | 000  | 110      | 0110      | 000       |      |           | 0110 | 000 |  |  | 0110 | 000 |  |
|        | 1001             |      |         |           |        | 1001 | 000      |           |           | 1001 | 000       |      |     |  |  |      |     |  |
|        | 1011             |      |         |           | 1011   |      |          |           | 1011      |      |           |      |     |  |  |      |     |  |
|        | 0010             |      |         |           | 0010   |      |          |           | 0010      |      |           |      |     |  |  |      |     |  |
|        | 0110             | 001  |         |           | 0110   | 001  |          |           | 0110      | 001  |           |      |     |  |  |      |     |  |
|        | 1001             | 001  |         |           | 1001   | 001  |          |           | 1001      |      |           |      |     |  |  |      |     |  |
|        | 1011             |      |         |           | 1011   |      |          |           | 1011      |      |           |      |     |  |  |      |     |  |
|        | 0010             |      |         |           | 0010   |      |          |           | 0010      |      | Host      |      |     |  |  |      |     |  |
|        | 0110<br>1001 010 | 010  |         |           | 0110   | 010  |          |           | 0110      | 010  | operation |      |     |  |  |      |     |  |
|        |                  |      |         |           | 1001   | 010  |          |           | 1001      | 010  | to        |      |     |  |  |      |     |  |
|        | 1011             |      |         | 1011      | 1011   |      |          |           | 1011      |      | 1010 010  |      |     |  |  |      |     |  |
|        | 0010             |      |         |           | 0010   |      |          |           | 0010      | 011  |           |      |     |  |  |      |     |  |
|        | 0110             | 011  |         |           | 0110   | 011  |          |           | 0110      |      |           |      |     |  |  |      |     |  |
|        | 1001             |      | 011     |           |        | 1001 | 011      |           |           | 1001 | 011       |      |     |  |  |      |     |  |
| 1010   | 1011             |      |         | 0110      | 1011   |      |          | 1010      | 1011      |      |           |      |     |  |  |      |     |  |
| 011    | 0010             |      |         | 101       | 0010   |      |          | 010       | 0010      |      |           |      |     |  |  |      |     |  |
|        | 0110             | 100  | 100     | 100       |        |      | 0110     | 100       |           |      | 0110      | 100  |     |  |  |      |     |  |
|        | 1001             |      |         |           |        |      | 1001     | 100       |           |      | 1001      | 100  |     |  |  |      |     |  |
|        | 1011             |      |         |           | 1011   |      |          |           | 1011      |      |           |      |     |  |  |      |     |  |
|        | 0010             |      |         |           | 0010   |      | Host     |           | 0010      |      |           |      |     |  |  |      |     |  |
|        | 0110             | 101  | 404     | 0         |        |      | 0110     | 404       | operation |      | 0110      | 101  |     |  |  |      |     |  |
|        | 1001             |      |         |           | 1001   | 101  | to       |           | 1001      | 101  |           |      |     |  |  |      |     |  |
|        | 1011             |      |         |           | 1011   |      | 0110 101 |           | 1011      |      |           |      |     |  |  |      |     |  |
|        | 0010             |      |         |           | 0010   |      |          |           | 0010      |      |           |      |     |  |  |      |     |  |
|        | 0110             | 110  | 011     | 0110      | 440    |      |          | 0110      | 440       |      |           |      |     |  |  |      |     |  |
|        | 1001             |      |         |           | 1001   | 110  | 110      |           |           | 1001 | 110       |      |     |  |  |      |     |  |
|        | 1011             |      |         | 1011      |        | 1011 |          |           |           |      |           |      |     |  |  |      |     |  |
|        | 0010             |      | 0010    | 0010      |        |      |          | 0010      |           |      |           |      |     |  |  |      |     |  |
|        | 0110             | 444  | 0011    |           | 0110   | 444  |          |           | 0110      | 444  |           |      |     |  |  |      |     |  |
|        | 1001             | 111  | 111     |           | 1001   | 111  |          |           | 1001      | 111  |           |      |     |  |  |      |     |  |
|        | 1011             |      |         |           | 1011   |      |          |           | 1011      |      |           |      |     |  |  |      |     |  |



### 8.5 Interrupt Arbitration; SETHID CCC is Issued by Host

The interrupt arbitration process works similar way as defined in Section 8.4 but with a simplification. It is assumed that in this case, all Target devices behind Hub across all DIMMs on I3C Basic bus have a unique 7-bit device select code. Further, it assumes that all devices on a DIMM have the same 3-bit HID code.

The SPD5 Hub device forwards the 4-bit LID code and 3-bit HID code one digit at a time that it receives from the local Target devices to the Host. The SPD5 Hub device's own receiver will see the same input and it forwards it back to the local device interface.

## 8.5.1 Interrupt Arbitration - Between SPD5 Hub and Local Target Devices behind Hub

On an any given DIMM, the arbitration is always won by the device that has the lowest 4-bit LID code since all devices on the DIMM has same 3-bit HID code.

### 8.5.2 Interrupt Arbitration - Between all SPD5 Hub and all Local Target Devices behind Hub

Across multiple DIMMs, the arbitration is always won by the device that has the lowest 7-bit address (4-bit LID + 3-bit HID).

### 8.5.3 Interrupt Arbitration - Between Host and All Devices

In an uncommon but possible scenario would be that at the exact same time as when the Target device is requesting an interrupt, the Host is starting an operation to the Target device. When this happens, Host also gets involved in the arbitration process along with the Target devices. During the arbitration phase, there will be always only one winning device and it could be either the Host or the Target device.

If the Host wins during the arbitration phase, it continues with normal operation. The losing Target device waits for next opportunity to send an interrupt.

If the Host loses during the arbitration phase, it must let go of the bus. When Host loses during the arbitration, the Host must let the Target device finish sending their 4-bit LID code followed by 3-bit HID code followed by R/W = '1'. At this point, during the 9<sup>th</sup> bit, the Host has two options to take the action as noted below:

- Host sends an ACK to accept the interrupt and hence accepts the IBI payload from the winning Target device.
   After the IBI payload, the Host issues STOP operation.
- Host sends an NACK followed by STOP operation.

In a rare but still possible scenario would be that at the exact same time as when the SPD5 Hub device is requesting an interrupt, the Host is starting an operation to that same SPD5 Hub device. When this happens, neither Host or nor the SPD5 Hub device knows it is a winner until the 8th bit and Host always wins. This is because, the SPD5 hub device sends R=1 (8th bit) during the interrupt. The Host sets W=0 (8th bit) during the operation. As a result, the Host wins and the SPD5 Hub device must let go of the bus and wait for the next opportunity to send an interrupt.

In an extreme rare but still possible scenario would be that at the exact same time as when the SPD5 Hub device is requesting an interrupt, the Host is requesting a read operation with default read address pointer mode to the SPD5 Hub device. When this happens, there is no winning device. This is the only time there is no winning device. This is because, the SPD5 Hub device sends R=1 (8<sup>th</sup> bit) during the interrupt and Host also sends R=1 for read request with default read address pointer mode. As a result, there is no winner because all devices, i.e. the Host



or the SPD5 Hub devices, are waiting for other device to ACK. In this case, no devices will ACK. Since there is no ACK by any device, the Host must time out and repeats the read request with Repeat Start. When it repeats the read request with Repeat Start, the SPD5 Hub device does not send an interrupt because of Repeat Start.

## 8.6 Clearing Device Status and IBI Status Registers

The SPD5 Hub device provides the IBI status in *MR48*[7] by setting it to '1'. The SPD5 Hub device clears the IBI status register *MR48*[7] to '0' automatically when it sends a complete IBI (including payload and without interruption) and it also clears Pending Interrupt Bits [3:0] to '0000'. Once IBI status register is cleared, the SPD5 Hub does not request for an IBI again unless another event occurs.

The SPD5 Hub device provides the device status in *MR51* and *MR52* registers. The status information in MR51 and *MR52* are latched and remains set even after the SPD5 Hub device sends IBI payload and clears the IBI status register *MR48*[7] to '0'. The Host must explicitly clear the status register through Clear command by writing '1' for appropriate status or by issuing a Global Clear command.

After Host issues Clear command, if the condition is no longer present, the SPD5 Hub device clears the appropriate status register, clears the IBI status register to '0' and Pending Interrupt Bits [3:0] to '0000' even if the SPD5 Hub device has not sent the IBI. After Host issues Clear command, if the condition is still present, the device will again set the appropriate status register, sets the IBI status register to '1' and Pending Interrupt Bits [3:0] to '0001' even if the device has already sent the IBI and entire IBI payload.



### 9 Error Check Function

## 9.1 Packet Error Check (PEC) Function

In I<sup>2</sup>C mode, packet error checking is not supported. Only I3C Basic mode supports packet error checking. The SPD5 Hub device implements an 8-bit Packet Error Code (PEC) which is appended at the end of all transactions if PECs is enabled through DEVCTRL CCC. The PEC is a CRC-8 value calculated on all the message bytes except for START, REPEATED START, STOP conditions or 'T' bits, ACK and NACK and IBI header (7'h7E followed by W=0) bits.

The polynomial for CRC-8 calculations is:

$$C(X) = X^8 + X^2 + X^1 + 1$$

The seed value for PEC function is all zero.

When Host calculates PEC for SPD5 Hub device, it includes LID and HID bits followed by R/W bit.

## 9.2 Parity Error Check Function

In I<sup>2</sup>C mode, parity error checking is not supported except for supported CCCs. Only I3C Basic mode supports parity error checking.

By default, when SPD5 Hub device is put in I3C Basic mode, parity function is automatically enabled. The Host can disable the function after it is enabled. Host can only disable the parity function with DEVCTRL CCC (RegMod = '0'). When parity function is disabled, the SPD5 Hub device simply ignores the 'T' bit information from the Host. The Host may actually choose to compute the parity and send that information during 'T' bit or simply drive static low or high in 'T' bit.

The SPD5 Hub device implements ODD parity. If an odd number of bits in the byte are '1', the parity bit value is '0'.

If even number of bits in the byte are '1', the parity bit value is '1'. The Host computes the parity and sends it during 'T' bit.

## 9.3 Packet Error Check and Parity Error Handling

There are two types of error checking done by the SPD5 Hub device: parity error checking and packet error checking. By default, the parity error checking is always enabled and packet error checking is disabled when the SPD5 Hub device is put in I3C Basic mode. The Host may enable the packet error checking at any time. The parity error is calculated for each byte. The Host sends parity error information in 'T' bit.

I3C Basic defines TE0, TE1, TE2, TE3, TE4, TE5, TE6 error detection for Target devices. Only TE1 and TE2 error detection is supported by the SPD5 Hub for parity checking. All other errors are not supported and not applicable.

### 9.3.1 Write Command Data Packet Error Handling - PEC Disabled

The SPD5 Hub device checks for the parity error for each byte in a packet except for the device select code byte that it receives from the Host as shown in Table 21.

Write command - if no parity error:

• The SPD5 Hub device executes the command.



Write command - if parity error:

- The SPD5 Hub device discards the byte in the packet that had a parity error.
- The SPD5 Hub device discards all subsequent bytes in that packet until the STOP operation. The SPD5 Hub
  device may or may not check parity for all sub-sequent bytes in that packet.
- Note that as the packet contains more than one byte, if first byte had no parity error but the second byte had
  a parity error, the SPD5 Hub device may or may not execute the first byte operation but second byte and all
  subsequent bytes operations are discarded.
- The SPD5 Hub device sets the *MR52*[0], *MR48*[7] and P\_Err in GETSTATUS CCC to '1'; updates Pending Interrupt Bits [3:0] to '0001' and waits for the next opportunity to send an in band interrupt if IBI is enabled.

### 9.3.2 Read Command Data Packet Error Handling - PEC Disabled

The SPD5 Hub device checks for parity error for each byte in a packet except for the device select code byte that it receives from the Host prior to Repeat Start as shown in Table 25.

The SPD5 Hub device does not compute the parity when it sends the data to the Host. The Host does not check for parity error for the bytes that SPD5 Hub device sends. The SPD5 Hub device sends Continuous ('1') or Stop ('0') information during 'T' bit.

Read Command - If no parity error:

- The SPD5 Hub sends ACK back to the Host when Host performs Start Repeat operation.
- The SPD5 Hub device executes the command and sends the data as shown in Table 25.

Read Command - If parity error:

- The SPD5 Hub device discards the byte in the packet that had a parity error.
- The SPD5 Hub device discards second byte in that packet if the parity error occurred in first byte. The SPD5
  Hub device may or may not check the parity for second byte in that packet.
- The SPD5 Hub sends NACK back to the Host when Host performs a Start Repeat operation. This is shown in the RED color cell in Table 25. The NACK represents either a parity error in one of the two bytes or that SPD5 Hub is not able to start the read operation. The Host may re-try Repeat Start again. The Host may do the Repeat Start as many times as it may desire. If the SPD5 Hub device NACKs due to parity error in a previous byte from the Host, it will always NACK regardless of how many times Host tries Repeat Start.
- The SPD5 Hub does not send the data shown in Table 25 and instead expects Host to perform STOP operation.
- The SPD5 Hub device sets *MR52*[0] and *MR48*[7] and P\_Err in GETSTATUS CCC to '1'; updates Pending Interrupt Bits [3:0] in GETSTATUS to '0001' and waits for the next opportunity to send an in band interrupt if IBI is enabled.

### 9.3.3 Write Command Data Packet Error Handling - PEC Enabled

The SPD5 Hub device checks for the parity error for each byte in a packet except for the device select code byte that it receives from the Host as shown in Table 22. Further, the SPD5 Hub device checks for the packet error for the entire packet (from Start condition until last byte of Data) that receives from the Host as shown in Table 22.

Write command - if no parity error:

 The SPD5 Hub device waits for the entire packet. If no error in packet, the SPD5 Hub device executes the command. If there is an error in the packet, the SPD5 Hub device discards the entire packet and does not



execute that packet and waits for STOP, sets the *MR52*[1] and *MR48*[7] to '1' and PEC\_Err in GETSTATUS CCC to '1' and updates Pending Interrupt Bits [3:0] in GETSTATUS CCC to '0001' and waits for the next opportunity to send in band interrupt if IBI is enabled.

### Write command - if parity error:

- The SPD5 Hub device discards that byte and the entire packet until STOP operation.
- The SPD5 Hub device sets MR52[0] and MR48[7] and P\_Err in GETSTATUS CCC to '1'; updates Pending Interrupt Bits [3:0] in GETSTATUS CCC to '0001' and waits for the next opportunity to send in band interrupt if IBI is enabled.
- The SPD5 Hub device may or may not check the error for the packet. If the SPD5 Hub device checks for the
  packet error, likely it will detect an error in the packet and the device may also set MR52[1] and PEC\_Err in
  GETSTATUS CCC to '1' as well.

### 9.3.4 Read Command Data Packet Error Handling - PEC Enabled

The SPD5 Hub device checks for the parity error for each byte in a packet except for the device select code byte that it receives from the Host prior to Repeat Start as shown in Table 26.

The SPD5 Hub device does not compute the parity when it sends the data to the Host. It does not check for parity error for the bytes shown in Table 26. The SPD5 Hub device sends Continuous ('1') or Stop ('0') information during 'T' bit when SPD5 Hub device is sending the read data.

The SPD5 Hub device checks for the PEC error for a packet that it receives from the Host from Start condition to Repeat Start condition (from first device select code followed by the address offset and CMD byte).

The SPD5 Hub device computes the packet error code for the entire packet starting with Repeat Start (device select code and the data SPD5 Hub device transmits back to Host)

Read command - If no parity error and no PEC error:

- The SPD5 Hub sends ACK back to the Host when Host performs a Start Repeat operation.
- The SPD5 Hub device executes the command and sends the data as shown in Table 26.
- The SPD5 Hub computes PEC for the bytes (from Start condition to PEC byte prior to Repeat Start) shown in Table 26.

Read command - if parity error or PEC error:

- The SPD5 Hub device discards the byte in the packet that had a parity error.
- The SPD5 Hub device discards second byte in that packet if a parity error occurred in first byte. The SPD5
- Hub device may or may not check parity for the second byte in that packet.
- The SPD5 Hub device discards the packet if there is a PEC error.
- The SPD5 Hub sends NACK back to the host when Host performs Start Repeat operation. This is shown in the RED color cell in Table 26. The NACK represents either PEC error or a parity error in one of the three bytes or that SPD5 Hub is not able to start the read operation. The Host may re-try Repeat Start again. The Host may do the Repeat Start as many times it may desire. The PEC calculation by SPD5 Hub device only includes device select code of the ACK responses of the Repeat Start operation. In other words, if there are more than one Repeat Start operation, the SPD5 Hub device includes the device select of only the last Repeat Start from the Host when it ACKs in PEC calculation and other NACK responses of the device select codes of the Repeat Start are not included in PEC calculation. If the SPD5 Hub device NACKs due to PEC error or a parity error in previous bytes from Host, it will always NACK regardless of how many times Host



tries Repeat Start.

- The SPD5 Hub does not send any data shown in Table 26 and instead expects Host to perform STOP operation.
- The SPD5 Hub device sets MR52[0] and MR48[7] and P\_Err in GETSTATUS CCC to '1' for parity error and MR52[1] and MR48[7] and PEC\_Err in GETSTATUS CCC to '1' for PEC error. Further, the SPD5 Hub updates Pending Interrupt Bits [3:0] in GETSTATUS CCC to '0001' and waits for the next opportunity to send an in band interrupt if IBI is enabled.

## 9.3.5 CCC Packet Error Handling

Parity error and PEC error detected in a CCC packet are handled in the same way as described for normal Read/Write operations.

### 9.3.6 Error Reporting

All error conditions including PEC error check and parity error check detected by the SPD5 Hub devices are captured in *MR51* and *MR52* registers.

There are three different possible ways error information can be communicated to the Host.

- 1. The Host makes the read request to MR51 and MR52 registers.
- 2. The Host starts any transaction with 7'h7E IBI header (only applicable in I3C mode).
- 3. The SPD5 Hub device sends in band interrupt if enabled, when its SCL and SDA input has been idle for t<sub>AVAL</sub> time (only applicable in I3C Basic mode).



# 10 SPD5 Hub Device - Write and Read

In both I<sup>2</sup>C and I3C mode, any read or write access to SPD5 Hub NVM memory must be followed by STOP operation (i.e. not Repeat Start) before launching new access to SPD5 Hub volatile memory registers. Conversely, any read or write access to SPD5 Hub volatile memory registers must be followed by STOP operation (i.e. not Repeat Start) before launching new access to SPD5 Hub NVM memory.

## 10.1 Command Truth Table

The command truth table as shown in Table 83 only applies in I3C Basic mode with PEC enabled. In I2C mode and I3C Basic mode with PEC disabled, the command truth table does not apply.

Table 83. For I3C Basic Mode Only w/ PEC Enabled - Command Truth Table

|                            |                 | Command<br>Code        | RW                  | MemReg              | Block<br>Address                               | Address                |
|----------------------------|-----------------|------------------------|---------------------|---------------------|------------------------------------------------|------------------------|
| SPD5 Command               | Command<br>Name | 2nd Byte<br>Bits [7:5] | 2nd Byte<br>Bit [4] | 1st Byte<br>Bit [7] | 2nd Byte<br>Bits [3:0]<br>1st Byte<br>Bits [6] | 1st Byte<br>Bits [5:0] |
| Write 1 Byte to Register   | W1R             |                        | 0                   | 0                   | V                                              | V                      |
| Read 1 Byte from Register  | R1R             | 000                    | 1                   | 0                   | V                                              | V                      |
| Write 1 Byte to NVM        | W1M             | 000                    | 0                   | 1                   | V                                              | V                      |
| Read 1 Byte from NVM       | R1M             |                        | 1                   | 1                   | V                                              | V                      |
| Write 2 Byte to Register   | W2R             |                        | 0                   | 0                   | V                                              | V                      |
| Read 2 Byte from Register  | R2R             | 001                    | 1                   | 0                   | V                                              | V                      |
| Write 2 Byte to NVM        | W2M             | 001                    | 0                   | 1                   | V                                              | V                      |
| Read 2 Byte from NVM       | R2M             |                        | 1                   | 1                   | V                                              | V                      |
| Write 4 Byte to Register   | W8R             |                        | 0                   | 0                   | V                                              | V                      |
| Read 4 Byte from Register  | R8R             | 010                    | 1                   | 0                   | V                                              | V                      |
| Write 4 Byte to NVM        | W8M             | 010                    | 0                   | 1                   | V                                              | V                      |
| Read 4 Byte from NVM       | R8M             |                        | 1                   | 1                   | V                                              | V                      |
| Write 16 Byte to Register  | W16R            |                        | 0                   | 0                   | V                                              | V                      |
| Read 16 Byte from Register | R16R            | 011                    | 1                   | 0                   | V                                              | V                      |
| Write 16 Byte to NVM       | W16M            | UII                    | 0                   | 1                   | V                                              | V                      |
| Read 16 Byte from NVM      | R16M            |                        | 1                   | 1                   | V                                              | V                      |
| Reserved                   | RSVD            | 011 to 111             | RSVD                | RSVD                | RSVD                                           | RSVD                   |



## 10.2 Write and Read Access - NVM Memory

For I<sup>2</sup>C mode and I3 mode with PEC disabled, the Write access to NVM memory is done within 16 byte boundary in a block. Once the last address within 16 byte boundary in a block is reached, the device stops the operation. The write operation to remaining addresses is not executed by the SPD5 Hub device. The SPD5 Hub device does not loop to first address within the 16 byte boundary in that block. The SPD5 Hub device does not set any register to inform this to the Host and does not generate any interrupt to the Host.

For I3C mode with PEC enabled, if for a given Write access (either W2M, W4M, W16M) to NVM memory reaches the last address within the 16 byte boundary in a block, (i.e. Byte 15, Byte 31, Byte 47, Byte 63), the device stops the operation. The write operation to remaining addresses is not executed by the SPD5 Hub device. The SPD5 Hub device does not loop to first address within the 16 byte boundary in that block. The SPD5 Hub device does not set any register to inform this to the Host and does not generate any interrupt to the Host.

Unlike Write access to NVM memory, any Read access to NVM memory does not impose 16 byte boundary or block boundary. The Read access to NVM memory is treated as continuous address space even if it crosses 16 byte boundary or block boundary in I<sup>2</sup>C mode or I3C Basic mode (w/ or w/o PEC enabled). The last byte for NVM memory is 1024<sup>th</sup> byte and when the address pointer reaches to the last byte, the SPD5 Hub device does not return any data. In I<sup>2</sup>C mode and I3C Basic mode with PEC disabled, the Host must do the STOP operation.

### 10.3 Write and Read Access - Register Memory

There is no concept of "Block Address". The "Block Address" is treated is simply as upper address bit when MemReg = '0' by the SPD5 Hub device.

For I<sup>2</sup>C mode and I3C Basic mode with PEC disabled or PEC enabled, any access to read or write to register memory is continuous address space even if it appears crossing 16 byte boundary or "Block Address" boundary. The last byte is MR255 and when the address pointer reaches to MR255, the SPD5 Hub device does not return any data.

In I<sup>2</sup>C mode and I3C Basic mode with PEC disabled, the Host must do the STOP operation.

## 10.4 Write Protection of Non-Volatile Memory

## 10.4.1 Normal Run Time Operation

In Normal Run Time Operation mode, by HSA Pin tied to GND via a resistor value, the SPD5 Hub device offers a write protection for its NVM memory. The MR12[7:0] and *MR13*[7:0] register contains a bit map for write protection status of each 64 byte block of NVM memory.

The MR12[7:0] and *MR13*[7:0] registers can be written to '1' at any time. When any bit in *MR12* or *MR13* is set to '1', further writes to that corresponding block of NVM are ignored and *MR52*[6] bit is set to '1'.

Once any bit is written to '1' in MR12 and *MR13*, clearing that bit in normal run time mode is not allowed. Any attempt to clear the bit in *MR12* and *MR13* is ignored and *MR52*[5] bit is set to '1'.

### 10.4.2 Offline Tester Operation

In Offline Tester Operation mode, by HSA Pin tied directly to GND with no resistor value, the SPD5 Hub device allows to clear any bit in *MR12* and *MR13* registers.



Once cleared, the SPD5 Hub device allows to modify the corresponding block of NVM memory.

### 10.4.3 Suggested Steps to Program SPD5 Hub Devices

The recommended steps to program the SPD Hub devices are:

- 1. Connect HSA Pin directly to GND (without a resistor).
- 2. Power up the device. The device senses HSA pin. It sets MR48[2] = '1' and enables write protection override.
- 3. Program MR12 and MR13 to enable desired NVM blocks to be written.
- 4. Program desired NVM blocks.
- 5. Program MR12 and MR13 to set the write protection as desired.



# 11 Registers

## 11.1 Register Attribute Definition

All volatile registers have Base Attributes as defined in Table 84. Some register attributes are further modified with Attribute Modifiers, as defined in Table 85.

The volatile register space has a continuous address. Unlike non-volatile memory in SPD5 Hub device, there is no concept of "Block" memory in volatile register space. When writing to and reading from volatile register space (i.e. MemReg = 0), the "Block Address bits" are treated simply as Upper address bits.

**Table 84. Register Base Attributes** 

| Attribute  | Abbreviation | Description                                                                                                                                                                                                            |  |  |  |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Read Only  | R            | This bit can be read by software. Writes have no effect.                                                                                                                                                               |  |  |  |
| Read/Write | RW           | This bit can be read or written by software.                                                                                                                                                                           |  |  |  |
| Write Only | W            | This bit can only be written by software.                                                                                                                                                                              |  |  |  |
| Reserved   | RV           | This bit is reserved for future expansion and its value must not be modified by software.  The bit will return '0' when read. When writing this bit, software must preserve the value read unless otherwise indicated. |  |  |  |

**Table 85. Register Attribute Modifier** 

| Attribute    | Abbreviation | Description                                                                                                                                              |
|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write 1 Only | 10           | This bit can only be set (i.e. write '1') but not reset (i.e. write '0')                                                                                 |
| Protected    | Р            | This bit is protected by the password registers TBD. This bit cannot be written to unless the password code has been written into the password registers |
| Persistent   | E            | Persistent.                                                                                                                                              |



## 11.2 Register Map

|                | Register Address |            |                                                              |
|----------------|------------------|------------|--------------------------------------------------------------|
| Register Name  | (Hex)            | Attribute  | Description                                                  |
| MR0            | 0x00             | ROE        | Device Type; Most Significant Byte                           |
| MR1            | 0x01             | ROE        | Device Type; Least Significant Byte                          |
| MR2            | 0x02             | ROE        | Device Revision                                              |
| MR3            | 0x03             | ROE        | Vendor ID Byte 0                                             |
| MR4            | 0x04             | ROE        | Vendor ID Byte 1                                             |
| MR5            | 0x05             | ROE        | Device Capability                                            |
| MR6            | 0x06             | ROE        | Device Write Recovery Time Capability                        |
| MR7 to MR10    | 0x07 to 0x0A     | RV         | Reserved                                                     |
| MR11           | 0x0B             | RW         | I <sup>2</sup> C Legacy Mode Device Configuration            |
| MR12           | 0x0C             | RWE        | Write Protection For NVM Blocks [7:0]                        |
| MR13           | 0x0D             | RWE        | Write Protection for NVM Blocks [15:8]                       |
| MD44           | 005              | DME        | Device Configuration - Host and Local Interface IO;          |
| MR14           | 0x0E             | RWE        | DO NOT USE [4:0]                                             |
| MR15           | 0x0F             | RV         | DO NOT USE                                                   |
| MR16 to MR17   | 0x10 to 0x11     | RV         | Reserved                                                     |
| MR18           | 0x12             | RO, RW     | Device Configuration                                         |
| MR19           | 0x13             | 10         | Clear Register MR51 Temperature Status Command               |
| MR20           | 0x14             | 10         | Clear Register MR52 Error Status Command                     |
| MR21 to MR25   | 0x15 to 0x19     | RV         | Reserved                                                     |
| MR26           | 0x1A             | RW         | TS Configuration                                             |
| MR27           | 0x1B             | 10, R0, RW | Interrupt Configurations                                     |
| MR28           | 0x1C             | RW         | TS Temperature High Limit Configuration - Low Byte           |
| MR29           | 0x1D             | RW         | TS Temperature High Limit Configuration - High Byte          |
| MR30           | 0x1E             | RW         | TS Temperature Low Limit Configuration - Low Byte            |
| MR31           | 0x1F             | RW         | TS Temperature Low Limit Configuration - High Byte           |
| MR32           | 0x20             | RW         | TS Critical Temperature High Limit Configuration – Low Byte  |
| MR33           | 0x21             | RW         | TS Critical Temperature High Limit Configuration – High Byte |
| MR34           | 0x22             | RW         | TS Critical Temperature Low Limit Configuration – Low Byte   |
| MR35           | 0x23             | RW         | TS Critical Temperature Low Limit Configuration – High Byte  |
| MR36 to MR47   | 0x24 to 0x2F     | RV         | Reserved for Device Configuration Type of Registers          |
| MR48           | 0x30             | RO         | Device Status                                                |
| MR49           | 0x31             | RO         | TS Current Sensed Temperature - Low Byte                     |
| MR50           | 0x32             | RO         | TS Current Sensed Temperature - High Byte                    |
| MR51           | 0x33             | RO         | TS Temperature Status                                        |
| MR52           | 0x34             | RO         | Hub, Thermal and NVM Error Status                            |
| MR53 to MR127  | 0x35 to 0x7F     | RV         | Reserved                                                     |
| MR128 to MR255 | 0x80 to 0xFF     | RV         | Reserved for Vendor Specific Registers                       |



#### 11.3 Thermal Sensor Registers Read Out Mechanism

All thermal registers are sixteen bits quantities stored in two consecutive registers; low byte first and then high byte. Five bits are reserved for future use. Reserved bits are Read only bits and must be set to '0' when Host writes to low and high byte. The device returns '0' in reserved bits when Host reads from the low and high byte. Remaining eleven bits in these paired registers form a signed value of multiples of 0.25 ranging from -256.00 to + 255.75. Units for all thermal registers are °C.

The format of each pair of thermal registers is shown in Table 86 below.

Table 86. Thermal Register - Low Byte and High Byte

| Reg   | jister    | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |
|-------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| MRX   | Low Byte  | 8     | 4     | 2     | 1     | 0.5   | 0.25  | RSVD  | RSVD  |
| MRX+1 | High Byte | RSVD  | RSVD  | RSVD  | Sign  | 128   | 64    | 32    | 16    |

<sup>1.</sup> Bit 'Sign' decides whether the readout temperature is positive or negative. The examples (reserved bits in grey, sign bit highlighted in blue) is shown in Table 87 below.

**Table 87. Thermal Register Examples** 

| High Byte | Low Byte  | Value   | Unit |
|-----------|-----------|---------|------|
| 0000 0101 | 1111 0000 | + 95.00 | °C   |
| 0000 0101 | 0101 0000 | + 85.00 | °C   |
| 0000 0100 | 1011 0000 | + 75.00 | °C   |
| 0000 0000 | 0001 0000 | + 1.00  | °C   |
| 0000 0000 | 0000 1100 | + 0.75  | °C   |
| 0000 0000 | 0000 1000 | + 0.50  | °C   |
| 0000 0000 | 0000 0100 | + 0.25  | °C   |
| 0000 0000 | 0000 0000 | 0.00    | °C   |
| 0001 1111 | 1111 1100 | - 0.25  | °C   |
| 0001 1111 | 1111 1000 | - 0.50  | °C   |
| 0001 1111 | 1111 0100 | - 0.75  | °C   |
| 0001 1111 | 1111 0000 | - 1.00  | °C   |
| 0001 1101 | 1000 0000 | - 40.00 | °C   |

## 11.4 Register Description

Table 88. MR0

| Addr | MR0     |         | Device Type; Most Significant Byte <sup>1</sup> |
|------|---------|---------|-------------------------------------------------|
| Bits | Attr    | Default | Description                                     |
| 7:0  | 7:0 ROE | 0x51    | MR0[7:0]: MSB_DEV_TYPE                          |
| 7.0  | NOL     | 0.01    | Device Type - SPD5 Hub Device                   |

<sup>1.</sup> The code in this register is used in conjunction with any device type in MR1 register.



## Table 89. MR1

| Addr | MR1  |         | Device Type; Least Significant Byte <sup>1</sup> |
|------|------|---------|--------------------------------------------------|
| Bits | Attr | Default | Description                                      |
|      |      |         | MR1[7:0]: LSB_DEV_TYPE                           |
| 7:0  | ROE  | 0x18    | Device Type                                      |
|      |      |         | 0x18: with Temperature Sensor; SPD5 Hub Device   |

<sup>1.</sup> The code in this register is used in conjunction with any device type in *MR0* register.

#### Table 90. MR2

| Addr | MR2  |         | Device Revision         |
|------|------|---------|-------------------------|
| Bits | Attr | Default | Description             |
| 7:6  | RV   | 0       | MR2[7:6]: Reserved      |
|      |      |         | MR2[5:4]: DEV_REV_MAJOR |
|      |      |         | Major Revision          |
| 5:4  | ROE  | 00      | 00 = Revision 1         |
| 5.4  | ROE  | 00      | 01 = Revision 2         |
|      |      |         | 10 = Revision 3         |
|      |      |         | 11 = Revision 4         |
|      |      |         | MR2[3:1]: DEV_REV_MINOR |
|      |      |         | Minor Revision          |
|      |      | 011     | 000 = Revision 0        |
| 3:1  | ROE  |         | 001 = Revision 1        |
|      |      |         | 010 = Revision 2        |
|      |      |         |                         |
|      |      |         | 111 = Revision 8        |
| 0    | RV   | 0       | MR2[0]: Reserved        |

#### Table 91. MR3

| Addr | MR3    |         | Vendor ID Byte 0          |
|------|--------|---------|---------------------------|
| Bits | Attr   | Default | Description               |
| 7:0  | .0 DOE | 0x86    | MR3[7:0]: VENDOR_ID_BYTE0 |
| 7.0  | ROE    | 0,000   | Vendor ID Byte 0          |

## Table 92. MR4

| Addr | MR4  |         | Vendor ID Byte 1          |
|------|------|---------|---------------------------|
| Bits | Attr | Default | Description               |
| 7:0  | DOE  | 0XC8    | MR4[7:0]: VENDOR_ID_BYTE1 |
| 7.0  | ROE  | UACO    | Vendor ID Byte 1          |



## Table 93. MR5

| Addr  | MR5   |                                   | Device Capability                       |
|-------|-------|-----------------------------------|-----------------------------------------|
| Bits  | Attr  | Default                           | Description                             |
| 7:2   | RV    | 0                                 | MR5[7:2]: Reserved                      |
|       | 1 ROE | 1                                 | MR6[1]: TS_SUPPORT                      |
| 4     |       |                                   | Internal Temperature Sensor Support     |
| '     |       |                                   | 0 = Does not support Temperature Sensor |
|       |       |                                   | 1 = Supports Temperature Sensor         |
|       |       |                                   | MR6[0]: HUB_SUPPORT                     |
| 0     |       |                                   | Hub Function Support                    |
| 0 ROE | I     | 0 = Does not support Hub function |                                         |
|       |       |                                   | 1 = Supports Hub function               |

## Table 94. MR6

| Addr | MR6  |         | Write Recovery Time        |
|------|------|---------|----------------------------|
| Bits | Attr | Default | Description                |
|      |      |         | MR6[7:4]:WR_REC_UNIT       |
|      |      |         | Write Recovery Unit        |
|      |      |         | 0000 = 0                   |
|      |      |         | 0001 = 1                   |
|      |      |         | 0010 = 2                   |
|      |      |         | 0011 = 3                   |
|      |      |         | 0100 = 4                   |
|      |      |         | 0101 = 5                   |
| 7:4  | ROE  | 0101    | 0110 = 6                   |
| 7.4  | ROE  | 0101    | 0111 = 7                   |
|      |      |         | 1000 = 8                   |
|      |      |         | 1001 = 9                   |
|      |      |         | 1010 = 10                  |
|      |      |         | 1011 = 50                  |
|      |      |         | 1100 = 100                 |
|      |      |         | 1101 = 200                 |
|      |      |         | 1110 = 500                 |
|      |      |         | 1111 = Reserved            |
| 3:2  | RV   | 0       | MR6[3:2]:Reserved          |
|      |      |         | MR6[1:0]: WR_REC_UNIT_TIME |
|      |      | 10      | Write Recovery Time Unit   |
| 4.0  | ROE  |         | 00 = ns                    |
| 1:0  | KUE  |         | 01 = μs                    |
|      |      |         | 10 = ms                    |
|      |      |         | 11 = Reserved              |



#### **Table 95. MR11**

| Addr | MR11 |         | I <sup>2</sup> C Legacy Mode Device Configuration                          |
|------|------|---------|----------------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                                |
| 7:4  | RV   | 0       | MR11[7:4]: Reserved                                                        |
|      |      |         | MR11[3]: I <sup>2</sup> C_LEGACY_MODE_ADDR                                 |
| 3    | RW   | 0       | SPD5 Hub Device - I <sup>2</sup> C Legacy Mode Addressing                  |
| 3    | KVV  | U       | 0 = 1 Byte Addressing for SPD5 Hub Device Memory                           |
|      |      |         | 1 = 2 Bytes Addressing for SPD5 Hub Device Memory                          |
|      |      | 000     | MR11[2:0]: I <sup>2</sup> C_LEGACY_MODE_ADDR_POINTER                       |
|      |      |         | SPD5 Device - Non Volatile Memory Address Page Pointer in I <sup>2</sup> C |
|      |      |         | Legacy Mode <sup>1,2,3</sup>                                               |
|      |      |         | 000 = Page 0 (0x00 to 0x7F)                                                |
|      |      |         | 001 = Page 1 (0x80 to 0xFF)                                                |
| 2:0  | RW   |         | 010 = Page 2 (0x100 to 0x17F)                                              |
|      |      |         | 011 = Page 3 (0x180 to 0x1FF)                                              |
|      |      |         | 100 = Page 4 (0x200 to 0x27F)                                              |
|      |      |         | 101 = Page 5 (0x280 to 0x2FF)                                              |
|      |      |         | 110 = Page 6 (0x300 to 0x37F)                                              |
|      |      |         | 111 = Page 7 (0x380 to 0x3FF)                                              |

<sup>1.</sup> This register is only applicable if bit [3] = '0' and *MR18*[5] = '0'. The SPD5 Hub device does not incur any delay to switch from one page to another page.

<sup>2.</sup> This register only applies to non-volatile memory (1024 Bytes) access of SPD5 Hub device. For volatile memory access, this register must be programmed to '000'.

<sup>3.</sup> See Section 10.2 for the NVM Write and Read operation when device reaches the last byte of the 16 bytes block boundary.



#### **Table 96. MR12**

| Addr | MR12  |         | NVM Protection Configuration For Blocks [7:0] <sup>1,2</sup> |
|------|-------|---------|--------------------------------------------------------------|
| Bits | Attr  | Default | Description                                                  |
|      |       |         | MR12[7]: WP_BLK_7                                            |
| 7    | DIAG  | A/E     | Write Protect - Block 7                                      |
| 7    | RWE   |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[6]: WP_BLK_6                                            |
| •    | DIAG  |         | Write Protect - Block 6                                      |
| 6    | RWE   |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[5]: WP_BLK_5                                            |
| -    | DIAG  |         | Write Protect - Block 5                                      |
| 5    | RWE   |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[4]: WP_BLK_4                                            |
| 4    | DWE   |         | Write Protect - Block 4                                      |
| 4    | RWE   |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[3]: WP_BLK_3                                            |
| 3    | RWE   |         | Write Protect - Block 3                                      |
| 3    | RVVE  |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[2]: WP_BLK_2                                            |
| 2    | RWE   |         | Write Protect - Block 2                                      |
| 2    | RVVE  |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[1]: WP_BLK_1                                            |
| 4    | D\A/E |         | Write Protect - Block 1                                      |
| 1    | RWE   |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |
|      |       |         | MR12[0]: WP_BLK_0                                            |
| 0    | RWE   |         | Write Protect - Block 0                                      |
| 0    | NVVE  |         | 0 = Not Protected                                            |
|      |       |         | 1 = Protected                                                |

<sup>1.</sup> Once any register bit is set to '1', it can only be cleared when the SPD5 Hub device is in offline tester mode of operation.

<sup>2.</sup> The write (or update) transaction to this register must be followed by STOP operation to allow SPD5 Hub device to update the setting.



#### **Table 97. MR13**

| Addr | MR13  |         | NVM Protection Configuration For Blocks [15:8] <sup>1,2</sup> |
|------|-------|---------|---------------------------------------------------------------|
| Bits | Attr  | Default | Description                                                   |
|      |       |         | MR13[7]: WP_BLK_15                                            |
| 7    | DWE   |         | Write Protect - Block 15                                      |
| 7    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[6]: WP_BLK_14                                            |
| 0    | DIAG  |         | Write Protect - Block 14                                      |
| 6    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[5]: WP_BLK_13                                            |
| -    | DIAG  |         | Write Protect - Block 13                                      |
| 5    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[4]: WP_BLK_12                                            |
| 4    | DIAG  |         | Write Protect - Block 12                                      |
| 4    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[3]: WP_BLK_11                                            |
| 2    | DIAG  |         | Write Protect - Block 11                                      |
| 3    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[2]: WP_BLK_10                                            |
| 2    | DWE   |         | Write Protect - Block 10                                      |
| 2    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[1]: WP_BLK_9                                             |
| 4    | DWE   |         | Write Protect - Block 9                                       |
| 1    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |
|      |       |         | MR13[0]: WP_BLK_8                                             |
| 0    | D\M/E |         | Write Protect - Block 8                                       |
| 0    | RWE   |         | 0 = Not Protected                                             |
|      |       |         | 1 = Protected                                                 |

<sup>1.</sup> Once any register bit is set to '1', it can only be cleared when the SPD5 Hub device is in offline tester mode of operation.

<sup>2.</sup> The write (or update) transaction to this register must be followed by STOP operation to allow SPD5 Hub device to update the setting.



#### **Table 98. MR14**

| Addr | MR14 |         | Device Configuration - Local Interface <sup>1,2</sup> |
|------|------|---------|-------------------------------------------------------|
| Bits | Attr | Default | Description                                           |
| 7:6  | RV   | 0       | MR14[7:6]: Reserved                                   |
|      | RWE  | 0       | MR14[5]: LOCAL_INF_PULLUP_CONF                        |
| _    |      |         | Local Interface - Pull Up Resistor Configuration      |
| 5    |      |         | 0 = Internal (on die) Pullup Resistor <sup>3</sup>    |
|      |      |         | 1 = External (board) Pullup Resistor                  |
| 4:0  | RV   | 0       | MR14[4:0]: DO NOT USE                                 |

- 1. DIMM Vendor configures this register during assembly based on the DIMM design. After SPD Hub device is powered up, the Host can alter the setting through this register.
- 2. The write (or update) transaction to this register must be followed by STOP operation to allow SPD5 Hub device to update the setting.
- 3. Typical value of on die pullup resistor is 1 K $\Omega$ . The minimum and maximum on die pullup resistor value is 750  $\Omega$  and 1.5 K $\Omega$  respectively.

#### **Table 99. MR15**

| Addr | MR15 |         | DO NOT USE            |
|------|------|---------|-----------------------|
| Bits | Attr | Default | Description           |
| 7:0  | RV   | 0       | MR15[7:0]: DO NOT USE |



#### **Table 100. MR18**

| Addr | MR18 |         | Device Configuration <sup>1</sup>                                      |
|------|------|---------|------------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                            |
|      |      |         | MR18[7]: PEC_EN                                                        |
| 7    | BO   | 0       | PEC Enable <sup>2,3</sup>                                              |
| /    | RO   | 0       | 0 = Disable                                                            |
|      |      |         | 1 = Enable                                                             |
|      |      |         | MR18[6]: PAR_DIS                                                       |
| 6    | RO   | 0       | Parity (T bit) Disable <sup>3,4</sup>                                  |
| 0    | KO   | U       | 0 = Enable                                                             |
|      |      |         | 1 = Disable                                                            |
|      |      |         | MR18[5]: INF_SEL                                                       |
| E    | BO   | 0       | Interface Selection                                                    |
| 5    | RO   | 0       | 0 = I <sup>2</sup> C Protocol (Max speed of 1 MHz)                     |
|      |      |         | 1 = I3C Basic Protocol <sup>5</sup>                                    |
|      |      |         | MR18[4]: DEF_RD_ADDR_POINT_EN                                          |
|      |      |         | Default Read Address Pointer Enable                                    |
| 4    | RW   | 0       | 0 = Disable Default Read Address Pointer (Address pointer is set       |
| 4    | KVV  | U       | by the Host) <sup>6</sup>                                              |
|      |      |         | 1 = Enable Default Read Address Pointer; Address selected by           |
|      |      |         | register bits [3:2]                                                    |
|      |      |         | MR18[3:2]: DEF_RD_ADDR_POINT_START                                     |
|      |      |         | Default Read Pointer Starting Address <sup>7</sup>                     |
| 3:2  | RW   | 00      | 00 = <i>MR4</i> 9                                                      |
|      |      |         | 01 = Reserved                                                          |
|      |      |         | 1x = Reserved                                                          |
|      |      |         | MR18[1]: DEF_RD_ADDR_POINT_BL                                          |
| 1    | RW   | 0       | Burst Length for Read Pointer Address for PEC Calculation <sup>8</sup> |
| 1    |      | 0       | 0 = 2 Bytes                                                            |
|      |      |         | 1 = 4 Bytes                                                            |
| 0    | RV   | 0       | MR18[0]: Reserved                                                      |

- The write (or update) transaction to this register must be followed by STOP operation to allow the SPD5 Hub device to update the setting.
- 2. This register is only applicable if MR18[5] = '1'.
- 3. This register is updated when RSTDAA CCC is registered by SPD5 Hub device or when SPD5 Hub device goes through bus reset as described in Section 5.4.
- 4. This register is only applicable if *MR18*[5] = '1'. When Parity function is disabled, the SPD5 Hub device simply ignores the 'T' bit information from the Host. The Host may actually choose to compute the parity and send that information in 'T' bit or simply drive static low or high in 'T' bit.
- 5. This register is automatically updated when SETAASA CCC or RSTDAA CCC is registered by the SPD5 Hub device or when SPD5 Hub device goes through bus reset as described in Section 5.4. This register can be read by the Host through normal Read operation but it cannot be written with normal write operation either in I<sup>2</sup>C mode or I3C Basic mode of operation. When this register is updated, it takes in effect when there is a next START operation (i.e. after STOP operation).
- 6. The setting in register MR18[3:1] is don't care.
- 7. This register is only applicable if MR18[4] = '1'.
- 8. This register is only applicable if *MR18*[7, 4] = '11'.



## **Table 101. MR19**

| Addr | MR19 |         | Clear Register Command <sup>1</sup>           |
|------|------|---------|-----------------------------------------------|
| Bits | Attr | Default | Description                                   |
| 7:4  | RV   | 0       | MR19[7:4]: Reserved                           |
|      |      |         | MR19[3]: CLR_TS_CRIT_LOW                      |
| 3    | 10   | 0       | Clear Temperature Sensor Critical Low Status  |
|      |      |         | 1 = Clear <i>MR51</i> [3] Register            |
|      |      |         | MR19[2]: CLR_TS_CRIT_HIGH                     |
| 2    | 10   | 0       | Clear Temperature Sensor Critical High Status |
|      |      |         | 1 = Clear <i>MR51</i> [2] Register            |
|      |      |         | MR19[1]: CLR_TS_LOW                           |
| 1    | 10   | 0       | Clear Temperature Sensor Low Status           |
|      |      |         | 1 = Clear <i>MR51</i> [1] Register            |
|      |      |         | MR19[0]: CLR_TS_HIGH                          |
| 0    | 10   | 0       | Clear Temperature Sensor High Status          |
|      |      |         | 1 = Clear <i>MR51</i> [0] Register            |

<sup>1.</sup> This entire register is self-clearing register after corresponding register is cleared.

## **Table 102. MR20**

| Addr | MR20 |         | Clear Register Command <sup>1</sup>                            |
|------|------|---------|----------------------------------------------------------------|
| Bits | Attr | Default | Description                                                    |
|      |      |         | MR20[7]: CLR_SPD_BUSY_ERROR                                    |
| 7    | 10   | 0       | Clear Write or Read Attempt while SPD Device Busy Error Status |
|      |      |         | 1 = Clear <i>MR</i> 52[7] Register                             |
|      |      |         | MR20[6]: CLR_WR_NVM_BLK_ERROR                                  |
| 6    | 10   | 0       | Clear Write Attempt to Protected NVM Block Error Status        |
|      |      |         | 1 = Clear <i>MR</i> 52[6] Register                             |
|      |      |         | MR20[5]: CLR_WR_NVM_PRO_REG_ERROR                              |
| 5    | 10   | 0       | Clear Write Attempt to NVM Protection Register Error Status    |
|      |      |         | 1 = Clear <i>MR</i> 52[5] Register                             |
| 4:3  | RV   | 0       | MR20[4:2]: Reserved                                            |
|      |      |         | MR20[1]: CLR_PEC_ERROR                                         |
| 1    | 10   | 0       | Clear Packet Error Status                                      |
|      |      |         | 1 = Clear <i>MR</i> 52[1] Register                             |
|      |      |         | MR20[0]: CLR_PAR_ERROR                                         |
| 0    | 10   | 0       | Clear Parity Error Status                                      |
|      |      |         | 1 = Clear <i>MR</i> 52[0] Register                             |

<sup>1.</sup> This entire register is self-clearing register after corresponding register is cleared.



#### **Table 103. MR26**

| Addr | MR26 |         | Thermal Sensor Configuration              |
|------|------|---------|-------------------------------------------|
| Bits | Attr | Default | Description                               |
| 7:1  | RV   | 0       | MR26[7:1] Reserved                        |
|      | RW   | 0       | MR26[0]: DIS_TS                           |
| 0    |      |         | Disable Temperature Sensor <sup>1,2</sup> |
| U    |      |         | 0 = Enable thermal sensor                 |
|      |      |         | 1 = Disable thermal sensor                |

- 1. This register is only applicable if MR1[7:0] programmed value is 0x18.
- 2. If this bit is set to '1' and then reset to '0', the Host must wait minimum of t<sub>INIT</sub> before accessing samples on the thermal sensor.

**Table 104. MR27** 

| Addr | MR27   |         | Interrupt Configuration                                                               |                                                                      |                                                                    |
|------|--------|---------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------|
| Bits | Attr   | Default | Description                                                                           |                                                                      |                                                                    |
|      | 7 10 0 |         | MR27[7]: CLR_GLOBAL                                                                   |                                                                      |                                                                    |
| 7    |        |         | Global Clear Event Status and In Band Interrupt Status1,2                             |                                                                      |                                                                    |
|      |        |         | 1 = Clear MR48[7], MR51[3:0] and MR52[7:5, 1:0] Register                              |                                                                      |                                                                    |
| 6:5  | RV     | 0       | MR27[6:5]: Reserved                                                                   |                                                                      |                                                                    |
|      |        |         | MR27[4]: IBI_ERROR_EN                                                                 |                                                                      |                                                                    |
| 4    | RO     | 0       | In Band Error Interrupt Enable for MR52 Error Log3                                    |                                                                      |                                                                    |
| 4    | KO     | 0       | 0 = Disable; Errors logged in MR52[7:5, 1:0] registers do not generate an IBI to Host |                                                                      |                                                                    |
|      |        |         | 1 = Enable; Errors logged in MR52[7:5, 1:0] registers generates an IBI to Host        |                                                                      |                                                                    |
|      |        |         | MR27[3]: IBI_TS_CRIT_LOW_EN                                                           |                                                                      |                                                                    |
|      | 3 RW 0 | D\\\    | D\A/                                                                                  | 0                                                                    | In Band Error Interrupt Enable for Temperature Sensor Critical Low |
| 3    |        | U       | 0 = Disable; MR51[3] = '1' does not generate an IBI to Host                           |                                                                      |                                                                    |
|      |        |         | 1 = Enable; MR51[3] = '1' and MR27[4] = '1' generates an IBI to Host                  |                                                                      |                                                                    |
|      |        |         | MR27[2]: IBI_TS_CRIT_HIGH_EN                                                          |                                                                      |                                                                    |
| 2    | RW 0   | 0       | In Band Error Interrupt Enable for Temperature Sensor Critical High                   |                                                                      |                                                                    |
|      |        | 0       | 0 = Disable; MR51[2] = '1' does not generate an IBI to Host                           |                                                                      |                                                                    |
|      |        |         |                                                                                       | 1 = Enable; MR51[2] = '1' and MR27[4] = '1' generates an IBI to Host |                                                                    |
|      |        |         | MR27[1]: IBI_TS_LOW_EN                                                                |                                                                      |                                                                    |
| 1    | RW     | 0       | In Band Error Interrupt Enable for Temperature Sensor Low                             |                                                                      |                                                                    |
| '    | IXVV   | 0       | 0 = Disable; MR51[1] = '1' does not generate an IBI to Host                           |                                                                      |                                                                    |
|      |        |         | 1 = Enable; MR51[1] = '1' and MR27[4] = '1' generates an IBI to Host                  |                                                                      |                                                                    |
|      | 0 RV 0 |         | MR27[0]: IBI_TS_HIGH_EN                                                               |                                                                      |                                                                    |
| 0    |        | 0       | In Band Error Interrupt Enable for Temperature Sensor High                            |                                                                      |                                                                    |
|      | IXV    |         | 0 = Disable; MR51[0] = '1' does not generate an IBI to Host                           |                                                                      |                                                                    |
|      |        |         | 1 = Enable; MR51[0] = '1' and MR27[4] = '1' generates an IBI to Host                  |                                                                      |                                                                    |

- 1. This register is a self-clearing register after corresponding registers are cleared. Writing '0' in this register has no effect.
- 2. After this command is issued, the device does not generate an IBI for any pending event. But if new event occurs, the device does generate an IBI.
- 3. This register is automatically updated when ENEC CCC or DISEC CCC or RSTDAA CCC is registered by the SPD5 Hub device or when SPD5 Hub device goes through bus reset as described in Section 5.4. This register can be read by the Host through normal read operation but cannot be written with normal write operation either in I<sup>2</sup>C mode or I3C Basic mode. When this register is updated, it takes effect when there is a next START operation (i.e. after STOP operation).



#### **Table 105. MR28**

| Addr | MR28 |         | Thermal Sensor High Limit Configuration - Low Byte 1,2,3            |
|------|------|---------|---------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                         |
|      | RW   | 0x70    | MR28[7:0]: TS_HIGH_LIMIT_LOW                                        |
| 7:0  |      |         | MR28 and MR29 - 16 bits thermal registers define the high limit for |
|      |      |         | thermal sensor.                                                     |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.            |

- 1. This entire register is only applicable if MR1[7:0] programmed value is 0x18.
- Critical temperature High Limit value must have a higher value than temperature High Limit (MR28[7:0] and MR29[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.

#### **Table 106. MR29**

| Addr | MR29 |         | Thermal Sensor High Limit Configuration - High Byte <sup>1,2,3</sup>                |
|------|------|---------|-------------------------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                                         |
|      | RW   | 0x03    | MR29[7:0]: TS_HIGH_LIMIT_HIGH                                                       |
| 7:0  |      |         | MR28 and MR29 - 16 bits thermal registers define the high limit for thermal sensor. |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                            |

- 1. This entire register is only applicable if MR1[7:0] programmed value is 0x18.
- 2. Critical temperature High Limit value must have a higher value than temperature High Limit (MR28[7:0] and MR29[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.

#### **Table 107. MR30**

| Addr | MR30 |         | Thermal Sensor Low Limit Configuration - Low Byte 1,2,3                                                                                                                   |
|------|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                                                                                                                               |
| 7:0  | RW   | 0       | MR30[7:0]: TS_LOW_LIMIT_LOW  MR30 and MR31 - 16 bits thermal registers define the low limit for thermal sensor.  See Table 86. Thermal Register - Low Byte and High Byte. |

- 1. This entire register is only applicable if MR1[7:0] programmed value is 0x18.
- Critical temperature Low Limit value must have a lower value than temperature Low Limit (MR30[7:0] and MR31[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.

#### **Table 108. MR31**

| Addr | MR31 |         | Thermal Sensor Low Limit Configuration - High Byte <sup>1,2,3</sup> |
|------|------|---------|---------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                         |
| 7:0  | RW   | 0       | MR31 [7:0]: TS_LOW_LIMIT_HIGH                                       |
|      |      |         | MR30 and MR31 - 16 bits thermal registers define the low limit for  |
|      |      |         | thermal sensor.                                                     |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.            |

- 1. This entire register is only applicable if *MR1*[7:0] programmed value is 0x18.
- 2. Critical temperature Low Limit value must have a lower value than temperature Low Limit (MR30[7:0] and MR31[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.



#### **Table 109. MR32**

| Addr | MR32 |         | Thermal Sensor Critical Temperature High Limit Configuration - Low Byte 1,2,3            |  |  |  |  |  |
|------|------|---------|------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bits | Attr | Default | Description                                                                              |  |  |  |  |  |
|      |      |         | MR32 7:0]: TS_CRIT_HIGH_LIMIT_LOW                                                        |  |  |  |  |  |
| 7:0  | RW   | 0x50    | MR32 and MR33 - 16 bits thermal registers define the critical temperature high limit for |  |  |  |  |  |
| 7.0  |      | 0x30    | thermal sensor.                                                                          |  |  |  |  |  |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                                 |  |  |  |  |  |

- 1. This entire register is only applicable if MR1[7:0] programmed value is 0x18.
- Critical temperature High Limit value must have a higher value than temperature High Limit (MR28[7:0] and MR29[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.

#### **Table 110. MR33**

| Addr | MR33 |         | Thermal Sensor Critical Temperature High Limit Configuration - High Byte <sup>1,2,3</sup> |  |  |  |  |  |
|------|------|---------|-------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bits | Attr | Default | Description                                                                               |  |  |  |  |  |
|      |      |         | MR33[7:0]: TS_CRIT_HIGH_LIMIT_HIGH                                                        |  |  |  |  |  |
| 7:0  | RW   | V 0x05  | MR32 and MR33 - 16 bits thermal registers define the critical temperature high limit for  |  |  |  |  |  |
| 7.0  |      |         | thermal sensor.                                                                           |  |  |  |  |  |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                                  |  |  |  |  |  |

- 1. This entire register is only applicable if MR1[7:0] programmed value is 0x18.
- Critical temperature High Limit value must have a higher value than temperature High Limit (MR28[7:0] and MR29[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.

**Table 111. MR34** 

| Addr | MR34 |         | Thermal Sensor Critical Temperature Low Limit Configuration - Low Byte 1,2,3            |  |  |  |  |  |
|------|------|---------|-----------------------------------------------------------------------------------------|--|--|--|--|--|
| Bits | Attr | Default | Description                                                                             |  |  |  |  |  |
|      | RW   | 0       | MR34[7:0]: TS_CRIT_LOW_LIMIT_LOW                                                        |  |  |  |  |  |
| 7.0  |      |         | MR34 and MR35 - 16 bits thermal registers define the critical temperature low limit for |  |  |  |  |  |
| 7:0  |      |         | thermal sensor.                                                                         |  |  |  |  |  |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                                |  |  |  |  |  |

- 1. This entire register is only applicable if MR1[7:0] programmed value is 0x18.
- 2. Critical temperature Low Limit value must have a lower value than temperature Low Limit (MR30[7:0] and MR31[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.

#### **Table 112. MR35**

| Addr | MR35 |         | Thermal Sensor Critical Temperature Low Limit Configuration - High Byte <sup>1,2,3</sup> |  |   |   |                                                                                         |
|------|------|---------|------------------------------------------------------------------------------------------|--|---|---|-----------------------------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                                              |  |   |   |                                                                                         |
|      |      |         | MR35[7:0]: TS_CRIT_LOW_LIMIT_HIGH                                                        |  |   |   |                                                                                         |
| 7:0  | RW   | RW      | ÐΜ                                                                                       |  | 0 | 0 | MR34 and MR35 - 16 bits thermal registers define the critical temperature low limit for |
| 7.0  |      | 100     | thermal sensor.                                                                          |  |   |   |                                                                                         |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                                 |  |   |   |                                                                                         |

- 1. This entire register is only applicable if *MR1*[7:0] programmed value is 0x18.
- 2. Critical temperature Low Limit value must have a lower value than temperature Low Limit (MR30[7:0] and MR31[7:0]).
- 3. The Reserved bits are Read Only bits. The Host must write '0' in reserved bits when writing and device always returns '0' from reserved bits when reads this byte.



#### **Table 113. MR48**

| Addr | MR48 |         | Device Status                                                                                     |
|------|------|---------|---------------------------------------------------------------------------------------------------|
| Bits | Attr | Default | Description                                                                                       |
|      |      |         | MR48[7]: IBI_STATUS                                                                               |
| 7    | RO   | 0       | Device Event In Band Interrupt Status                                                             |
| ,    | INO. | 0       | 0 = No pending IBI                                                                                |
|      |      |         | 1 = Pending IBI                                                                                   |
| 6:4  | RV   | 0       | MR48[6:4]: Reserved                                                                               |
|      |      |         | MR48[3]: WR_OP_STATUS                                                                             |
|      | RO   |         | Write Operation Status                                                                            |
| 3    |      | 0       | 0 = No internal write operation is on-going;                                                      |
| 3    |      |         | 1 = Internal write operation is on-going; Device ignores Host Write command if Host attempts      |
|      |      |         | to write when this bit is '1'. The device self clears this bit to '0' when its completes internal |
|      |      |         | write operation                                                                                   |
|      |      |         | MR48[2]: WP_OVERRIDE_STATUS                                                                       |
|      |      |         | Write Protect Override Status                                                                     |
|      |      |         | 0 = Override of write protect bits in <i>MR12</i> and <i>MR13</i> are blocked                     |
| 2    | RO   | -       | 1 = Override of write protect bits in <i>MR12</i> and <i>MR13</i> are allowed                     |
|      |      |         | The default state of this register reflects the sensing of HSA pin during power on.               |
|      |      |         | This bit is set to '1' if HSA pin is directly tied to GND.                                        |
|      |      |         | This bit is set to '0' if HSA pin is connected to GND through a resistor.                         |
| 1:0  | RV   | 0       | MR48[1:0]: Reserved                                                                               |

#### **Table 114. MR49**

| Addr | MR49 |         | Current Sensed Temperature - Low Byte <sup>1,2</sup>                                       |  |  |  |
|------|------|---------|--------------------------------------------------------------------------------------------|--|--|--|
| Bits | Attr | Default | Description                                                                                |  |  |  |
|      |      |         | MR49[7:0]: TS_SENSE_LOW                                                                    |  |  |  |
| 7:0  | RO   | 0       | MR49 and MR50 - 16 bits thermal registers return the most recent conversion of the thermal |  |  |  |
| 7:0  |      |         | sensor.                                                                                    |  |  |  |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                                   |  |  |  |

- 1. This entire register is only applicable if *MR1*[7:0] programmed value is 0x18.
- 2. The device always returns '0' from reserved bits.

## **Table 115. MR50**

| Addr | MR50 |         | Current Sensed Temperature - High Byte <sup>1,2</sup>                                      |  |  |  |  |  |
|------|------|---------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bits | Attr | Default | Description                                                                                |  |  |  |  |  |
| 7:0  | RO   | 0       | MR50[7:0]: TS_SENSE_HIGH                                                                   |  |  |  |  |  |
|      |      |         | MR49 and MR50 - 16 bits thermal registers return the most recent conversion of the thermal |  |  |  |  |  |
|      |      | 0       | sensor.                                                                                    |  |  |  |  |  |
|      |      |         | See Table 86. Thermal Register - Low Byte and High Byte.                                   |  |  |  |  |  |

- 1. This entire register is only applicable if *MR1*[7:0] programmed value is 0x18.
- 2. The device always returns '0' from reserved bits.



## **Table 116. MR51**

| Addr | MR51 |         | Thermal Sensor Temperature Status <sup>1</sup>                           |    |    |    |   |                                                            |
|------|------|---------|--------------------------------------------------------------------------|----|----|----|---|------------------------------------------------------------|
| Bits | Attr | Default | Description                                                              |    |    |    |   |                                                            |
| 7:4  | RV   | 0       | MR51[7:4]: Reserved                                                      |    |    |    |   |                                                            |
|      |      |         | MR51[3]: TS_CRIT_LOW_STATUS                                              |    |    |    |   |                                                            |
| 3    | RO   | 0       | Temperature Sensor Critical Low                                          |    |    |    |   |                                                            |
| 3    | KO   | 0       | 0 = Temperature is above the limit set in <i>MR34</i> and <i>MR35</i>    |    |    |    |   |                                                            |
|      |      |         | 1 = Temperature is below the limit set in <i>MR34</i> and <i>MR35</i>    |    |    |    |   |                                                            |
|      |      |         | MR51[2]: TS_CRIT_HIGH_STATUS                                             |    |    |    |   |                                                            |
| 2    | RO   | 0       | Temperature Sensor Critical High                                         |    |    |    |   |                                                            |
| 2    |      |         | 0 = Temperature is below the limit set in MR32 and MR33                  |    |    |    |   |                                                            |
|      |      |         | 1 = Temperature is above the limit set in <i>MR32</i> and <i>MR33</i>    |    |    |    |   |                                                            |
|      |      |         | MR51[1]: TS_LOW_STATUS                                                   |    |    |    |   |                                                            |
| 1    | RO   | 0       | Temperature Sensor Low                                                   |    |    |    |   |                                                            |
| '    | RU   | RO      | RO                                                                       | RO | RO | KO | 0 | 0 = Temperature above limit set in registers MR30 and MR31 |
|      |      |         | 1 = Temperature below limit set in registers <i>MR30</i> and <i>MR31</i> |    |    |    |   |                                                            |
|      |      |         | MR51[0]: TS_HIGH_STATUS                                                  |    |    |    |   |                                                            |
| 0    | RO   | 0       | Temperature Sensor High                                                  |    |    |    |   |                                                            |
|      | NO   |         | 0 = Temperature is below the limit set in registers MR28 and MR29        |    |    |    |   |                                                            |
|      |      |         | 1 = Temperature is above the limit set in registers MR28 and MR29        |    |    |    |   |                                                            |

<sup>1.</sup> This entire register is only applicable if *MR1*[7:0] programmed value is 0x18.



#### **Table 117. MR52**

| Addr | MR52   |         | Hub and Thermal Sensor Error Status                                                                 |
|------|--------|---------|-----------------------------------------------------------------------------------------------------|
| Bits | Attr   | Default | Description                                                                                         |
|      |        |         | MR52[7]: BUSY_ERROR_STATUS                                                                          |
| 7    | RO     | 0       | Write or Read Attempt while SPD5 Hub Device was Busy (Write Recovery Time Violation) <sup>1,2</sup> |
| ,    | /   RO | 0       | 0 = No write or read attempt while SPD Hub device was busy                                          |
|      |        |         | 1 = Write or Read attempt while SPD5 Hub device was busy                                            |
|      | 6 RO   |         | MR52[6]: WR_NVM_BLK_ERROR_STATUS                                                                    |
| 6    |        | 0       | Write Attempt to Protected NVM Block                                                                |
| 0    | KO     | 0       | 0 = No write attempt                                                                                |
|      |        |         | 1 = Write attempt to protected NVM Block                                                            |
|      |        |         | MR52[5]: WR_NVM_PRO_REG_ERROR_STATUS                                                                |
| 5    | RO     | 0       | Write Attempt to NVM Protection Registers                                                           |
| 3    | RO     |         | 0 = No attempt to modify write protect registers                                                    |
|      |        |         | 1 = Write attempt to modify write protect registers                                                 |
| 4:2  | RO     | 0       | MR52[4:2]: Reserved                                                                                 |
|      |        |         | MR52[1]: PEC_ERROR_STATUS                                                                           |
| 1    | RO     | 0       | Packet Error <sup>3,4</sup>                                                                         |
| '    | KO     | 0       | 0 = No PEC Error                                                                                    |
|      |        |         | 1 = PEC Error in one or more packets                                                                |
|      |        |         | MR52[0]: PAR_ERROR_STATUS                                                                           |
| 0    | RO     | 0       | Parity Check Error <sup>4,5</sup>                                                                   |
|      | , KO   |         | 0 = No Parity Error                                                                                 |
|      |        |         | 1 = Parity Error in one or more bytes                                                               |

<sup>1.</sup> SPD5 Hub device busy status is only for accessing EEPROM memory. For any access to volatile register space, this bit definition does not apply.

- 2. When SPD5 Hub device is busy with EEPROM write/read, it sends NACK to the Host requests within write recovery time.
- 3. Only applicable MR18[5] = '1' and if PEC function is enabled.
- 4. This register is updated when SPD5 Hub device goes through bus reset as described in Section 5.4.
- 5. Only applicable in MR18[5] = '1' and if Parity function is not disabled or for supported CCC in I<sup>2</sup>C mode.



## 12 Electrical Specifications

## 12.1 Absolute Maximum Ratings

Stressing the device above the rating listed in the Absolute Maximum Ratings table may cause permanent damage to the device. These are stress ratings only and operation of the device at these or any other conditions above those indicated in the Operating sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability.

| Symbol           | Parameter                              | Mix  | Max  | Unit |
|------------------|----------------------------------------|------|------|------|
| T <sub>STG</sub> | Storage temperature                    | -65  | +150 | °C   |
| VDDIO            | Supply voltage                         | -0.5 | +2.1 | V    |
| VDDSPD           | Supply voltage                         | -0.5 | +2.1 | V    |
| Vhsa             | Voltage on HSA Pin                     | -0.5 | +2.1 | V    |
| V <sub>IO</sub>  | Voltage on HSCL, HSDA, LSCL, LSDA Pins | -0.5 | +3.6 | V    |

### 12.2 ESD Ratings

| Symbol           | Parameter     | Test Condition                                                               | Value  | Unit |
|------------------|---------------|------------------------------------------------------------------------------|--------|------|
| \/               | Electrostatic | Human body model (HBM), per ANSI/ESDA/JEDEC JS-001 <sup>1</sup>              | ± 2000 | V    |
| V <sub>ESD</sub> | discharge     | Charged device model (CDM), per JEDEC specification JESD22-C101 <sup>2</sup> | ± 1000 | V    |

<sup>1.</sup> JEDEC document JEP155 states that 500-V HBM allows safe manufacturing with a standard ESD control process.

## 12.3 Operating Condition, Measurement Condition

**Table 118. Operating Condition** 

| Symbol               | Parameter                                                          | Min | Тур | Max  | Unit |
|----------------------|--------------------------------------------------------------------|-----|-----|------|------|
| VDDSPD               | Input Supply Voltage <sup>1</sup>                                  |     | 1.8 | 1.98 | V    |
| VDDIO                | Input Supply Voltage <sup>2</sup>                                  |     | 1.0 | 1.05 | V    |
| TCASE                | Case operating temperature                                         | -40 |     | 125  | °C   |
| т                    | Case temperature range for NVM Write operation                     | -40 |     | 95   | °C   |
| T <sub>WRITEOK</sub> | Data writes outside this range may not meet retention requirements |     |     | 95   |      |

For DDR5 DIMM application, the DDR5 PMIC VOUT\_1.8V setting should be selected such that absolute Min and Max values for SPD Hub specification are not violated.

Table 119, Write Endurance and Data Retention Characteristics

| Symbol          | Parameter                      | Min     | Тур | Max | Unit   |
|-----------------|--------------------------------|---------|-----|-----|--------|
| DR              | Data Retention @ 25 °C         | 100     |     |     | Years  |
| N <sub>W1</sub> | Write Endurance Cycles @ 25 °C | ≥100000 |     |     | Cycles |
| N <sub>W2</sub> | Write Endurance Cycles @ 95 °C | 100000  |     |     | Cycles |

<sup>2.</sup> JEDEC document JEP157 states that 250-V CDM allows safe manufacturing with a standard ESD control process.

<sup>2.</sup> For DDR5 DIMM application, the DDR5 PMIC VOUT\_1.0V setting should be selected such that absolute Min and Max values for SPD Hub specification are not violated.



#### Table 120. AC Measurement Conditions<sup>1</sup>

| Symbol | Parameter                              | Min        | Max | Unit |
|--------|----------------------------------------|------------|-----|------|
| CL     | Load capacitance                       | 40         |     | pF   |
|        | Input rise and fall times - Open Drain |            | TBD | ns   |
|        | Input rise and fall times - Push Pull  |            | TBD | ns   |
|        | Input signal swing levels              | 0.2 to 0.8 |     | V    |
|        | Input levels for timing reference      | 0.3 to 0.7 |     | V    |

1. This AC measurement condition (Figure 17and Table 120) is only for the test purpose in lab.



Figure 17. AC Measurement Waveform

**Table 121. Input Parameters** 

| Symbol          | Parameter <sup>1,2</sup>                                | Test Condition             | Min | Max | Unit |
|-----------------|---------------------------------------------------------|----------------------------|-----|-----|------|
| C <sub>IN</sub> | Input capacitance (HSDA, HSCL, LSDA)                    |                            |     | 5   | pF   |
| +               | Pulse width of spikes which must be                     | Single glitch, f ≤ 100 KHz |     |     | ns   |
| tsp             | suppressed by the input filter in I <sup>2</sup> C mode | Single glitch, f > 100 KHz | 0   | 50  | ns   |

- 1.  $T_A = 25 \,^{\circ}\text{C}$ ,  $f = 400 \,\text{kHz}$
- 2. Verified by design and characterization, not necessarily tested on all devices.

#### **Table 122. Output Ron Specification**

| Symbol              | Parameter <sup>1</sup>                                 | Min | Max | Unit |
|---------------------|--------------------------------------------------------|-----|-----|------|
| R <sub>on_PUH</sub> | HSDA Output Pullup Driver Impedance                    | 10  | 45  | Ohm  |
| R <sub>on_PDH</sub> | HSDA Output Pulldown Driver Impedance                  | 10  | 40  | Ohm  |
| Ron_Local           | LSCL, LSDA Output Pullup and Pulldown Driver Impedance | 20  | 100 | Ohm  |

1. Pulldown  $R_{on} = V_{out} / I_{out}$ ; Pullup  $R_{on} = (V_{IO} - V_{out}) / I_{out}$ 



#### 12.4 DC Characteristics

| Symbol           | Parameter                                    | Test Condition                               | Min   | Max | Unit   |
|------------------|----------------------------------------------|----------------------------------------------|-------|-----|--------|
| ILI              | Input Leakage Current                        |                                              |       | ± 5 | μA     |
| I <sub>LO</sub>  | Output Leakage Current                       |                                              |       | ± 5 | μA     |
| I <sub>DDR</sub> | Supply Current, Read Operation <sup>1</sup>  | $V_{DDSPD}$ = 1.8V, $f_{C}$ = 12.5 MHz       |       | 2   | mA     |
| I <sub>DDW</sub> | Supply Current, Write Operation <sup>1</sup> | $V_{DDSPD}$ = 1.8V, $f_{C}$ = 12.5 MHz       |       | 3   | mA     |
| I <sub>DD1</sub> | Standby Supply Current                       | $V_{IN} = V_{DDSPD} = 1.8V$                  |       | 50  | μA     |
| VIL              | Input Low Voltage                            |                                              | -0.35 | 0.3 | ٧      |
| ViH              | Input High Voltage                           |                                              | 0.7   | 3.6 | ٧      |
| Vol              | Output Low Voltage <sup>2</sup>              | 3 mA sink current                            |       | 0.3 | V      |
| V <sub>OH</sub>  | Output High Voltage                          | 3 mA source current                          | 0.75  |     | V      |
| l                | Output Low Current                           | V <sub>OL</sub> = 0.3V                       | -3    |     | m 1    |
| lol              | (HSDA, LSDA, LSCL)                           | VOL - 0.3V                                   | -3    |     | mA     |
| Іон              | Output High Current                          | V <sub>OH</sub> = V <sub>DDIO</sub> - 0.3V   |       | -3  | mA     |
| ЮН               | (HSDA, LSDA, LSCL)                           | VOH - VDDIO - U.3 V                          |       | -3  | IIIA   |
| SR <sub>R</sub>  | Rising Output Slew Rate <sup>3</sup>         |                                              | 0.1   | 1.0 | V/ns   |
| SKR              | (HSDA, LSDA, LSCL)                           |                                              | 0.1   | 1.0 | V/115  |
| SR₅              | Falling Output Slew Rate <sup>3</sup>        |                                              | 0.1   | 3.0 | V/ns   |
| SK⊦              | (HSDA, LSDA, LSCL)                           |                                              | 0.1   | 3.0 | V/115  |
| V <sub>PON</sub> | Power On Reset Threshold                     | Monotonic rise between V <sub>PON</sub>      | 1.6   |     | \<br>\ |
| V PON            |                                              | and V <sub>DDSPD(min)</sub> without ringback | 1.0   |     | V      |
| VPOFF            | Power Off Threshold for Warm Power On        | No ringback above VP <sub>OFF</sub>          |       | 0.3 | V      |
| VPOFF            | Cycle                                        | INO IIIIgback above VFOFF                    |       | 0.5 | v      |

- 1. Thermal sensor is active.
- 2. Example calculation for  $V_{OL}$ =  $R_{on}$  \* ( $I_{leakage}$  +  $I_{out}$ ); where  $I_{out}$  =  $V_{DDIO}$ / ( $R_{pu}$  +  $R_{on}$ );  $R_{pu}$  = Pullup resistor with typical value of 1K $\Omega$ ; Min and Max value of 750  $\Omega$  and 1.5 K $\Omega$ , respectively.
- Output slew rate is guaranteed by design and / or characterization. The output slew rate reference load is shown in Figure 20. I2C Bus AC Data Output Timing Parameter Definition
- 4. and Figure 21. Output Slew Rate and Output Timing Reference Load
- 5. shows the timing measurement points. For slew rate measurements, the V<sub>OH</sub> level shown in Figure 21. *Output Slew Rate and Output Timing Reference Load*
- 6. is a function of  $R_{on}$  value;  $V_{OH} = \{1.0 / (R_{on} + 50)\} * 50$ .



## 12.5 AC Characteristics

| Symbol                    | Parameter                                                           |                 | lode -<br>Drain | I3C Basic -<br>Push-Pull <sup>1</sup> |                   |      |  |
|---------------------------|---------------------------------------------------------------------|-----------------|-----------------|---------------------------------------|-------------------|------|--|
| Cymbol                    | T diamotor                                                          |                 | Max             | Min                                   | Max               | Unit |  |
| fscL                      | Clock Frequency                                                     | <b>Min</b> 0.01 | 1               | 0                                     | 12.5              | MHz  |  |
| thigh                     | Clock Pulse Width High Time                                         | 260             |                 | 35                                    |                   | ns   |  |
| t <sub>LOW</sub>          | Clock Pulse Width Low Time                                          | 500             |                 | 35                                    |                   | ns   |  |
| tтімеоит                  | Detect Clock Low Timeout                                            | 10              | 50              | 10                                    | 50                | ms   |  |
| t <sub>R</sub>            | SDA Rise Time <sup>2,3</sup>                                        |                 | 120             |                                       | 5                 | ns   |  |
| t <sub>F</sub>            | SDA Fall Time <sup>2,3</sup>                                        |                 | 120             |                                       | 5                 | ns   |  |
| tsu:dat                   | Data In Set-up Time <sup>2</sup>                                    | 50              |                 | 8                                     |                   | ns   |  |
| t <sub>HD:DI</sub>        | Data In Hold Time <sup>2</sup>                                      | 0               |                 | 3                                     |                   | ns   |  |
| tsu:sta                   | Start Condition Setup Time <sup>2</sup>                             | 260             |                 | 12                                    |                   | ns   |  |
| thd:sta                   | Start Condition Hold Time <sup>2</sup>                              | 260             |                 | 30                                    |                   | ns   |  |
| tsu:sto                   | Stop Condition Setup Time <sup>2</sup>                              | 260             |                 | 12                                    |                   | ns   |  |
| t <sub>BUF</sub>          | Time between Stop Condition and next Start Condition <sup>2,4</sup> | 500             |                 | 500                                   |                   | ns   |  |
| t <sub>W</sub>            | Write Time                                                          | See M           | ı<br>aximum F   | Recovery                              | Time in           | MR6  |  |
| tpoff                     | Warm Power Cycle Off Time                                           | 1               |                 | 1                                     |                   | ms   |  |
|                           | Time from Valid 1.8V Supply to Sense HSA Pin for HID                |                 |                 |                                       |                   |      |  |
| $t_{\sf Sense\_HSA}$      | Code Assignment                                                     |                 | 5               |                                       | 5                 | ms   |  |
| t <sub>INIT</sub>         | Time from Power On to First Command                                 | 10              |                 | 10                                    |                   | ms   |  |
|                           | Bus Available Time (No Edges Seen on HSDA and                       |                 |                 |                                       |                   |      |  |
| taval                     | HSCL)                                                               |                 |                 | 1                                     |                   | μs   |  |
|                           | Time to Issue IBI after an Event is Detected when Bus is            |                 |                 |                                       | 4.5               |      |  |
| t <sub>IBI_ISSUE</sub>    | Available                                                           |                 |                 |                                       | 15                | μs   |  |
|                           | Time from Clear Register Status to any I3C Operation                |                 |                 |                                       |                   |      |  |
|                           | with Start Condition to Avoid IBI Generation; PEC                   |                 |                 | 4                                     |                   | μs   |  |
|                           | Disabled                                                            |                 |                 |                                       |                   |      |  |
| tCLR_I3C_CMD_Delay        | Time from Clear Register Status to any I3C Operation                |                 |                 |                                       |                   |      |  |
|                           | with Start Condition to Avoid IBI Generation; PEC                   |                 |                 | 15                                    |                   | μs   |  |
|                           | Enabled                                                             |                 |                 |                                       |                   |      |  |
| t <sub>PDHL</sub>         | Propagation Delay, HSDA to LSDA and HSCL to LSCL <sup>5</sup>       |                 | 200             |                                       | 6                 | ns   |  |
| t <sub>PDLH</sub>         | Propagation Delay, LSDA to HSDA <sup>5</sup>                        |                 | 200             |                                       | 6                 | ns   |  |
| t <sub>HD:DAT</sub>       | HSCL Falling Clock In to HSDA Data Out Hold Time <sup>6</sup>       | 0.5             | 350             | N/A                                   | N/A               | ns   |  |
| t <sub>DOUT</sub>         | HSCL Falling Clock In to HSDA Valid Data Out Time <sup>7</sup>      | N/A             | N/A             | 0.5                                   | 12                | ns   |  |
| t <sub>DOFFT</sub>        | HSCL Rising Clock In to SDA Output Off8                             | N/A             | N/A             | 0.5                                   | 12                | ns   |  |
| t <sub>DOFFC</sub>        | HSCL Rising Clock In to Controller SDA Output Off <sup>9</sup>      | N/A             | N/A             | 0.5                                   | t <sub>HIGH</sub> | ns   |  |
| t <sub>CL_r_DAT_f</sub>   | HSCL Rising Clock In to Controller Driving HSDA Low <sup>10</sup>   | N/A             | N/A             | 40                                    |                   | ns   |  |
| tprivotpi coo pri vi      | DEVCTRL CCC Followed by DEVCTRL CCC or Register                     | 3               |                 | 3                                     |                   | 110  |  |
| tdevctrlccc_delay_pec_dis | Read/Write Command Delay <sup>11,12,13</sup>                        | ა<br>           |                 | <u> </u>                              |                   | μs   |  |
| twr_rd_delay_pec_en       | Register Write Command Followed by Register Read                    | N/A             | N/A             | 8                                     |                   | μs   |  |



| Symbol                            | Parameter                                             |     | I <sup>2</sup> C Mode -<br>Open Drain |     | I3C Basic -<br>Push-Pull <sup>1</sup> |      |
|-----------------------------------|-------------------------------------------------------|-----|---------------------------------------|-----|---------------------------------------|------|
|                                   |                                                       | Min |                                       | Min | Max                                   | Unit |
|                                   | Command Delay in PEC Enabled Mode <sup>14,15,16</sup> |     |                                       |     |                                       |      |
| t                                 | SETHID CCC or SETAASA CCC to any other CCC or         | 2.5 |                                       |     |                                       |      |
| ti2C_CCC_Update_Delay             | Read/Write Command Delay                              | 2.5 |                                       |     |                                       | μs   |
| t                                 | RSTDAA CCC or ENEC CCC or DISEC CCC to any            |     |                                       | 2.5 |                                       | 116  |
| t <sub>I3C_CCC_Update_Delay</sub> | other CCC or Read/Write Command Delay                 |     |                                       | 2.5 |                                       | μs   |
| t <sub>CCC_Delay</sub>            | Any CCC to RSTDAA CCC delay                           | N/A | N/A                                   | 2.5 |                                       | μs   |

- 1. I3C mode with Open Drain operation follows timing values as shown in I2C Mode Open Drain column.
- 2. See Figure 18 for input timing parameter definition.
- 3. See Figure 22. Output Slew Rate Measurement Points
- 4. for voltage threshold definition for rise and fall times.
- 5. If PEC is enabled, two rd delay pec en timing parameter also applies.
- 6. See Figure 27 for timing definition. See Figure 20. I2C Bus AC Data Output Timing Parameter Definition
- 7. for output timing parameter measurement reference load.
- 8. See Figure 19. I3C Basic Bus AC Data Output Timing Parameter Definition
- for output timing parameter definition.
- 10. The SPD5 Hub device must be in configured in I3C Basic mode to guarantee t<sub>DOUT</sub> value. See Figure 18. *I2C or I3C Basic Bus AC Input Timing Parameter Definition*
- 11. for output timing parameter definition. See Figure 20. I2C Bus AC Data Output Timing Parameter Definition
- 12. for output timing parameter measurement reference load.
- 13. The SPD5 Hub device must be configured in I3C Basic mode to guarantee t<sub>DOFFT</sub> value. See Figure 8. See Figure 20. I2C Bus AC Data Output Timing Parameter Definition
- 14. for output timing parameter measurement reference load. Also refer to MIPI Alliance Specification for *I3C Basic Version* 1.0-19 July 2018, section 5.1.2.3.2, Transition from Address ACK to Mandatory Byte during IBI.
- 15. The SPD5 Hub device must be configured in I3C Basic mode. The Host guarantees t<sub>DOFFC</sub> value. See Figure 8. *Target Open Drain to Host Push Pull Hand Off Operation*
- 16. See Figure 20. I2C Bus AC Data Output Timing Parameter Definition
- 17. for output timing parameter measurement reference load.
- 18. See Figure 11.
- From STOP condition of DEVCTRL CCC to START condition for Register Read or Register Write Command Data Packet delay.
- 20. The SPD5 Hub device may send ACK or NACK if Host does not satisfy tDEVCTRLCCC DELAY PEC DIS timing parameter.
- 21. This timing parameter restriction is only applicable when PEC function is disabled in SPD5 Hub. If PEC is enabled, this timing parameter does not apply.
- From STOP condition for Register Write Command Data Packet to START condition for Register Read Command Data Packet delay.
- 23. This timing parameter restriction is only applicable when PEC function is enabled in SPD5 Hub. If PEC is disabled, this timing parameter does not apply.
- 24. The SPD5 Hub device may send ACK or NACK if Host does not satisfy two RD DELAY PEC EN timing parameter.



## 12.6 AC Timing Definition

## 12.6.1 I<sup>2</sup>C or I3C Basic Bus Timing

The SPD5 Hub device follows the I<sup>2</sup>C or I3C Basic bus timing requirements. The Figure 18. *I2C or I3C Basic Bus AC Input Timing Parameter Definition* 

show the timing diagram for Data Bus Input and Data Output parameters.



Figure 18. I<sup>2</sup>C or I3C Basic Bus AC Input Timing Parameter Definition



Figure 19. I3C Basic Bus AC Data Output Timing Parameter Definition



Figure 20. I<sup>2</sup>C Bus AC Data Output Timing Parameter Definition





Figure 21. Output Slew Rate and Output Timing Reference Load



Figure 22. Output Slew Rate Measurement Points



Figure 23. Rise and Fall Timing Parameter Definition

#### **HSCL Non Monotonicity**

Due to non-deterministic loading (number of DIMMs populated) on an unterminated bus, there can be reflections on the bus, causing slope reversal on the HSCL signal on the input receiver of the SPD5 HUB.

The SPD5 Hub device must tolerate t<sub>SLPR</sub> and t<sub>SLPR\_PK2PK</sub> slope reversal on HSCL in I3C mode as shown in Figure 24 to Figure 26.



| Symbol     | Parameter                                                                          |   | Max. | Unit |
|------------|------------------------------------------------------------------------------------|---|------|------|
| tslpr      | Pulse width of slope reversal which must be suppressed <sup>1,2</sup>              | 0 | 2.6  | ns   |
| SLPR_PK2PK | The Peak to Peak voltage of slope reversal which must be suppressed <sup>1,2</sup> | 0 | 150  | mV   |

- 1. Verified by design and characterization, not necessarily tested on all devices.
- 2. These parameters apply in I3C mode.



Figure 24. Slope Reversal on HSCL at VIH

Note: tpdhl is for reference only in this diagram; refer to measurement methodology for details on this parameter.



Figure 25. Slope Reversal on HSCL between VIL and VIH

Note: tpdhl is for reference only in this diagram; refer to measurement methodology for details on this parameter.





Figure 26. Slope Reversal on HSCL at VIL

Note: tpdhl is for reference only in this diagram; refer to measurement methodology for details on this parameter.

#### 12.6.2 Hub Propagation Delay

The SPD5 Hub device has a propagation delay of tpdHL for its host interface HSCL/HSDA input signals to the local interface LSCL/LSDA signals respectively.

Similarly, the SPD5 Hub device has a propagation delay of tpDLH for its local interface LSDA input signal to the host interface HSDA signal.





Figure 27. Propagation Delay through the SPD5 Hub Device



## 12.7 Temperature Sensor Performance

**Table 124. Temperature Sensor Performance** 

| Symbol            | Parameter                             | Test Condition                  | Min | Тур  | Max  | Unit |
|-------------------|---------------------------------------|---------------------------------|-----|------|------|------|
|                   | Temperature Sensor Accuracy           | +75°C ≤ T <sub>A</sub> ≤ +95°C  |     | ±0.5 | ±1.0 | °C   |
|                   | (Active Range)                        | +73 C 3 TA 3 +93 C              |     | ±0.5 | ±1.0 | )    |
| T                 | Temperature Sensor Accuracy           | +40°C ≤ T <sub>A</sub> ≤ +125°C |     | ±1.0 | ±2.0 | °C   |
| TACC              | (Monitor Range)                       |                                 |     | ±1.0 | ±2.0 | C    |
|                   | Temperature Sensor Accuracy           | -40°C ≤ T <sub>A</sub> ≤ +125°C |     | ±2.0 | ±3.0 | °C   |
|                   | (Industrial Temperature Range)        | -40 C S TA S + 123 C            |     | ±2.0 | ±3.0 | C    |
| R <sub>TS</sub>   | Temperature Sensor Resolution         |                                 |     | 0.25 |      | °C   |
| t <sub>CONV</sub> | Conversion Time                       | Assumes 0.25 °C accuracy        |     |      | 68   | ms   |
| T <sub>HYST</sub> | Hysteresis between temperature events |                                 | 1   |      |      | °C   |



## 13 Package Information



## NOTES:

- 1. All dimensions are in millimeters.
- 2. Package dimensions does not include mold flash, protrusions, or gate burrs.
- 3. Refer to the Table 125. UDFN dimensions(mm).



## Table 125. UDFN dimensions(mm)

| SYMBOL | MIN  | TYP      | MAX  |
|--------|------|----------|------|
| А      | 0.70 | 0.75     | 0.80 |
| A1     | 0    | 0.02     | 0.05 |
| b      | 0.18 | 0.25     | 0.30 |
| С      | 0.18 | 0.20     | 0.25 |
| D      | 1.90 | 2.00     | 2.10 |
| D2     | 1.40 | 1.50     | 1.60 |
| е      |      | 0.50 BSC |      |
| Nd     |      | 1.50 BSC |      |
| Е      | 2.90 | 3.00     | 3.10 |
| E2     | 1.50 | 1.60     | 1.70 |
| L      | 0.30 | 0.40     | 0.50 |
| h      | 0.20 | 0.25     | 0.30 |



## 14 Ordering Information

| Ordering Code    | Package Type | ECO Plan        | Packing Type      | MOQ   | OP Temp(°C)     |      |            |
|------------------|--------------|-----------------|-------------------|-------|-----------------|------|------------|
| GD30PD5118WETR-I | UDFN         | Green Tape & Re | Croon Tong & Dool | C**** | Tape & Reel     | 3000 | Industrial |
| GD30PD3116WETR-I | ODFN         | Green           | iape α Reei       | 3000  | -40°C to +125°C |      |            |



# 15 Revision History

| REVISION NUMBER | DESCRIPTION                        | DATE |
|-----------------|------------------------------------|------|
| 1.0             | Initial release and device details | 2024 |



## **Important Notice**

This document is the property of GigaDevice Semiconductor Inc. and its subsidiaries (the "Company"). This document, including any product of the Company described in this document (the "Product"), is owned by the Company according to the laws of the People's Republic of China and other applicable laws. The Company reserves all rights under such laws and no IntellectµAl Property Rights are transferred (either wholly or partially) or licensed by the Company (either expressly or impliedly) herein. The names and brands of third party referred thereto (if any) are the property of their respective owner and referred to for identification purposes only.

The Company makes no representations or warranties of any kind, express or implied, with regard to the merchantability and the fitness for a particular purpose of the Product, nor does the Company assume any liability arising out of the application or use of any Product described in this document. Any information provided in this document is provided only for reference purposes. It is the sole responsibility of the user of this document to determine whether the Product is suitable and fit for its applications and products planned, and properly design, program, and test the functionality and safety of its applications and products planned using the Product. Unless otherwise expressly specified in the datasheet of the Product, the Product is designed, developed, and/or manufactured for ordinary business, industrial, personal, and/or household applications only, and the Product is not designed or intended for use in (i) safety critical applications such as weapons systems, nuclear facilities, atomic energy controller, combustion controller, aeronautic or aerospace applications, traffic signal instruments, pollution control or hazardous substance management; (ii) life-support systems, other medical equipment or systems (including life support equipment and surgical implants); (iii) automotive applications or environments, including but not limited to applications for active and passive safety of automobiles (regardless of front market or aftermarket), for example, EPS, braking, ADAS (camera/fusion), EMS, TCU, BMS, BSG, TPMS, Airbag, Suspension, DMS, ICMS, Domain, ESC, DCDC, e-clutch, advancedlighting, etc.. Automobile herein means a vehicle propelled by a self-contained motor, engine or the like, such as, without limitation, cars, trucks, motorcycles, electric cars, and other transportation devices; and/or (iv) other uses where the failure of the device or the Product can reasonably be expected to result in personal injury, death, or severe property or environmental damage (collectively "Unintended Uses"). Customers shall take any and all actions to ensure the Product meets the applicable laws and regulations. The Company is not liable for, in whole or in part, and customers shall hereby release the Company as well as its suppliers and/or distributors from, any claim, damage, or other liability arising from or related to all Unintended Uses of the Product. Customers shall indemnify and hold the Company, and its officers, employees, subsidiaries, affiliates as well as its suppliers and/or distributors harmless from and against all claims, costs, damages, and other liabilities, including claims for personal injury or death, arising from or related to any Unintended Uses of the Product.

Information in this document is provided solely in connection with the Product. The Company reserves the right to make changes, corrections, modifications or improvements to this document and the Product described herein at any time without notice. The Company shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them. Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2024 GigaDevice - All rights reserved