

---

---

# DFI

## DDR PHY Interface



**DFI 5.2 Specification**  
**OCTOBER 15, 2024**

---



---



---

| Release Information |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev #               | Date        | Change                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1.0                 | 30 Jan 2007 | Initial Release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2.0                 | 17 Jul 2007 | Modifications/Additions for DDR3 Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2.0                 | 21 Nov 2007 | Additional modifications/additions for DDR3 support. Added read and write leveling. Changes approved by the Technical Committee for DDR3 support.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2.0                 | 21 Dec 2007 | Removed references to data eye training for PHY Evaluation mode, added a gate training-specific mode signal, corrected references and clarified read <u>training</u> .                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2.0                 | 11 Jan 2008 | Modified wording; standardized notations in figures, clarified terminology for read and write leveling.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2.0                 | 26 Mar 2008 | Added timing parameter $t_{rdlvl\_en}$ and $t_{wrlvl\_en}$ , signal $dfi\_rdlvl\_edge$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2.1                 | 2 Oct 2008  | Added initial LPDDR2 support and corrected minor errors from 2.0 release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2.1                 | 24 Nov 2008 | Added frequency change protocol, signal timing definitions, $t_{rdlvl\_load}$ and $t_{wrlvl\_load}$ timing parameters and adjusted diagrams accordingly.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2.1                 | 30 Jan 2009 | Added DFI logo.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2.1                 | 31 Mar 2009 | Updated width of $dfi\_rdlvl\_edge$ , corrected erroneous figures, updated $t_{rdlvl\_en}$ and $t_{wrlvl\_en}$ definitions.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2.1                 | 20 May 2009 | Added low power control interface, modified leveling request signal description to include frequency change, added $dfi\_data\_byte\_disable$ signal and $t_{phy\_wrdata}$ timing parameters. Added DIMM support to the status interface and updated frequency ratios from an example to a defined method. Updated frequency ratios information for new proposals, modified default values and requirements for some training interface signals, incorporated LPDDR2 training operations changes                                                                              |
| 2.1                 | 22 Jun 2009 | Expanded frequency ratio information to include vectored read data, expanded use of $dfi\_init\_start$ , added timing diagrams for 1:4 frequency ratio systems                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2.1.1               | 23 Mar 2010 | Added reference to the parity interface to the Overview. Changed $dfi\_parity\_in$ signal to have a phase index. Modified description of $dfi\_freq\_ratio$ signal to make it optional except for MCs/PHYs that support multiple frequency ratios. Expanded figure 32 into two figures to represent odd and even timing parameters.                                                                                                                                                                                                                                           |
| 2.1.1               | 01 Apr 2010 | Changed minimum value for $t_{lp\_wakeup}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2.1.1               | 20 Apr 2010 | Corrected figure 3 timing violation. Corrected erroneous sentence for 2T timing. Corrected figure 35 $t_{phy\_wrlat}$ timing. Correct incorrect references to $t_{phy\_wrlat}$ in frequency ratio read examples.                                                                                                                                                                                                                                                                                                                                                              |
| 2.1.1               | 27 May 2010 | Added Figure 4 and text to explain differences between Figure 3 and 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2.1.1               | 09 Jun 2010 | Modified text in $dfi\_init\_start$ and surrounding figures 3 and 4 for more clarity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3.0                 | 21 May 2012 | Added DDR4 DRAM support for: CRC, CA parity timing, CRC and CA parity errors, DBI, leveling support, and CA modifications. Added DFI read data rotation clarification, read data pointer resynchronization, independent timing of DFI read data valid per data slice, data path chip select, error interface, and programmable parameters. Renamed PHY evaluation mode. Removed MC evaluation mode and $t_{phy\_wrdelay}$ timing parameter. Added support for refresh during training, multiple CS training, enhancements to the update interface and the idle bus definition |
| 3.1                 | 19 May 2012 | Added support for LPDDR3. Enhanced the Low Power Control Interface to have separate control and data requests. Added the PHY-Requested Training Interface to enable PHY-independent training in non-DFI training mode.                                                                                                                                                                                                                                                                                                                                                        |
| --                  | 14 Nov 2013 | Synchronized book files to 3.1 in advance of upcoming changes from JM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

---



---

|     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| --  | 21 Nov 2013 | Incorporated review corrections.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| --  | 21 Mar 2014 | Incorporated committee comments, corrected erroneous cross references, fine-tuned formatting, fine-tuned typographical items.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4.0 | 04 Aug 2017 | Merged DFI 4.0 Spec Addendum to DFI 3.1. Added support for LPDDR4, DB training, per-slice read leveling, DFI read/write chip select, write DQ training, PHY master interface, frequency indicator, DFI disconnect protocol, DFI data bit disabling, slice parameter, geardown mode, DFI feature and matrix topology matrix, 3D stack support and inactive CS support. Also modified CA training, write leveling strobe and changed the DFI training to be optional. Enhanced DFI read data eye training sequence, update interface for self-refresh exit |
|     | 20 Jul 2017 | Incorporated review changes from 4.0 Addendum merge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5.0 | 27 Apr 2018 | Corrected formatting, spelling and content errors from 4.0 version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5.1 | 26 Mar 2021 | Incorporated new proposals for DFI 5.1, standardized look and feel of all figures, added new signals and updated tables as a result.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5.2 | 19 Aug 2024 | Incorporated new proposals for DFI 5.2, corrected spelling errors, Added MRDIMM support, LPDDR5 BL32 Support, Support for different DFI ratios on the Command and Data Interfaces, renamed the PHY Master Interface to the PHY Managed Interface.                                                                                                                                                                                                                                                                                                        |

---

#### Proprietary Notice

No part of this document may be copied or reproduced in any form or by any means without prior written consent of Cadence.

Cadence makes no warranties with respect to this documentation and disclaims any implied warranties of merchantability or fitness for a particular purpose. Information in this document is subject to change without notice. Cadence assumes no responsibility for any errors that may appear in this document.

Except as may be explicitly set forth in such agreement, Cadence does not make, and expressly disclaims, any representations or warranties as to the completeness, accuracy, or usefulness of the information contained in this document. Cadence does not warrant that use of such information will not infringe any third party rights, nor does Cadence assume any liability for damages or costs of any kind that may result from use of such information.

© Copyright 2021 Cadence Design Systems, Inc. All rights reserved worldwide. Portions of this material are © JEDEC Solid State Technology Association. All rights reserved. Reprinted with permission.

#### RESTRICTED RIGHTS LEGEND

Use, duplication, or disclosure by the Government is subject to restrictions as set forth in subparagraphs (c)(1)(ii) of the Rights in Technical Data and Computer Software clause at DFARS 252.227-7013.

#### Destination Control Statement

All technical data contained in this product is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### Trademarks

Cadence and the Cadence logo are registered trademarks of Cadence Design Systems, Inc.

All other products or brand names mentioned are trademarks or registered trademarks of their respective holders.

#### End User License Agreement2

1. Subject to the provisions of Clauses 2, 3, 4, 5 and 6, Cadence hereby grants to licensee ("Licensee") a perpetual, nonexclusive, nontransferable, royalty free, worldwide copyright license to use and copy the DFI (DDR PHY Interface) specification (the "DFI Specification") for the purpose of developing, having developed, manufacturing, having manufactured, offering to sell, selling, supplying or otherwise distributing products which comply with the DFI

---

---

Specification.

2.THE DFI SPECIFICATION IS PROVIDED "AS IS" WITH NO WARRANTIES EXPRESS, IMPLIED OR STATUTORY, INCLUDING BUT NOT LIMITED TO ANY WARRANTY OF SATISFACTORY QUALITY, MERCHANTABILITY, NONINFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE.

3.No license, express, implied or otherwise, is granted to Licensee, under the provisions of Clause 1, to use Cadence's or any other person or entity participating in the development of the DFI Specification listed herein (individually "Participant," collectively "Participants") trade name, or trademarks in connection with the DFI Specification or any products based thereon. Nothing in Clause 1 shall be construed as authority for Licensee to make any representations on behalf of Cadence or the other Participants in respect of the DFI Specification.

4.NOTWITHSTANDING ANYTHING ELSE WILL CADENCE'S TOTAL AGGREGATE LIABILITY FOR ANY CLAIM, SUIT, PROCEEDING OR OTHERWISE, RELATING IN ANYWAY TO THE DFI SPECIFICATION EXCEED \$1.00USD.

5.NOTWITHSTANDING ANYTHING ELSE WILL ANY PARTICIPANT'S TOTAL AGGREGATE LIABILITY FOR ANY CLAIM, SUIT, PROCEEDING OR OTHERWISE, RELATING IN ANYWAY TO THE DFI SPECIFICATION EXCEED \$1.00USD.

6.Licensee agrees that Cadence and the Participants may use, copy, modify, reproduce and distribute any written comments or suggestions ("Communications") provided regarding the DFI Specification by Licensee and that Licensee will not claim any proprietary rights in the DFI Specification, or implementations thereof by any Participant or third party, as a result of the use of the Communications in developing or changing the DFI Specification. Cadence and the participants will have no confidentiality obligations with respect to the Communications and Licensee will not include any confidential information of Licensee or any third party in any Communications.

Participants

AMD     ARM     Broadcom     Cadence     Intel     Samsung     ST     Synopsys     Uniquify

---

---

# Contents

---

|            |                                            |           |
|------------|--------------------------------------------|-----------|
| <b>1.0</b> | <b>Overview</b>                            | <b>17</b> |
| <b>2.0</b> | <b>Architecture</b>                        | <b>18</b> |
| <b>2.1</b> | <b>Clocking</b>                            | <b>18</b> |
| <b>2.2</b> | <b>Optional Protocols</b>                  | <b>22</b> |
| <b>2.3</b> | <b>DFI Feature Requirements</b>            | <b>23</b> |
| 2.3.1      | Global Features                            | 23        |
| 2.3.2      | Memory Topology-Specific Features          | 23        |
| 2.3.3      | DFI Signals                                | 25        |
| <b>2.4</b> | <b>Definition of a Slice</b>               | <b>35</b> |
| <b>3.0</b> | <b>Interface Signal Groups</b>             | <b>36</b> |
| <b>3.1</b> | <b>Command Interface</b>                   | <b>36</b> |
| 3.1.1      | Mapping the CA Bus to the dfi_address Bus. | 36        |
| 3.1.2      | Clock Disabling                            | 38        |
| 3.1.3      | Frequency Ratio Systems                    | 38        |
| 3.1.4      | CA Parity and Parity/CRC Errors            | 38        |
| 3.1.5      | 2N Mode Interface                          | 38        |
| 3.1.6      | DDR5 CS Geardown Mode Interface            | 39        |
| 3.1.7      | Command Signals and Parameters             | 40        |
| <b>3.2</b> | <b>Write Data Interface</b>                | <b>44</b> |
| 3.2.1      | Write Data Mask/Write DBI                  | 44        |
| 3.2.2      | Write Data Chip Select                     | 45        |
| 3.2.3      | Write Data CRC                             | 45        |
| 3.2.3.1    | Write DRAM CRC                             | 45        |
| 3.2.3.2    | Write Link CRC                             | 46        |
| 3.2.4      | Frequency Ratio                            | 47        |
| 3.2.5      | MRDIMM Mux Mode                            | 47        |
| 3.2.6      | Write Data Signals and Parameters          | 47        |

---

---

|             |                                                        |           |
|-------------|--------------------------------------------------------|-----------|
| <b>3.3</b>  | <b>Read Data Interface . . . . .</b>                   | <b>51</b> |
| 3.3.1       | Read DBI . . . . .                                     | 51        |
| 3.3.2       | Read Data CRC . . . . .                                | 51        |
| 3.3.2.1     | Read DRAM CRC . . . . .                                | 51        |
| 3.3.2.2     | Read Link CRC . . . . .                                | 52        |
| 3.3.3       | Read Data Chip Select . . . . .                        | 52        |
| 3.3.4       | Read Data Valid . . . . .                              | 52        |
| 3.3.5       | Frequency Ratio . . . . .                              | 53        |
| 3.3.6       | MRDIMM Mux Mode . . . . .                              | 53        |
| 3.3.7       | Read Data Signals and Parameters . . . . .             | 53        |
| <b>3.4</b>  | <b>Update Interface . . . . .</b>                      | <b>56</b> |
| <b>3.5</b>  | <b>Status Interface . . . . .</b>                      | <b>61</b> |
| 3.5.1       | Initialization . . . . .                               | 61        |
| 3.5.2       | Reduced Data Buses . . . . .                           | 61        |
| 3.5.3       | Frequency Ratio . . . . .                              | 62        |
| 3.5.4       | Frequency Change . . . . .                             | 62        |
| 3.5.5       | Frequency Indicator . . . . .                          | 62        |
| 3.5.6       | Status Interface Signals and Parameters . . . . .      | 63        |
| <b>3.6</b>  | <b>Low Power Control Interface . . . . .</b>           | <b>68</b> |
| <b>3.7</b>  | <b>Error Interface . . . . .</b>                       | <b>76</b> |
| <b>3.8</b>  | <b>PHY Managed Interface . . . . .</b>                 | <b>77</b> |
| 3.8.1       | Inactive Chip Selects . . . . .                        | 77        |
| 3.8.2       | PHY Managed Interface Signals and Parameters . . . . . | 78        |
| <b>3.9</b>  | <b>Disconnect Protocol . . . . .</b>                   | <b>81</b> |
| <b>3.10</b> | <b>MC to PHY Message Interface . . . . .</b>           | <b>83</b> |
| <b>3.11</b> | <b>WCK Control Interface . . . . .</b>                 | <b>84</b> |
| <b>3.12</b> | <b>Channels for Multi-Channel Memories . . . . .</b>   | <b>86</b> |
| <b>3.13</b> | <b>Link ECC . . . . .</b>                              | <b>88</b> |
| <b>3.14</b> | <b>Link DQ CRC . . . . .</b>                           | <b>89</b> |
| <b>4.0</b>  | <b>Functional Use . . . . .</b>                        | <b>91</b> |

---

---

|            |                                                       |            |
|------------|-------------------------------------------------------|------------|
| <b>4.1</b> | <b>Initialization .....</b>                           | <b>91</b>  |
| <b>4.2</b> | <b>PHY Independent Training Boot Sequence.....</b>    | <b>92</b>  |
| 4.2.1      | Refresh Requirements .....                            | 93         |
| 4.2.2      | Boot Into Self-Refresh.....                           | 93         |
| <b>4.3</b> | <b>Command Interface Signals .....</b>                | <b>93</b>  |
| <b>4.4</b> | <b>DFI Clock Disabling.....</b>                       | <b>95</b>  |
| <b>4.5</b> | <b>3DS Stack Support.....</b>                         | <b>96</b>  |
| 4.5.1      | 3DS Addressing with dfi_cid and dfi_cs for DDR3 ..... | 96         |
| 4.5.2      | 3DS Addressing with dfi_cid and dfi_cs for DDR4 ..... | 97         |
| <b>4.6</b> | <b>Data Bus Inversion.....</b>                        | <b>97</b>  |
| <b>4.7</b> | <b>Write Transactions.....</b>                        | <b>98</b>  |
| 4.7.1      | Write Transaction Sequence .....                      | 98         |
| 4.7.2      | DBI - Write .....                                     | 104        |
| 4.7.3      | Link ECC - Write.....                                 | 105        |
| 4.7.4      | Write Data Interleaving .....                         | 105        |
| 4.7.5      | Cyclic Redundancy Check - Write .....                 | 106        |
| 4.7.5.1    | DRAM CRC .....                                        | 106        |
| 4.7.5.1.1  | MC CRC Support (phycrc_mode = 0) .....                | 107        |
| 4.7.5.1.2  | PHY CRC Support (phycrc_mode = 1) .....               | 109        |
| 4.7.5.1.3  | Burst Chop 4 with PHY CRC Support .....               | 110        |
| 4.7.5.2    | Write Link CRC .....                                  | 111        |
| 4.7.6      | CA Bus Timing .....                                   | 112        |
| 4.7.6.1    | LPDDR2 / LPDDR3 Memories .....                        | 113        |
| 4.7.6.2    | LPDDR4 Memories .....                                 | 114        |
| 4.7.6.3    | LPDDR5 Memories .....                                 | 114        |
| 4.7.6.4    | DDR5 Memories Without RCD .....                       | 117        |
| 4.7.6.5    | DDR5 Memories With RCD.....                           | 121        |
| 4.7.6.6    | DDR5 MRDIMM Memories .....                            | 123        |
| <b>4.8</b> | <b>Read Transactions .....</b>                        | <b>127</b> |
| 4.8.1      | Read Transaction Sequence.....                        | 128        |

---

---

|             |                                                                   |            |
|-------------|-------------------------------------------------------------------|------------|
| 4.8.2       | DBI - Read . . . . .                                              | 134        |
| 4.8.2.1     | MC DBI Support (phydbi_mode = 0) . . . . .                        | 134        |
| 4.8.2.2     | PHY DBI Support (phydbi_mode = 1) . . . . .                       | 134        |
| 4.8.3       | Link ECC - Read . . . . .                                         | 134        |
| 4.8.4       | Read Data Interleaving . . . . .                                  | 135        |
| 4.8.5       | Cyclic Redundancy Check - Read . . . . .                          | 138        |
| 4.8.5.1     | DRAM CRC . . . . .                                                | 138        |
| 4.8.5.2     | Read Link CRC . . . . .                                           | 138        |
| <b>4.9</b>  | <b>Update . . . . .</b>                                           | <b>139</b> |
| 4.9.1       | MC-Initiated Update . . . . .                                     | 139        |
| 4.9.2       | PHY-Initiated Update . . . . .                                    | 140        |
| 4.9.3       | DFI Bus Idle . . . . .                                            | 141        |
| <b>4.10</b> | <b>Frequency Ratios Across the DFI . . . . .</b>                  | <b>142</b> |
| 4.10.1      | Frequency Ratio Clock Definition . . . . .                        | 143        |
| 4.10.2      | Interface Signals with Frequency Ratio Systems . . . . .          | 144        |
| 4.10.3      | Write Data Interface in Frequency Ratio Systems . . . . .         | 147        |
| 4.10.4      | Read Data Interface in Frequency Ratio Systems . . . . .          | 150        |
| 4.10.4.1    | DFI Read Data Rotation . . . . .                                  | 157        |
| 4.10.4.2    | Read Data Resynchronization . . . . .                             | 161        |
| 4.10.4.3    | DFI Read Data Rotation in Large Frequency Ratio Systems . . . . . | 161        |
| <b>4.11</b> | <b>Frequency Change . . . . .</b>                                 | <b>166</b> |
| 4.11.1      | Frequency Change Protocol - Acknowledged . . . . .                | 167        |
| 4.11.2      | Frequency Change Request Protocol - Not Acknowledged . . . . .    | 168        |
| <b>4.12</b> | <b>CA Parity Signaling and CA Parity, CRC Errors . . . . .</b>    | <b>169</b> |
| 4.12.1      | CA Parity Timing . . . . .                                        | 170        |
| 4.12.2      | CA Parity and CRC Errors . . . . .                                | 170        |
| 4.12.3      | CA Parity and CRC Errors in Frequency Ratio Systems . . . . .     | 170        |
| <b>4.13</b> | <b>Low Power Control Handshaking . . . . .</b>                    | <b>172</b> |
| <b>4.14</b> | <b>Error Signaling . . . . .</b>                                  | <b>176</b> |
| <b>4.15</b> | <b>PHY Control of the DFI Bus . . . . .</b>                       | <b>177</b> |

---

---

|                                                                                  |            |
|----------------------------------------------------------------------------------|------------|
| <b>4.16 DFI Disconnect Protocol .....</b>                                        | <b>179</b> |
| 4.16.1 Update Interface.....                                                     | 179        |
| 4.16.2 PHY Managed Interface .....                                               | 180        |
| <b>4.17 2N Mode .....</b>                                                        | <b>181</b> |
| 4.17.1 Use of 2N Mode.....                                                       | 181        |
| 4.17.2 Use of DDR5 CS Geardown Mode with 2N Mode.....                            | 184        |
| <b>4.18 Use of the MC to PHY Message Interface .....</b>                         | <b>186</b> |
| 4.18.1 Timing Diagram.....                                                       | 187        |
| 4.18.2 PHY Messages.....                                                         | 187        |
| 4.18.3 Information Data Signal .....                                             | 188        |
| <b>4.19 Use of the WCK Control Interface.....</b>                                | <b>188</b> |
| <b>4.20 Channel Operation for Multi-Channel Memories .....</b>                   | <b>191</b> |
| 4.20.1 Fully Independent Operation.....                                          | 191        |
| 4.20.2 Fully Combined Operation .....                                            | 192        |
| 4.20.3 Semi-Independent Operation.....                                           | 193        |
| 4.20.4 Multi-Configuration Support.....                                          | 194        |
| <b>4.21 DFI Interactions .....</b>                                               | <b>196</b> |
| <b>4.22 MRDIMM Memories with Pseudo-Channels .....</b>                           | <b>199</b> |
| 4.22.1 Write Transaction Timing .....                                            | 200        |
| 4.22.2 Read Transaction Timing.....                                              | 202        |
| 4.22.3 Read Transaction Considerations for Pseudo-Channels .....                 | 206        |
| <b>4.23 Use of the dfi_rddata_cs / dfi_wrdata_cs Signal with DDR5 DIMMs.....</b> | <b>208</b> |
| 4.23.1 Example 1 .....                                                           | 209        |
| 4.23.2 Example 2 .....                                                           | 209        |
| <b>5.0 Signal Timing.....</b>                                                    | <b>211</b> |
| <b>6.0 Glossary .....</b>                                                        | <b>214</b> |



---

---

# List of Figures

---

|            |                                                                                                                                    |     |
|------------|------------------------------------------------------------------------------------------------------------------------------------|-----|
| FIGURE 1.  | Block Diagram of Interface Signals: Command, Write Data, Read Data, Update, Status, PHY Managed, Disconnect and Error .....        | 26  |
| FIGURE 2.  | Block Diagram of Interface Signals: Low Power Control, MC to PHY Message and WCK Control .....                                     | 27  |
| FIGURE 3.  | Link DQ CRC Packet .....                                                                                                           | 90  |
| FIGURE 4.  | Dependency on dfi_init_complete .....                                                                                              | 91  |
| FIGURE 5.  | System Setting Signals - dfi_init_start Asserts Before dfi_init_complete .....                                                     | 92  |
| FIGURE 6.  | MC De-Asserting dfi_reset_n and/or Asserting dfi_cke along with dfi_init_start ..                                                  | 92  |
| FIGURE 7.  | DFI Command Interface Signal Relationships .....                                                                                   | 94  |
| FIGURE 8.  | Example of tcmd_lat (tcmd_lat = 1, tphy_wrlat = 2) .....                                                                           | 95  |
| FIGURE 9.  | DRAM Clock Disable Behavior .....                                                                                                  | 96  |
| FIGURE 10. | Back-to-Back Writes (DRAM Burst of 4: tphy_wrlat = 0, tphy_wrdata = 1) .....                                                       | 100 |
| FIGURE 11. | Back-to-Back Interrupted Contiguous Writes (DRAM Burst of 8: tphy_wrlat = 3, tphy_wrdata = 2) .....                                | 101 |
| FIGURE 12. | Back-to-Back Writes (DRAM Burst of 8: tphy_wrlat = 4, tphy_wrdata = 4) .....                                                       | 101 |
| FIGURE 13. | Two Independent Writes (DRAM Burst of 4: tphy_wrlat = 0, tphy_wrdata = 1) ..                                                       | 102 |
| FIGURE 14. | Two Independent Writes (DRAM Burst of 4: tphy_wrlat = 3, tphy_wrdata = 1) ..                                                       | 102 |
| FIGURE 15. | Two Independent Writes (DRAM Burst of 8: tphy_wrlat = 3, tphy_wrdata = 3) ..                                                       | 103 |
| FIGURE 16. | Two Independent Writes (DRAM Burst of 4: tphy_wrlat = 3, tphy_wrdata = 4) ..                                                       | 103 |
| FIGURE 17. | Write Commands Utilizing dfi_wrdata_cs (DRAM Burst of 4: tphy_wrlat = 3, tphy_wrdat = 4, tphy_wrcslat = 2, tphy_wrcsgap = 1) ..... | 104 |
| FIGURE 18. | LPDDR4 Write Command .....                                                                                                         | 104 |
| FIGURE 19. | Link ECC with Write Commands .....                                                                                                 | 105 |
| FIGURE 20. | Non-Interleaved Write Commands (LPDDR5 Example) .....                                                                              | 106 |
| FIGURE 21. | Interleaved Write Commands (LPDDR5 Example) .....                                                                                  | 106 |
| FIGURE 22. | DFI Write Data Bus for MC CRC Support Mode (Two Bursts starting in Phase 0)                                                        | 108 |
| FIGURE 23. | DFI Write Data Bus for MC CRC Support Mode (Two Back-to-Back Bursts) ..                                                            | 109 |

---

---

|                                                                                                      |     |
|------------------------------------------------------------------------------------------------------|-----|
| FIGURE 24. DFI Write Data Bus for PHY CRC Support Mode .....                                         | 110 |
| FIGURE 25. DFI Write Data Bus for PHY CRC Support Mode with Burst Chop .....                         | 111 |
| FIGURE 26. Link CRC with Write Commands .....                                                        | 112 |
| FIGURE 27. LPDDR2 / LPDDR3 Read Timing with a 1:1 Command and 1:1 Data Frequency Ratio .....         | 114 |
| FIGURE 28. LPDDR4 Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....                  | 114 |
| FIGURE 29. LPDDR5 Read Timing With a 1:1 Command and 1:2 Data Frequency Ratio .....                  | 115 |
| FIGURE 30. LPDDR5 Read Timing With a 1:1 Command and 1:4 Data Frequency Ratio .....                  | 115 |
| FIGURE 31. LPDDR5 Read Timing With a 1:2 Command and 1:4 Data Frequency Ratio .....                  | 116 |
| FIGURE 32. LPDDR5 Write Timing With a 1:1 Command and 1:2 Data Frequency Ratio .....                 | 116 |
| FIGURE 33. LPDDR5 Write Timing With a 1:1 Command and 1:4 Data Frequency Ratio .....                 | 117 |
| FIGURE 34. LPDDR5 Write Timing With a 1:2 Command and 1:4 Data Frequency Ratio .....                 | 117 |
| FIGURE 35. DDR5 without RCD 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....     | 118 |
| FIGURE 36. DDR5 without RCD 2N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....     | 118 |
| FIGURE 37. DDR5 without RCD 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio .....     | 119 |
| FIGURE 38. DDR5 1N without RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio ..... | 119 |
| FIGURE 39. DDR5 without RCD 2N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....    | 120 |
| FIGURE 40. DDR5 without RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....    | 120 |
| FIGURE 41. DDR5 without RCD 2N Write Timing with a 1:4 Command and 1:4 Data Frequency Ratio .....    | 121 |
| FIGURE 42. DDR5 with RCD 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....        | 121 |
| FIGURE 43. DDR5 with RCD 2N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....        | 122 |

---

---

---

|                                                                                                         |     |
|---------------------------------------------------------------------------------------------------------|-----|
| FIGURE 44. DDR5 with RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....          | 122 |
| FIGURE 45. DDR5 with RCD 2N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio .....          | 123 |
| FIGURE 46. DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio .....    | 124 |
| FIGURE 47. DDR5 MRDIMM Mux Mode 1N Write Timing with a 1:4 Command and 1:4 Data Frequency Ratio .....   | 125 |
| FIGURE 48. DDR5 MRDIMM Mux Mode 2N Read Timing with a 1:2 Command and 1:4 Data Frequency Ratio .....    | 126 |
| FIGURE 49. DDR5 MRDIMM Mux Mode 2N Write Timing with a 1:2 Command and 1:4 Data Frequency Ratio .....   | 127 |
| FIGURE 50. Single Read Transaction of 2 Data Words .....                                                | 129 |
| FIGURE 51. Single Read Transaction of 4 Data Words .....                                                | 129 |
| FIGURE 52. Back-to-Back Read Transactions with First Read Burst Interrupted (DDR1 Example BL = 8) ..... | 130 |
| FIGURE 53. Two Independent Read Transactions (DDR1 Example) .....                                       | 130 |
| FIGURE 54. Two Independent Read Transactions (DDR2 Example) .....                                       | 131 |
| FIGURE 55. Two Independent Read Transactions (DDR2 Example) .....                                       | 131 |
| FIGURE 56. Two Independent Read Transactions (DDR3 Example) .....                                       | 132 |
| FIGURE 57. Example MRR Transactions with LPDDR2 .....                                                   | 132 |
| FIGURE 58. DFI Read Data Transfer Illustrating dfi_rddata_valid Definition .....                        | 133 |
| FIGURE 59. Read Commands Utilizing dfi_rddata_cs .....                                                  | 133 |
| FIGURE 60. LPDDR4 Read Command .....                                                                    | 134 |
| FIGURE 61. Link ECC with Read Commands .....                                                            | 135 |
| FIGURE 62. Non-Interleaved Read Commands (LPDDR5 Example) .....                                         | 136 |
| FIGURE 63. Interleaved Read Commands (LPDDR5 Example) .....                                             | 137 |
| FIGURE 64. Interleaved Read Commands with Transmission Delay (LPDDR5 Example) .....                     | 138 |
| FIGURE 65. Link CRC with Read Commands .....                                                            | 139 |
| FIGURE 66. MC-Initiated Update Timing Diagram .....                                                     | 140 |

---

---

|                                                                                                                         |     |
|-------------------------------------------------------------------------------------------------------------------------|-----|
| FIGURE 67. MC-Initiated Update with No Response .....                                                                   | 140 |
| FIGURE 68. PHY-Initiated Update Timing Diagram .....                                                                    | 141 |
| FIGURE 69. DFI Bus Idle State Timing Parameter - twrdata_delay .....                                                    | 142 |
| FIGURE 70. Frequency Ratio 1:2 Phase Definition .....                                                                   | 143 |
| FIGURE 71. Frequency Ratio 1:4 Phase Definition .....                                                                   | 143 |
| FIGURE 72. Mixed Frequency Ratio Phase Definition .....                                                                 | 143 |
| FIGURE 73. Example 1:2 Command Frequency Ratio Command Stream .....                                                     | 145 |
| FIGURE 74. Example 1:4 Command Frequency Ratio Command Stream .....                                                     | 146 |
| FIGURE 75. 1:2 Command and 1:2 Data Frequency Ratio Write Data Example .....                                            | 147 |
| FIGURE 76. 1:2 Command and 1:2 Data Frequency Ratio Aligned Write Data Example .....                                    | 148 |
| FIGURE 77. 1:2 Command and 1:2 Data Frequency Ratio Aligned Write Enable Example .....                                  | 149 |
| FIGURE 78. LPDDR4 Write Command, 1:2 Command and 1:2 Data Frequency Ratio (tphy_wrdata = 0) .....                       | 150 |
| FIGURE 79. 1:2 Command and 1:2 Data Frequency Ratio Single Read Data Example with Even Read Data to Enable Timing ..... | 152 |
| FIGURE 80. 1:2 Command and 1:2 Data Frequency Ratio Single Read Data Example with Odd Read Data to Enable Timing .....  | 153 |
| FIGURE 81. 1:4 Command and 1:4 Data Frequency Ratio Single Read Data Example .....                                      | 154 |
| FIGURE 82. 1:2 Command and 1:2 Data Frequency Ratio Multiple Read Data Example .....                                    | 155 |
| FIGURE 83. 1:4 Command and 1:4 Data Frequency Ratio Multiple Read Data Example .....                                    | 156 |
| FIGURE 84. LPDDR4 Read Command, 1:2 Command and 1:2 Data Frequency Ratio .....                                          | 157 |
| FIGURE 85. DFI Read Data Bus for Two 10UI Bursts, each starting in Phase 0 .....                                        | 158 |
| FIGURE 86. DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 0 (trddata_en = 2, tphy_rdlat = 8) .....    | 159 |
| FIGURE 87. DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 1 .....                                     | 160 |
| FIGURE 88. DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 0 (trddata_en = 2, tphy_rdlat = 10) .....   | 161 |
| FIGURE 89. Read Rotation Rule 1 Example .....                                                                           | 162 |
| FIGURE 90. Read Rotation Rule 2 Example .....                                                                           | 162 |
| FIGURE 91. Read Rotation Rule 3 Example .....                                                                           | 163 |

---

---

|                                                                                                                                                         |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| FIGURE 92. Read Rotation Rule 4 Example .....                                                                                                           | 163 |
| FIGURE 93. Enable Signals for the Read Data Rotation Examples in a 1:4 Frequency Ratio System .....                                                     | 164 |
| FIGURE 94. Simple DFI Read Data Rotation Example in a 1:4 Frequency Ratio System .....                                                                  | 164 |
| FIGURE 95. Moderate DFI Read Data Rotation Example in a 1:4 Frequency Ratio System .....                                                                | 165 |
| FIGURE 96. Extreme DFI Read Data Rotation Example in a 1:4 Frequency Ratio System .....                                                                 | 165 |
| FIGURE 97. Non-Integral Transfer-Length-to-Ratio Example .....                                                                                          | 166 |
| FIGURE 98. Frequency Change Request Acknowledge Timing Diagram .....                                                                                    | 168 |
| FIGURE 99. Frequency Change Request Acknowledge Timing Diagram, with Optional<br>dfi_cmd_freq_ratio, dfi_data_freq_ratio and dfi_freq_fsp Signals ..... | 168 |
| FIGURE 100. Frequency Change Request Ignored Timing Diagram .....                                                                                       | 169 |
| FIGURE 101. Odd Command Parity Error Example Timing Diagram .....                                                                                       | 169 |
| FIGURE 102. dfi_alert_n_aN with 1:2 Command Frequency Ratio .....                                                                                       | 171 |
| FIGURE 103. Low Power Control Handshaking Timing Diagram .....                                                                                          | 173 |
| FIGURE 104. Low Power Control Request with No Response .....                                                                                            | 173 |
| FIGURE 105. Low Power Control Handshaking Timing Diagram with Multiple Wakeup Times .....                                                               | 174 |
| FIGURE 106. Low Power State Progressing From an Active Command Interface to Inactive .....                                                              | 174 |
| FIGURE 107. Low Power State Requiring Ongoing Use of the Command Interface .....                                                                        | 175 |
| FIGURE 108. Data Low Power Request Acknowledged Only .....                                                                                              | 175 |
| FIGURE 109. Both Data and Control Low Power Requests Acknowledged Simultaneously .....                                                                  | 176 |
| FIGURE 110. Both Data and Control Low Power Requests Acknowledged, At Different Times .....                                                             | 176 |
| FIGURE 111. Example of Error Condition .....                                                                                                            | 177 |
| FIGURE 112. PHY Managed Interface Timing .....                                                                                                          | 178 |
| FIGURE 113. Refresh Timing .....                                                                                                                        | 179 |
| FIGURE 114. PHY Update Request, QOS Disconnect Protocol .....                                                                                           | 180 |
| FIGURE 115. PHY Update Request, Error Disconnect Protocol .....                                                                                         | 180 |
| FIGURE 116. PHY Managed Interface, QOS Disconnect Protocol .....                                                                                        | 181 |
| FIGURE 117. Illustration of DDR4 read in 1N Mode .....                                                                                                  | 182 |
| FIGURE 118. Illustration of DDR4 read in 2N Mode .....                                                                                                  | 182 |
| FIGURE 119. Illustration of DDR5 without RCD read in 1N Mode .....                                                                                      | 183 |

---



---

|                                                                                                                                                |     |
|------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| FIGURE 120. Illustration of DDR5 without RCD read in 2N Mode with DDR5 CS Geardown<br>Disabled                                                 | 183 |
| FIGURE 121. Entering 2N Mode with a Sync Command; DDR4 with Matched Command Frequency<br>Ratio                                                 | 184 |
| FIGURE 122. Entering 2N Mode with a MPC command; DDR5 without RCD, 1:2 Command<br>Frequency Ratio, with CS Geardown Disabled                   | 184 |
| FIGURE 123. Illustration of DDR5 without RCD read in 2N Mode with DDR5 CS Geardown<br>Enabled                                                  | 185 |
| FIGURE 124. DDR5 Self-Refresh Exit Sequence in 2N Mode with DDR5 CS Geardown Enabled                                                           | 186 |
| FIGURE 125. MC to PHY Message Handshaking Timing Diagram                                                                                       | 187 |
| FIGURE 126. WCK Timing, Read 1:1 Command and 1:4 Data Ratio Timing Diagram                                                                     | 189 |
| FIGURE 127. WCK Timing for a Write, 1:1 Command and 1:2 Data Frequency Ratio, 2 Rank<br>Timing Diagram                                         | 190 |
| FIGURE 128. LPDDR5 WriteX Function                                                                                                             | 191 |
| FIGURE 129. LPDDR4 Independent Channels                                                                                                        | 192 |
| FIGURE 130. LPDDR4 Combined Channels                                                                                                           | 193 |
| FIGURE 131. Semi-Independent Channel Interfaces                                                                                                | 194 |
| FIGURE 132. Example of LPDDR4 Multi-Configuration                                                                                              | 195 |
| FIGURE 133. MRDIMM Mux 1N Mode Write 1:4 Command and 1:4 Data Frequency Ratio                                                                  | 201 |
| FIGURE 134. MRDIMM Mux 2N Mode Write 1:2 Command and 1:4 Data Frequency Ratio                                                                  | 202 |
| FIGURE 135. MRDIMM Mux 1N Mode Read 1:4 Command and 1:4 Data Frequency Ratio                                                                   | 204 |
| FIGURE 136. MRDIMM Mux 2N Mode Read 1:2 Command and 1:4 Data Frequency Ratio                                                                   | 205 |
| FIGURE 137. DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:2 Command and 1:2 Data<br>Frequency Ratio with Offset Between Pseudo-Channel Commands | 207 |
| FIGURE 138. DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:4 Command and 1:4 Data<br>Frequency Ratio with Offset Between Pseudo-Channel Commands | 208 |

## 1.0 Overview

---

The DDR PHY Interface (DFI) is an interface protocol that defines the signals, timing parameters and programmable parameters required to transfer command information and data across the DFI and between the DDR memory controller (MC) and the DDR PHY (PHY). The programmable parameters are options defined by the MC, PHY, or system and programmed into the MC and/or the PHY. DFI applies to: DDR1, DDR2, DDR3, DDR4, DDR4 LRDIMM, DDR4 RDIMM, DDR5, DDR5 LRDIMM, DDR5 RDIMM, DDR5 MRDIMM, LPDDR1, LPDDR2, LPDDR3, LPDDR4 and LPDDR5 DRAMs.

The DFI protocol does not encompass all of the features of the MC or the PHY, nor does the protocol put any restrictions on how the MC or the PHY interface to other aspects of the system.

This specification is organized by the interface groups listed in Table 1, “Interface Groups”.

---

**TABLE 1. Interface Groups**

---

| Interface Group     | Description                                                                                                        |
|---------------------|--------------------------------------------------------------------------------------------------------------------|
| Command             | Required to drive the address and command signals to the DRAM devices.                                             |
| Write Data          | Used to send write and receive valid read data across the DFI.                                                     |
| Read Data           |                                                                                                                    |
| Update              | Provides an ability for the MC or the PHY to initiate idling the DFI bus.                                          |
| Status              | Used for system initialization, feature support and to control the presence of valid clocks to the DRAM interface. |
| PHY Managed         | Used to allow the PHY to control the DFI bus.                                                                      |
| Disconnect Protocol | Allows an ongoing handshake to be broken.                                                                          |
| Error               | Used to communicate error information from the PHY to the MC.                                                      |
| Low Power Control   | Allows the PHY to enter power-saving modes.                                                                        |
| MC to PHY Message   | Used to send defined messages from the MC to the PHY.                                                              |
| WCK Control         | Controls the WCK on, off and synchronization timing.                                                               |

Within each interface group are signals and parameters. Some signals are applicable only to certain DRAM types. All of the DFI signals must use the corresponding parameters.

Changes in the DFI protocol between versions may result in incompatibilities between MCs and PHYs which were designed to adhere to different versions of the DFI specification. If using devices designed for different versions of the DFI specification, review the changes associated with the corresponding versions and ensure changes will not interfere with interoperability in a specific configuration.

All figures are provided for illustrative purposes only. Timing diagrams may illustrate condensed or otherwise unrealistic signal timing.

A glossary of terminology used in this specification can be found in Table 55, “Glossary of Terms”.

## 2.0 Architecture

---

The DFI specification requires a DFI clock and DFI-defined signals that must be driven directly by registers referenced to a rising edge of the DFI clock. There are no rules dictating the source of the DFI clock, nor are there restrictions on how the DFI-defined signals are received. For DFI interoperability between the MC and the PHY, ensure compatibility in:

- Signal widths
- Interconnect timing
- Timing parameters
- Frequency ratio
- Function

Interconnect timing compatibility between the MC and the PHY at target frequencies is determined by the specification of the output timing for signals driven and the setup and hold requirements to receive these signals on the DFI per device, as defined by the device.

The DFI specification does not dictate absolute latencies or a fixed range of values that must be supported by each device. Certain DFI timing parameters can be specified as fixed values, maximum values, or as constants based on other values in the system.

DFI timing parameters must be held constant while commands are being executed on the DFI bus; however, if necessary, DFI timing parameters may be changed during a frequency change or while the bus is in the idle state. For more information on timing, refer to Section 5.0, “Signal Timing”.

The DFI specification identifies the DFI signals relevant to a specific implementation based upon support for specific DRAM device(s), optional features and frequency ratio. For more information on which signals are relevant to a specific implementation, refer to Table 4, “DFI Signal Requirements”.

### 2.1 Clocking

The DFI bus does not include a clock signal; The DFI clock is generally assumed to be the same clock as the MC clock. The MC may operate at the same or different clock frequency than the PHY’s interface to memory, which is also referred to as the host interface. If the DFI clock and the host interface clock(s) are the same frequency, the system is defined as a matched frequency system. If the MC operates at a lower frequency, with a 1:2, 1:4 or 1:8 ratio to the host interface, the system is defined as a frequency ratio system.

Depending on the DRAM or DIMM protocol, the host interface may utilize a single memory clock or separate command and data clocks. For protocols utilizing a single host clock, the terms “Command clock” and “Data clock” refer to the common clock.

DFI recognizes four clock domains as follows:

- the DFI clock domain: this is the MC-PHY interface clock
- the Control clock domain: this clock domain is always the same frequency as the DFI clock domain
- the Command clock domain: this clock domain is always the same frequency as the host command clock (eg. CK, DCK)
- the Data clock domain: this clock domain is always the same frequency as the host clock or strobe (eg. DQS, RDQS, WCK)

For a matched frequency system, these four clock domains operate at the same frequency. For a frequency ratio system, the DFI defines two clock ratios: the command ratio is the ratio between the slower Control clock domain and the faster Command clock domain, and the data ratio is the ratio between the slower Control clock domain and the faster Data clock domain. A frequency ratio system with a 1:1 command frequency ratio may be referred to as a matched command ratio system for brevity. All DFI signals operate on the DFI clock but are associated with one of the other three clock domains for timing and phase relationships. Refer to Table 2, “Signals by Reference Clock Domain” for the reference domain. DFI also defines timing parameters associated with each reference clock domain. Parameters that cross domains will require special care. For LPDDR5 and DDR5 MRDIMMs, refer to the examples in Section 4.7.6, “CA Bus Timing” for more information on these signals.

LPDDR5 is an example of a memory that utilizes separate command and data clocks at the host interface. If the host command clock operates at the DFI clock frequency (i.e. 1:1 ratio), the host data clock must operate at either a 2:1 or a 4:1 ratio to the DFI clock. Therefore, the command ratio would be 1:1 and data ratio would be 1:2 or 1:4.

DDR4 is an example of a memory that utilizes a single memory clock at the host interface. If the host command clock operates at twice the DFI clock frequency (i.e. 2:1 ratio), the host data clock will also operate at a 2:1 ratio to the DFI clock. Therefore, the command ratio and data ratio would both be 1:2.

Table 2, “Signals by Reference Clock Domain” for the reference domain correlates each DFI signal with its reference clock domain.

**TABLE 2. Signals by Reference Clock Domain**

| Signal                | Interface           | Reference Clock Domain |
|-----------------------|---------------------|------------------------|
| dfi_ctrlupd_ack       | Update              | Control clock          |
| dfi_ctrlupd_req       |                     |                        |
| dfi_phyupd_ack        |                     |                        |
| dfi_phyupd_req        |                     |                        |
| dfi_phyupd_type       |                     |                        |
| dfi_cmd_freq_ratio    | Status              |                        |
| dfi_data_freq_ratio   |                     |                        |
| dfi_freq_fsp          |                     |                        |
| dfi_frequency         |                     |                        |
| dfi_init_complete     |                     |                        |
| dfi_init_start        |                     |                        |
| dfi_phymngd_ack       | PHY Managed         |                        |
| dfi_phymngd_cs_state  |                     |                        |
| dfi_phymngd_req       |                     |                        |
| dfi_phymngd_state_sel |                     |                        |
| dfi_phymngd_type      |                     |                        |
| dfi_disconnect_error  | Disconnect Protocol |                        |
| dfi_error             | Error               |                        |
| dfi_error_info        |                     |                        |
| dfi_lp_ctrl_ack       | Low Power Control   |                        |
| dfi_lp_ctrl_req       |                     |                        |
| dfi_lp_ctrl_wakeup    |                     |                        |
| dfi_lp_data_ack       |                     |                        |
| dfi_lp_data_req       |                     |                        |
| dfi_lp_data_wakeup    |                     |                        |
| dfi_ctrlmsg           | MC to PHY Message   |                        |
| dfi_ctrlmsg_ack       |                     |                        |
| dfi_ctrlmsg_data      |                     |                        |
| dfi_ctrlmsg_req       |                     |                        |

**TABLE 2.** Signals by Reference Clock Domain

| Signal                            | Interface   | Reference Clock Domain |
|-----------------------------------|-------------|------------------------|
| <code>dfi_2n_mode</code>          | Command     | Command clock          |
| <code>dfi_cs_geardown</code>      |             |                        |
| <code>dfi_act_n</code>            |             |                        |
| <code>dfi_address</code>          |             |                        |
| <code>dfi_alert_n</code>          |             |                        |
| <code>dfi_bank</code>             |             |                        |
| <code>dfi_bg</code>               |             |                        |
| <code>dfi_cas_n</code>            |             |                        |
| <code>dfi_cid</code>              |             |                        |
| <code>dfi_cke</code>              |             |                        |
| <code>dfi_cs</code>               |             |                        |
| <code>dfi_dram_clk_disable</code> |             |                        |
| <code>dfi_odt</code>              |             |                        |
| <code>dfi_parity_in</code>        |             |                        |
| <code>dfi_ras_n</code>            |             |                        |
| <code>dfi_reset_n</code>          |             |                        |
| <code>dfi_we_n</code>             |             |                        |
| <code>dfi_wrdata</code>           | Write Data  | Data clock             |
| <code>dfi_wrdata_crc</code>       |             |                        |
| <code>dfi_wrdata_cs</code>        |             |                        |
| <code>dfi_wrdata_ecc</code>       |             |                        |
| <code>dfi_wrdata_en</code>        |             |                        |
| <code>dfi_wrdata_mask</code>      |             |                        |
| <code>dfi_rddata</code>           | Read Data   |                        |
| <code>dfi_rddata_crc</code>       |             |                        |
| <code>dfi_rddata_cs</code>        |             |                        |
| <code>dfi_rddata_dbi</code>       |             |                        |
| <code>dfi_rddata_dnv</code>       |             |                        |
| <code>dfi_rddata_en</code>        |             |                        |
| <code>dfi_rddata_valid</code>     |             |                        |
| <code>dfi_wck_cs</code>           | WCK Control |                        |
| <code>dfi_wck_en</code>           |             |                        |
| <code>dfi_wck_toggle</code>       |             |                        |

The frequency ratios depend on the relationships of the reference clocks for the DFI and the host. The command frequency ratio is defined between the DFI clock and the host command clock, and the data frequency ratio is defined between the DFI clock and the host data clock.

Control clock domain signals do not operate at a clock ratio, they are always DFI clock based. Refer to Table 2, “Signals by Reference Clock Domain” for the signal clock domains.

For a matched frequency system, to accommodate double data rate data, the DFI read and write data bus width is generally twice the width of the host data bus. For a frequency ratio system, the DFI read and write data bus width will be multiplied proportional to the data frequency ratio to allow the MC and PHY to transfer all of the host-required data in a single DFI clock cycle. The write data must be delivered with the DFI data words aligned in ascending order.

For a matched frequency system, or frequency ratio system with a 1:1 command ratio, a single DFI command is issued per DFI clock and contains the command transferred in a single host clock. A DFI command signal corresponding to a double data rate signal on the host interface is generally twice the width to accommodate both edges. For a frequency ratio system without a 1:1 command ratio, a DFI command is issued per phase where the number of command phases is equivalent to the command frequency ratio.

The PHY must be able to accept a command on any and all phases.

For signals operating at a frequency ratio:

- Phase-specific signals with a suffix of "\_pN", with the phase number N (e.g., **dfi\_wrdata\_pN**), replace the matched frequency signals. These may include command (if this is a command frequency ratio system), write data, read data and WCK control (if this is a data frequency ratios system) interface group signals. Phase-specific signals allow the MC to drive multiple commands in a single DFI clock cycle.
- Data word-specific signals with a suffix of "\_wN", with the DFI data word number N (e.g., **dfi\_rddata\_wN**), replace the matched frequency signals for the read interface to distinguish how DRAM words are transferred across the DFI bus.
- Variable pulse width-specific signals with a suffix of "aN", with the command clock cycle N (e.g., **dfi\_alert\_n\_aN**), replace the matched frequency signals for the status interface to maintain the pulse width during transmission of error signals from the memory system to the PHY.
- For all signal types, the suffix for phase 0/data word 0/clock cycle 0 is optional.

For timing parameters that cross frequency ratio domains, the phase/word/clock cycle N of both DFI signals must be translated into the target (usually Data) domain. This can be accomplished by multiplying the command phase N by the data ratio divided by the command ratio. For example, if the command ratio is 1:2 and the data ratio is 1:4, command phase 0 aligns with data phase 0 and command phase 1 aligns with data phase 2. For more information, refer to Section 4.10.1, “Frequency Ratio Clock Definition”.

For more information on frequency ratios, refer to Section 4.10, “Frequency Ratios Across the DFI”.

## 2.2 Optional Protocols

Optional protocols handle data bus inversion (DBI), link ECC, cyclic redundancy check (CRC), system frequency change, command/address (CA) parity, low power and the error interface. For more information on optional protocols, refer to Section 4.6, “Data Bus Inversion”, Section 4.7.5, “Cyclic Redundancy Check - Write”, Section 4.11, “Frequency

Change”, Section 4.12, “CA Parity Signaling and CA Parity, CRC Errors”, Section 4.14, “Error Signaling”, Section 4.17, “2N Mode” and Section 4.19, “Use of the WCK Control Interface”.

## **2.3 DFI Feature Requirements**

The DFI specification defines the MC-PHY interface for numerous memory protocols and topologies. Not all DFI features are applicable or required for any particular memory sub-system. Features are divided into global and memory-specific features to aid interoperability and optimal system design.

### **2.3.1 Global Features**

Global features apply to all memory topologies. While these features are valid across all memory sub-systems, they are not always required. For example, any system can utilize “low power control” to reduce system power. However, the requirement of “low power control” is based on system trade-offs and constraints that are outside the scope of DFI. The list of global features are:

- Frequency ratios across DFI
- Frequency change
- Low power control
- Error signaling
- Update interface
- PHY managed interface
- Clock disabling
- Data bit enable
- DFI disconnect
- Independent channel support
- MC to PHY message

For specific signal requirements, refer to Table 4, “DFI Signal Requirements”.

### **2.3.2 Memory Topology-Specific Features**

A subset of DFI features is not globally applicable to all memory sub-systems. A matrix of memory topology and features is defined in Table 3, “Features by Memory Topology”. While the feature matrix defines when a feature applies to a specific memory topology, each feature is not necessarily required. Specific feature requirements are based on system trade-offs and constraints that are outside the scope of DFI. For specific signal requirements per feature, refer to Table 3, “Features by Memory Topology”.

---

**TABLE 3. Features by Memory Topology**

| Memory Class | Topologies                                 | Applicable Features <sup>a,b</sup>            |
|--------------|--------------------------------------------|-----------------------------------------------|
| DDR1         | Discrete, DIMM                             | No additional features beyond global features |
| DDR2         | Discrete, Unbuffered DIMM, Registered DIMM | No additional features beyond global features |

---

**TABLE 3.** Features by Memory Topology

| Memory Class | Topologies                | Applicable Features <sup>a,b</sup>                                                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DDR3         | Discrete, Unbuffered DIMM | DFI disconnect during training                                                                                                                                                                                                                                                                                                                     |
|              | Registered DIMM           | <ul style="list-style-type: none"> <li>• All DDR3 discrete, unbuffered DIMM features</li> <li>• CA parity</li> <li>• CA parity errors</li> </ul>                                                                                                                                                                                                   |
| DDR4         | Discrete, Unbuffered DIMM | <ul style="list-style-type: none"> <li>• DFI disconnect during training</li> <li>• Read data bus inversion</li> <li>• Write data bus inversion</li> <li>• Write data CRC</li> <li>• Write data CRC errors</li> <li>• CA parity</li> <li>• CA parity errors</li> <li>• 2N mode</li> </ul>                                                           |
|              | Registered DIMM           | All DDR4 discrete and unbuffered DIMM features                                                                                                                                                                                                                                                                                                     |
|              | Load Reduced DIMM         | <ul style="list-style-type: none"> <li>• All DDR4 discrete and unbuffered DIMM features</li> </ul>                                                                                                                                                                                                                                                 |
| DDR5         | Discrete, Unbuffered DIMM | <ul style="list-style-type: none"> <li>• DFI disconnect during training</li> <li>• Read data bus inversion</li> <li>• Write data bus inversion</li> <li>• Read data CRC</li> <li>• Write data CRC</li> <li>• Write data CRC errors</li> <li>• CA parity</li> <li>• CA parity errors</li> <li>• 2N mode</li> <li>• DDR5 CS Geardown mode</li> </ul> |
|              | Registered DIMM           | All DDR5 discrete and unbuffered DIMM features, except DDR5 CS Geardown                                                                                                                                                                                                                                                                            |
|              | Load Reduced DIMM         | <ul style="list-style-type: none"> <li>• All DDR5 Registered DIMM features</li> </ul>                                                                                                                                                                                                                                                              |
|              | Multiplexed Rank DIMM     | <ul style="list-style-type: none"> <li>• All DDR5 Registered DIMM features</li> <li>• Pseudo-Channels</li> <li>• Read DQ Link CRC</li> <li>• Write DQ Link CRC</li> <li>• Write DQ Link CRC errors</li> </ul>                                                                                                                                      |
| LPDDR1       | Any                       | No additional features beyond global features                                                                                                                                                                                                                                                                                                      |
| LPDDR2       | S2, S4                    | DFI disconnect during training                                                                                                                                                                                                                                                                                                                     |
|              | NVM                       | <ul style="list-style-type: none"> <li>• All LPDDR2 S2, S4 features</li> <li>• Data not valid</li> </ul>                                                                                                                                                                                                                                           |
| LPDDR3       | Any                       | DFI disconnect during training                                                                                                                                                                                                                                                                                                                     |

**TABLE 3.** *Features by Memory Topology*

| Memory Class | Topologies | Applicable Features <sup>a,b</sup>                                                                                                                                                                                                     |
|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPDDR4       | Any        | <ul style="list-style-type: none"><li>• Read data bus inversion</li><li>• Write data bus inversion</li><li>• Combined and multi-configuration channel support</li><li>• DFI disconnect during training</li></ul>                       |
| LPDDR5       | Any        | <ul style="list-style-type: none"><li>• Read data bus inversion</li><li>• Write data bus inversion</li><li>• Combined and multi-configuration channel support</li><li>• DFI disconnect during training</li><li>• WCK Control</li></ul> |

- a. DFI defines features for specific memory class and topology. However, features can be extended beyond memory classes that are explicitly supported in DFI. This topic is outside the scope of DFI.  
b. Feature support is limited to features that are included in a specific DFI version. For example, DFI support of DFI disconnect is not applicable to DFI 3.1 or previous MC and PHY components

Items as follows describe some limits of the feature topology matrix and serve to simplify the matrix and DFI.

- Package types (PoP, MCP, DDP, QDP, etc.) are not defined in DFI and therefore are not part of the feature topology matrix.
- Features that are defined completely with a signal, with no other DFI ramifications, are not included in the feature topology matrix. This list includes the following items:
  - Termination: defined by **dfi\_odt**
  - Per rank delay line support: defined by **dfi\_rrdata\_cs / dfi\_wrdata\_cs**For these cases, support is defined in the DFI Signal Requirements section.

DRAM features supported but not explicitly covered by DFI are not included in the matrix. These include:

- Per DRAM addressability

### **2.3.3 DFI Signals**

The DFI signals associated with each interface group, and the device originating the signal, are shown in Figure 1, “Block Diagram of Interface Signals: Command, Write Data, Read Data, Update, Status, PHY Managed, Disconnect and Error” and Figure 2, “Block Diagram of Interface Signals: Low Power Control, MC to PHY Message and WCK Control”. The signal requirements and parameters associated with each signal are listed in Table 4, “DFI Signal Requirements”. Other signals may exist between the MC and the PHY for a particular implementation. The signals are listed functionally within each interface group.

**FIGURE 1.** Block Diagram of Interface Signals: Command, Write Data, Read Data, Update, Status, PHY Managed, Disconnect and Error



1. Optional suffix for frequency ratio systems.

2. Dual-function signal. In DDR4/LPDDR4 systems with write DBI enabled, the signal transforms from a mask to a write DBI signal.  
*Italicized text indicates that the phase/word/cycle is optional.*

**FIGURE 2.** Block Diagram of Interface Signals: Low Power Control, MC to PHY Message and WCK Control


1. Optional suffix for frequency ratio systems.  
 2. Dual-function signal. In DDR4/LPDDR4 systems with write DBI enabled, the signal transforms from a mask to a write DBI signal.  
*Italicized text indicates that the phase/word/cycle is optional.*

To determine which signals are required for a specific configuration, review Table 4, “DFI Signal Requirements”. This table identifies the signals associated with each interface group, the parameters associated with each signal, and whether the signal is applicable, required, or optional for each device.

Each signal is device-specific and has corresponding parameters which must be used. Multiple parameter types may apply to a signal. Timing parameters are indicated with the prefix `t` (e.g., `txxxx_xxxx`). Programmable parameters are indicated with a prefix to indicate the defining device and a suffix (e.g., `phyxxxx_en`). The signals are listed functionally within each interface group.

**TABLE 4.** DFI Signal Requirements

| Command Interface           |                                        |                                                                                                                                                                                           |                                                                                                                                                                                           |
|-----------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signal                      | Associated Parameters                  | MC                                                                                                                                                                                        | PHY                                                                                                                                                                                       |
| <code>dfi_2n_mode_pN</code> | <code>t<sub>2n_mode_delay</sub></code> | Optional for DDR4 DRAMs.<br>Required for DDR5 DRAMs.<br>Suffix ( <code>_pN</code> ) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup> | Optional for DDR4 DRAMs.<br>Required for DDR5 DRAMs.<br>Suffix ( <code>_pN</code> ) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup> |
| <code>dfi_act_n_pN</code>   | <code>t<sub>ctrl_delay</sub></code>    | Required for DDR4 DRAMs. <sup>b</sup><br>Suffix ( <code>_pN</code> ) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                | Required for DDR4 DRAMs. <sup>b</sup><br>Suffix ( <code>_pN</code> ) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                |

**TABLE 4.** DFI Signal Requirements

|                       |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_address_pN</b> | <b>t<sub>ctrl_delay</sub></b>                                                                                                                                                                                      | Required for all DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Required for all DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>dfi_alert_n_aN</b> | <b>phy<sub>crc_mode</sub></b><br><b>phy<sub>linkdqcrc_mode</sub></b><br><b>t<sub>parin_lat</sub></b><br><b>t<sub>phy_crcmax_lat</sub></b><br><b>t<sub>phy_cremin_lat</sub></b><br><b>t<sub>phy_paritylat</sub></b> | Required for the following systems: <ul style="list-style-type: none"><li>• DDR3 RDIMM systems</li><li>• DDR4 and DDR5 systems that support CRC, CA parity, or both.</li></ul> In all other cases, this signal is not required, but can optionally be included.<br>Requirement because of CRC is unrelated to <b>phy<sub>crc_mode</sub></b> or <b>phy<sub>linkdqcrc_mode</sub></b> value.<br>Requirement because of CA parity is unrelated to location (MC, PHY) that the parity is generated.<br>Suffix (_aN) required for command frequency ratio systems to replicate information across the word. <sup>a</sup> | Required for the following systems: <ul style="list-style-type: none"><li>• DDR3 RDIMM systems</li><li>• DDR4 and DDR5 systems that support CRC, CA parity, or both.</li></ul> In all other cases, this signal is not required, but can optionally be included.<br>Requirement because of CRC is unrelated to <b>phy<sub>crc_mode</sub></b> or <b>phy<sub>linkdqcrc_mode</sub></b> value.<br>Requirement because of CA parity is unrelated to location (MC, PHY) that the parity is generated.<br>Suffix (_aN) required for command frequency ratio systems to replicate information across the word. <sup>a</sup> |
| <b>dfi_bank_pN</b>    | <b>t<sub>ctrl_delay</sub></b>                                                                                                                                                                                      | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                           | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>dfi_bg_pN</b>      | <b>t<sub>ctrl_delay</sub></b>                                                                                                                                                                                      | Required for DDR4 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Required for DDR4 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>dfi_cas_n_pN</b>   | <b>t<sub>ctrl_delay</sub></b>                                                                                                                                                                                      | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                           | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                           |

**TABLE 4.** DFI Signal Requirements

|                                |                                                                           |                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_cid_pN</b>              | <b>t<sub>ctrl</sub>_delay</b>                                             | Required for DDR3 and DDR4 devices. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                 | Required for DDR3 and DDR4 devices. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                             |
| <b>dfi_cke_pN</b>              | <b>t<sub>ctrl</sub>_delay</b>                                             | Required for DDR1, DDR2, DDR3, DDR4, LPDDR1, LPDDR2, LPDDR3 and LPDDR4 DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                    | Required for DDR1, DDR2, DDR3, DDR4, LPDDR1, LPDDR2, LPDDR3 and LPDDR4 DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                |
| <b>dfi_cs_pN</b>               | <b>t<sub>cmd</sub>_lat</b><br><b>t<sub>ctrl</sub>_delay</b>               | Required for all DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                          | Required for all DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                      |
| <b>dfi_cs_gardown_pN</b>       | <b>t<sub>cs</sub>_gardown_delay</b>                                       | Optional for DDR5 DRAMs.                                                                                                                                                                                                                                                                                                                                               | Optional for DDR5 DRAMs.                                                                                                                                                                                                                                                                                                                                           |
| <b>dfi_dram_clk_disable_pN</b> | <b>t<sub>dram_clk_disable</sub></b><br><b>t<sub>dram_clk_enable</sub></b> | Required for all DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                          | Required for all DRAMs.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                                                      |
| <b>dfi_odt_pN</b>              | <b>phy<sub>crc</sub>_mode</b><br><b>t<sub>ctrl</sub>_delay</b>            | Required for DDR2, DDR3, DDR4 and LPDDR3 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                     | Required for DDR2, DDR3, DDR4 and LPDDR3 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                                                                 |
| <b>dfi_parity_in_pN</b>        | <b>t<sub>parin</sub>_lat</b><br><b>t<sub>phy_paritylat</sub></b>          | Required for the following systems: <ul style="list-style-type: none"><li>• DDR3 RDIMM systems</li><li>• DDR4 and DDR5 systems that support CA parity</li></ul> In all other cases, this signal is not required, but can optionally be included.<br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup> | Optional. Only relevant for the following systems when the PHY requires the MC to generate the parity information: <ul style="list-style-type: none"><li>• DDR3 RDIMM systems</li><li>• DDR4 and DDR5 systems that support CA parity.</li></ul> Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup> |

**TABLE 4.** DFI Signal Requirements

| <b>dfi_ras_n_pN</b>         | <b>t<sub>ctrl_delay</sub></b>                                                                        | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>   | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>   |
|-----------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_reset_n_pN</b>       | <b>t<sub>ctrl_delay</sub></b>                                                                        | Required for DDR3, DDR4, DDR5, LPDDR4 and LPDDR5 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup> | Required for DDR3, DDR4, DDR5, LPDDR4 and LPDDR5 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup> |
| <b>dfi_we_n_pN</b>          | <b>t<sub>ctrl_delay</sub></b>                                                                        | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>   | Required for DDR1, DDR2, DDR3, DDR4 and LPDDR1 DRAMs. <sup>b</sup><br>Suffix (_pN) required for command frequency ratio systems to replicate information across the phases. <sup>a</sup>   |
| <b>Write Data Interface</b> |                                                                                                      |                                                                                                                                                                                            |                                                                                                                                                                                            |
| <b>Signal</b>               | <b>Associated Parameters</b>                                                                         | <b>MC</b>                                                                                                                                                                                  | <b>PHY</b>                                                                                                                                                                                 |
| <b>dfi_wrdata_pN</b>        | <b>phy<sub>crc_mode</sub></b><br><b>t<sub>phy_wrdata</sub></b><br><b>t<sub>phy_wrlat</sub></b>       | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                 | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                 |
| <b>dfi_wrdata_crc_pN</b>    | <b>phy<sub>linkdqcrc_mode</sub></b><br><b>t<sub>phy_wrdata</sub></b><br><b>t<sub>phy_wrlat</sub></b> | Required for DDR5 MRDIMMs when <b>phy<sub>linkdqcrc_mode</sub></b> = 'b1.<br>Suffix (_pN) required for frequency ratio systems to replicate information across the phases. <sup>a</sup>    | Required for DDR5 MRDIMMs when <b>phy<sub>linkdqcrc_mode</sub></b> = 'b1.<br>Suffix (_pN) required for frequency ratio systems to replicate information across the phases. <sup>a</sup>    |
| <b>dfi_wrdata_cs_pN</b>     | <b>t<sub>phy_wresgap</sub></b><br><b>t<sub>phy_wreslat</sub></b>                                     | Required for all DRAMs if there is more than 1 chip select.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>             | Optional.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                               |

**TABLE 4.** DFI Signal Requirements

| <b>dfi_wrdata_ecc_pN</b>   | <b>phylinkecc_mode</b>                                                                                                                                            | Required for LPDDR5 DRAMs when <b>phylinkecc_mode</b> = 'b1.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup> | Optional. Is a pass-through signal if the MC supports Link ECC, or is required if the <b>phylinkecc_mode</b> = 'b0 and the PHY is handling link ECC.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup> |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_wrdata_en_pN</b>    | <b>dfi_rw_length</b><br><b>phycrc_mode</b><br><b>tphy_cremax_lat</b><br><b>tphy_cremin_lat</b><br><b>tphy_wrdata</b><br><b>tphy_wrlat</b><br><b>twrdata_delay</b> | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                      | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                              |
| <b>dfi_wrdata_mask_pN</b>  | <b>phycrc_mode</b><br><b>tphy_wrdata</b><br><b>tphy_wrlat</b>                                                                                                     | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                      | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                              |
| <b>Read Data Interface</b> |                                                                                                                                                                   |                                                                                                                                                                                 |                                                                                                                                                                                                                                                                         |
| <b>Signal</b>              | <b>Associated Parameters</b>                                                                                                                                      | <b>MC</b>                                                                                                                                                                       | <b>PHY</b>                                                                                                                                                                                                                                                              |
| <b>dfi_rddata_wN</b>       | <b>tphy_rdlat</b><br><b>tRDDATA_en</b>                                                                                                                            | Required for all DRAMs.<br>Suffix (_wN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                      | Required for all DRAMs.<br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup>                                                                                                                                |
| <b>dfi_rddata_crc_wN</b>   | <b>phylinkdqrc_mode</b><br><b>tphy_rdlat</b><br><b>tRDDATA_en</b>                                                                                                 | Required for DDR5 MRDIMMs when <b>phylinkdqrc_mode</b> = 'b1.<br>Suffix (_pN) required for frequency ratio systems to replicate information across the phases. <sup>a</sup>     | Required for DDR5 MRDIMMs when <b>phylinkdqrc_mode</b> = 'b1.<br>Suffix (_pN) required for frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                             |
| <b>dfi_rddata_cs_pN</b>    | <b>tphy_rdsgap</b><br><b>tphy_rdeslat</b>                                                                                                                         | Required for all DRAMs if there is more than 1 chip select.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>  | Optional.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                                                            |

**TABLE 4.** DFI Signal Requirements

| <b>dfi_rddata_dbi_wN</b>   | <b>phydbi_mode</b><br><b>phylinkecc_mode</b><br><b>tphy_rdlat</b><br><b>trddata_en</b> | Applicable for DDR4, LPDDR4 and LPDDR5 DRAMs only and required when MC DBI support is enabled and <b>phydbi_mode = 0</b> .<br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup> | Applicable for DDR4, LPDDR4 and LPDDR5 DRAMs only and required when MC DBI support is enabled and <b>phydbi_mode = 0</b> .<br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup> |
|----------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_rddata_dnv_wN</b>   | <b>tphy_rdlat</b><br><b>trddata_en</b>                                                 | Required for LPDDR2 DRAMs. <sup>b</sup><br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup>                                                                                    | Required for LPDDR2 DRAMs. <sup>b</sup><br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup>                                                                                    |
| <b>dfi_rddata_en_pN</b>    | <b>tphy_rdlat</b><br><b>trddata_en</b><br><b>dfirw_length</b>                          | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                  | Required for all DRAMs.<br>Suffix (_pN) required for data frequency ratio systems to replicate information across the phases. <sup>a</sup>                                                                                                  |
| <b>dfi_rddata_valid_wN</b> | <b>tphy_rdlat</b><br><b>trddata_en</b>                                                 | Required for all DRAMs.<br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup>                                                                                                    | Required for all DRAMs.<br>Suffix (_wN) required for data frequency ratio systems to replicate information across the word. <sup>a</sup>                                                                                                    |
| <b>Update Interface</b>    |                                                                                        |                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                             |
| Signal                     | Associated Parameters                                                                  | MC                                                                                                                                                                                                                                          | PHY                                                                                                                                                                                                                                         |
| <b>dfi_ctrlupd_ack</b>     | <b>tctrlupd_max</b><br><b>tctrlupd_min</b>                                             | Required for all DRAMs.                                                                                                                                                                                                                     | Optional.                                                                                                                                                                                                                                   |
| <b>dfi_ctrlupd_req</b>     | <b>tctrlupd_interval</b><br><b>tctrlupd_max</b><br><b>tctrlupd_min</b>                 | Required for all DRAMs.                                                                                                                                                                                                                     | Optional.                                                                                                                                                                                                                                   |
| <b>dfi_phyupd_ack</b>      | <b>tphyupd_typeX</b>                                                                   | Required for all DRAMs.                                                                                                                                                                                                                     | Optional.                                                                                                                                                                                                                                   |
| <b>dfi_phyupd_req</b>      | <b>tphyupd_resp</b><br><b>tphyupd_typeX</b>                                            | Required for all DRAMs.                                                                                                                                                                                                                     | Optional.                                                                                                                                                                                                                                   |
| <b>dfi_phyupd_type</b>     | <b>tphyupd_typeX</b>                                                                   | Required for all DRAMs.                                                                                                                                                                                                                     | Optional.                                                                                                                                                                                                                                   |
| <b>Status Interface</b>    |                                                                                        |                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                             |
| Signal                     | Associated Parameters                                                                  | MC                                                                                                                                                                                                                                          | PHY                                                                                                                                                                                                                                         |
| <b>dfi_cmd_freq_ratio</b>  | <b>dficmdfreq_ratio</b>                                                                | Required if the MC supports a command frequency ratio system.                                                                                                                                                                               | Required if the MC supports a command frequency ratio system.                                                                                                                                                                               |
| <b>dfi_data_freq_ratio</b> | <b>dfidatafreq_ratio</b>                                                               | Required if the MC supports a data frequency ratio system.                                                                                                                                                                                  | Required if the MC supports a data frequency ratio system.                                                                                                                                                                                  |

**TABLE 4.** DFI Signal Requirements

| <b>dfi_freq_fsp</b>               | <b>dfifspx_freq</b>                                                                                                                                                                              | Required if the DRAM supports FSP and the MC supports frequency change.      | Required if the DRAM supports FSP and the PHY supports frequency change.     |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| <b>dfi_frequency</b>              | <b>phyfreq_range</b>                                                                                                                                                                             | Required for all DRAMs if the MC supports frequency change.                  | Required if the PHY supports frequency change.                               |
| <b>dfi_init_complete</b>          | <b>tinit_complete</b><br><b>tinit_start</b>                                                                                                                                                      | Required for all DRAMs.                                                      | Required for all DRAMs.                                                      |
| <b>dfi_init_start</b>             | <b>tinit_complete</b><br><b>tinit_start</b><br><b>tinit_start_min</b>                                                                                                                            | Required for all DRAMs.                                                      | Required for all DRAMs.                                                      |
| <b>PHY Managed Interface</b>      |                                                                                                                                                                                                  |                                                                              |                                                                              |
| Signal                            | Associated Parameters                                                                                                                                                                            | MC                                                                           | PHY                                                                          |
| <b>dfi_phymngd_ack</b>            | <b>tphymngd_resp</b>                                                                                                                                                                             | Required for all DRAMs.                                                      | Optional.                                                                    |
| <b>dfi_phymngd_cs_state</b>       |                                                                                                                                                                                                  | Required for all DRAMs.                                                      | Optional.                                                                    |
| <b>dfi_phymngd_req</b>            | <b>tphymngd_resp</b><br><b>tphymngd_typeX</b>                                                                                                                                                    | Required for all DRAMs.                                                      | Optional.                                                                    |
| <b>dfi_phymngd_state_sel</b>      |                                                                                                                                                                                                  | Required for all DRAMs.                                                      | Optional.                                                                    |
| <b>dfi_phymngd_type</b>           |                                                                                                                                                                                                  | Required for all DRAMs.                                                      | Optional.                                                                    |
| (not associated with a signal)    | <b>tphymngd_rfsh</b>                                                                                                                                                                             | Required for all DRAMs.                                                      | Optional.                                                                    |
| <b>Disconnect Protocol</b>        |                                                                                                                                                                                                  |                                                                              |                                                                              |
| Signal                            | Associated Parameters                                                                                                                                                                            | MC                                                                           | PHY                                                                          |
| <b>dfi_disconnect_error</b>       | <b>tctrlupd_disconnect</b><br><b>tctrlupd_disconnect_error</b><br><b>tphymngd_disconnect</b><br><b>tphymngd_disconnect_error</b><br><b>tphyupd_disconnect</b><br><b>tphyupd_disconnect_error</b> | Optional for all DRAMs.                                                      | Optional.                                                                    |
| <b>Error Interface (optional)</b> |                                                                                                                                                                                                  |                                                                              |                                                                              |
| Signal                            | Associated Parameters                                                                                                                                                                            | MC                                                                           | PHY                                                                          |
| <b>dfi_error</b>                  | <b>terror_resp</b>                                                                                                                                                                               | Supported for all DRAM types.<br>Required when error interface is supported. | Supported for all DRAM types.<br>Required when error interface is supported. |
| <b>dfi_error_info</b>             | <b>terror_resp</b>                                                                                                                                                                               | Optional.                                                                    | Optional.                                                                    |

**TABLE 4.** *DFI Signal Requirements*

| Low Power Control Interface<br>(optional) |                                                                                                     |                                                                        |                                                                        |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------|
| Signal                                    | Associated Parameters                                                                               | MC                                                                     | PHY                                                                    |
| <code>dfi_lp_ctrl_ack</code>              | $t_{lp\_resp}$<br>$t_{lp\_ctrl\_wakeup}$                                                            | Supported for all DRAM types.<br>Required when low power is supported. | Supported for all DRAM types.<br>Required when low power is supported. |
| <code>dfi_lp_ctrl_req</code>              | $t_{lp\_resp}$                                                                                      | Supported for all DRAM types.<br>Required when low power is supported. | Supported for all DRAM types.<br>Required when low power is supported. |
| <code>dfi_lp_ctrl_wakeup</code>           | $t_{lp\_ctrl\_wakeup}$                                                                              | Supported for all DRAM types.<br>Required when low power is supported. | Supported for all DRAM types.<br>Required when low power is supported. |
| <code>dfi_lp_data_ack</code>              | $t_{lp\_resp}$<br>$t_{lp\_data\_wakeup}$                                                            | Supported for all DRAM types.<br>Required when low power is supported. | Supported for all DRAM types.<br>Required when low power is supported. |
| <code>dfi_lp_data_req</code>              | $t_{lp\_resp}$                                                                                      | Supported for all DRAM types.<br>Required when low power is supported. | Supported for all DRAM types.<br>Required when low power is supported. |
| <code>dfi_lp_data_wakeup</code>           | $t_{lp\_data\_wakeup}$                                                                              | Supported for all DRAM types.<br>Required when low power is supported. | Supported for all DRAM types.<br>Required when low power is supported. |
| MC to PHY Message Interface               |                                                                                                     |                                                                        |                                                                        |
| Signal                                    | Associated Parameters                                                                               | MC                                                                     | PHY                                                                    |
| <code>dfi_ctrlmsg</code>                  |                                                                                                     | Optional.                                                              | Optional.                                                              |
| <code>dfi_ctrlmsg_ack</code>              | $t_{ctrlmsg\_resp}$<br>$t_{ctrlmsg\_max}$                                                           | Optional.                                                              | Optional.                                                              |
| <code>dfi_ctrlmsg_data</code>             |                                                                                                     | Optional.                                                              | Optional.                                                              |
| <code>dfi_ctrlmsg_req</code>              |                                                                                                     | Optional.                                                              | Optional.                                                              |
| WCK Control Interface                     |                                                                                                     |                                                                        |                                                                        |
| Signal                                    | Associated Parameters                                                                               | MC                                                                     | PHY                                                                    |
| <code>dfi_wck_cs_pN</code>                | $t_{wck\_toggle\_cs}$<br>$t_{wck\_toggle\_post}$                                                    | Required for LPDDR5 DRAMs.                                             | Required for LPDDR5 DRAMs.                                             |
| <code>dfi_wck_en_pN</code>                | $t_{wck\_dis}$<br>$t_{wck\_en\_fs}$<br>$t_{wck\_en\_rd}$<br>$t_{wck\_en\_wr}$<br>$t_{wck\_en\_wrx}$ | Required for LPDDR5 DRAMs.                                             | Required for LPDDR5 DRAMs.                                             |

**TABLE 4.** *DFI Signal Requirements*

|                          |                                                                                                                                               |                                                          |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| <b>dfi_wck_toggle_pN</b> | <b>t<sub>wck_fast_toggle</sub></b><br><b>t<sub>wck_toggle</sub></b><br><b>t<sub>wck_toggle_cs</sub></b><br><b>t<sub>wck_toggle_post</sub></b> | Required for LPDDR5 DRAMs.<br>Required for LPDDR5 DRAMs. |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|

- a. For frequency ratio systems, replicates signals into phase/data word/clock cycle-specific buses that define the validity of the data for each phase N (*pN*)/data word N (*wN*)/clock cycle N (*aN*), as applicable. The phase 0 suffixes are not required.
- b. Other DRAMs must hold this signal in the idle state.

## 2.4 Definition of a Slice

All slices are expected to be identical but since the alignment of data to the interface is expected to be defined by the MC and the PHY, there is flexibility in the connection. Some systems do not have a data width that aligns to a slice boundary. But, since not all data bits are required to be connected, this is allowable. The **phydata\_slice\_width** programmable parameter will resolve this issue and define how the MC and PHY place data so that any alignment issues can be resolved.

This parameter is defined by the PHY and specifies the width of a common slice component. It is acceptable for the PHY to have slices that are less than the defined slice width. In this scenario, the DFI data bit disables would be utilized to define which bits are not available.

The programmable parameter associated with the data slice definition is listed in Table 5, “DFI Data Slice Definition Programmable Parameters”.

**TABLE 5.** *DFI Data Slice Definition Programmable Parameters*

| Parameter                  | Defined By | Description                                                                                                                                                                                               |
|----------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phydata_slice_width</b> | PHY        | PHY Data Slice Width. Defines the width of a common PHY data slice component. All slices are defined having the same width. Unused bits can be disabled by using the <b>dfidata_bit_enable</b> parameter. |

The number of PHY slices is determined by dividing the DFI Data Width by the **phydata\_slice\_width** parameter. The MC and PHY must define the DFI Data Width of the device in terms of slices even if the device does not implement all of the signals. The unused signals should be clearly defined in terms of bit location by using the **dfidata\_bit\_enable** parameter. Otherwise, the number of slices might not be deterministic.

The MC might have more input signals than defined for PHY-driven signals on the interface. The MC must be able to operate with these signals tied inactive at the MC. The DFI Data Width for the MC and PHY can be less than the width defined for the interface as previously discussed. In this case, the MC and/or PHY must clearly define how the data signals are to be connected to the slice-based interface. Any “no connects” to the interface should be clearly defined.

## 3.0 Interface Signal Groups

### 3.1 Command Interface

The command interface handles the transmission of signals required to drive the address and command signals to the DRAM devices; the interface includes signals and timing parameters. The signals are intended to be passed to the DRAM or DIMM devices in a manner that maintains the timing relationship among the signals on the DFI; the  $t_{ctrl\_delay}$  timing parameter defines the delay introduced between the DFI interface and the host command interface.

#### 3.1.1 Mapping the CA Bus to the **dfi\_address** Bus

For newer memories, a CA bus exists to the memory. This is not relevant for DDR1, LPDDR1, DDR2, DDR3 or DDR4 memories.

For low power memories and the latest DDR DRAMs, the CA bus is mapped onto to the **dfi\_address** bus. The following signals must be held at constant values when present in any of these implementations: **dfi\_cid**, **dfi\_bank**, **dfi\_bg**, **dfi\_act\_n**, **dfi\_ras\_n**, **dfi\_cas\_n**, and **dfi\_we\_n**. Special mapping is required for LPDDR2, LPDDR3, LPDDR5 and DDR5 memories.

For LPDDR2 and LPDDR3 memories, the **dfi\_address** bus must have a minimum of 20 bits to hold the rising and falling DDR CA bus for the entire clock period. The PHY is responsible for transmitting the 20-bit **dfi\_address** bus as a double data rate 10-bit output, transmitting to the LPDDR2 or LPDDR3 DRAM on the rising and falling CA phases. The LPDDR2/LPDDR3 interface mapping is detailed in Table 6, “Bit Definitions of the **dfi\_address** bus for LPDDR2 and LPDDR3”.

**TABLE 6.** Bit Definitions of the **dfi\_address** bus for LPDDR2 and LPDDR3

| <b>dfi_address</b> |  | 19              | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9               | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------|--|-----------------|----|----|----|----|----|----|----|----|----|-----------------|---|---|---|---|---|---|---|---|---|
| CA Bus             |  |                 |    |    |    |    |    |    |    |    |    | LPDDR2/LPDDR3 1 |   |   |   |   |   |   |   |   |   |
|                    |  | 9               | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  | 9               | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CA Bus             |  | LPDDR2/LPDDR3 2 |    |    |    |    |    |    |    |    |    |                 |   |   |   |   |   |   |   |   |   |
|                    |  | 9               | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                 |   |   |   |   |   |   |   |   |   |

For LPDDR4, the CA bus is a SDR (single data rate) CA bus; therefore, the **dfi\_address** bus is 6 bits wide.

For LPDDR5, the CA bus is a 7-bit DDR (double data rate) interface. Since the **dfi\_address** is a single phase signal for LPDDR5, the CA bus phases are concatenated such that the rising edge CA is on the lower 7 bits and the falling edge CA is on the upper 7 bits.

**TABLE 7.** Bit Definitions of the **dfi\_address** bus for LPDDR5

| <b>dfi_address</b> |  | 13     | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
|--------------------|--|--------|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| CA Bus             |  |        |    |    |    |   |   |   |   |   |   | LPDDR5 |   |   |   |
|                    |  | 6      | 5  | 4  | 3  | 2 | 1 | 0 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| CA Bus             |  | LPDDR5 |    |    |    |   |   |   |   |   |   |        |   |   |   |
|                    |  | 6      | 5  | 4  | 3  | 2 | 1 | 0 |   |   |   |        |   |   |   |

---

## Interface Signal Groups

---

For DDR5 without RCD, the CA bus is an SDR (single data rate) CA bus; therefore, the **dfi\_address** bus width is matched to the DDR5 CA bus width. For 1N mode, the CA bus values are driven on the **dfi\_address** bus for 1 DFI clock in matched frequency or 1 clock phase for frequency ratio. For 2N mode, the CA bus values are driven on the **dfi\_address** bus for 2 DFI clocks in matched frequency or 2 clock phases for frequency ratio. The command can start on any clock phase and for multi-clock commands, must continue for consecutive clocks or phases until the command is complete.

For DDR5 with RCD, the DRAM's 14-bit CA bus is reduced to a 7-bit CA bus between the PHY and RCD. In 1N mode, it is DDR (double data rate); therefore, the **dfi\_address** bus width is 14 bits, with the rising edge CA bits on the lower 7 bits and the falling edge CA bits on the upper 7 bits. (The 14-bit concatenated **dfi\_address** signal corresponds to the 14-bit DRAM CA bus.) In 2N mode, it is SDR (single data rate) split across 2 memory cycles (i.e. 2 DFI phases), with the DRAM's lower 7 bits sent in the first phase and the upper 7 bits sent in the second phase; therefore, the **dfi\_address** bus width is 7 bits. To ensure backwards compatibility with older designs, in 2N mode, a MC must drive **dfi\_address[13:7]** (if present) with a replica of **dfi\_address[6:0]**, and a PHY must ignore **dfi\_address[13:7]** (if present) and only use **dfi\_address[6:0]**. In either mode, the command can start on any clock phase and for multi-clock commands, must continue for consecutive clocks or phases until the command is complete.

---

**TABLE 8.** Bit Definitions of the **dfi\_address** bus for DDR5 with RCD in 1N Mode

|                    |  |            |    |    |    |   |   |   |            |   |   |   |   |   |   |
|--------------------|--|------------|----|----|----|---|---|---|------------|---|---|---|---|---|---|
| <b>dfi_address</b> |  | 13         | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
| CA Bus             |  |            |    |    |    |   |   |   | DDR5 Lower |   |   |   |   |   |   |
|                    |  |            |    |    |    |   |   |   | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|                    |  | DDR5 Upper |    |    |    |   |   |   |            |   |   |   |   |   |   |
|                    |  | 6          | 5  | 4  | 3  | 2 | 1 | 0 |            |   |   |   |   |   |   |

---

**TABLE 9.** Bit Definitions of the **dfi\_address** bus for DDR5 with RCD in 2N Mode

|                    |  |                      |    |    |    |   |   |   |            |   |   |   |   |   |   |
|--------------------|--|----------------------|----|----|----|---|---|---|------------|---|---|---|---|---|---|
| <b>dfi_address</b> |  | 13                   | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
| CA Bus             |  | DDR5 Lower (replica) |    |    |    |   |   |   | DDR5 Lower |   |   |   |   |   |   |
|                    |  | 6                    | 5  | 4  | 3  | 2 | 1 | 0 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>dfi_address</b> |  | 13                   | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
| CA Bus             |  | DDR5 Upper (replica) |    |    |    |   |   |   | DDR5 Upper |   |   |   |   |   |   |
|                    |  | 6                    | 5  | 4  | 3  | 2 | 1 | 0 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |

Note: Bits [13:7] only apply to an MC and must be ignored by a PHY.

DDR5 MRDIMMs can be run in Rank Mode or Mux Mode. For DDR5 MRDIMM in Rank Mode, the CA bus is mapped to the **dfi\_address** bus in the same way as DDR5 with RCD.

For DDR5 MRDIMM in Mux Mode in 1N, the CA bus is mapped to the **dfi\_address** bus in a similar way as DDR5 with RCD's 1N Mode and the CA bus operates at double-data rate. For DDR5 MRDIMM in Mux Mode in 2N, this is also true except that the command interface runs at half the frequency of the data interfaces.

In DDR5 MRDIMM in Mux Mode, two pseudo-channels (PS0 and PS1) are interleaved on the same host interface. The command interface is interleaved per-host-clock cycle. Each phase of the **dfi\_address** bus represents a single cycle on the

host interface. To achieve pseudo-channel interleaving, alternating phases are used for alternating pseudo-channels. (i.e. Even phases are used for pseudo-channel 0, and odd phases are used for pseudo-channel 1.)

---

**TABLE 10.** Bit Definitions of the **dfi\_address** bus for DDR5 MRDIMM Mux Mode in 1N and 2N Mode

| dfi_address |                                                                                   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
|-------------|-----------------------------------------------------------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| CA Bus      |  |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|             |  |    |    |    |    |   |   |   |   |   |   |   |   |   | DDR5 Lower    |
|             |  |    |    |    |    |   |   |   | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
| DDDR5 Upper |                                                                                   |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|             |                                                                                   |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|             |                                                                                   |    |    |    |    |   |   |   |   |   |   |   |   |   | 6 5 4 3 2 1 0 |

### 3.1.2 Clock Disabling

The **dfi\_dram\_clk\_disable** signal is used by the MC to inform the PHY when to enable/disable the host command clock. The timing parameters **t<sub>dram\_clk\_disable</sub>** and **t<sub>dram\_clk\_enable</sub>** define the timing of the host interface clock enable/disable relative to the **dfi\_dram\_clk\_disable** signal.

For more information on the host clock controls, refer to Section 4.10, “Frequency Ratios Across the DFI”.

### 3.1.3 Frequency Ratio Systems

For command frequency ratio systems, the buses/signals of the command interface are replicated into phase-specific signals with a suffix of “\_pN” that defines the signal value for each phase N of the DFI clock. Phase 0 may exclude the suffix if desired. The MC may issue commands on any phase to communicate with the PHY. For example, the MC may issue commands only on a single phase, such as phase 0, or may issue commands on any combination of phases; the PHY must be able to accept a command on any and all phases.

### 3.1.4 CA Parity and Parity/CRC Errors

The CA parity and alert support signals are provided specifically when these features are supported. In these cases, additional IO pins are included to receive command (CA) parity, communicate command parity, and communicate command parity or write CRC error status (alert). In systems that require command parity support, the MC communicates its command parity setting on the **dfi\_parity\_in** signal. In systems that require either CRC or command parity support, the PHY reports CRC or command parity errors on the **dfi\_alert\_n** signal. For more information on alert support signals, refer to Section 3.2.3, “Write Data CRC”, Section 3.1.7, “Command Signals and Parameters”, and Section 4.12, “CA Parity Signaling and CA Parity, CRC Errors”.

### 3.1.5 2N Mode Interface

Some DRAMs include a 2N mode (also referred to as the geardown mode in DDR4 memories) for enabling command bus operation at high frequencies. Previously, systems would use 2T operation for increasing setup and hold times on the command bus. With 2N mode, all command/address (CA) bus signals can benefit from larger setup and hold times. In addition, for DDR4 memories operating in Geardown mode, the CS signals can also benefit from larger setup and hold times.

Larger setup and hold times are accomplished by operating the CA bus at  $\frac{1}{2}$  the frequency of memory clock. The DRAM internally samples the bus every other clock. This is not a requirement for all memory types. For DDR4 operating in Geardown mode, the MC can change CA and CS signals only every other Command clock as defined by the

synchronization pulse from the PHY. For DDR5 without RCD operating in 2N mode, the MC can change the CA signals only every other Command clock, however there is no synchronization pulse and no restrictions on the alignment.

For 2N mode, for DDR4 or DDR5 without RCD, the PHY might need to change the alignment of the memory command's CA and/or CS relative to the memory clock. In normal operation, the memory command is generally aligned to the falling edge of the memory clock to center on the following rising edge. In 2N mode, the command should be aligned to the command's first clock rising edge to center on the command's second clock rising edge. To accomplish this, the PHY receives notice when the memory changes between normal mode and 2N mode via the **dfi\_2n\_mode** signal.

For DDR5 with RCD, when the **dfi\_2n\_mode** signal = 'b0, the MC must drive CA signals following double data rate rules, and when the **dfi\_2n\_mode** signal = 'b1, the MC must drive CA signals following single data rate rules. Refer to Section 4.7.6, "CA Bus Timing" for more information. The PHY does not make additional adjustments to the DCA to DCK timing.

For DDR5 MRDIMM, the **dfi\_2n\_mode** signal is used to indicate whether the CA bus uses double data rate (**dfi\_2n\_mode** = 'b0) or single data rate (**dfi\_2n\_mode** = 'b1) operation. In Rank Mode, this operates the same as DDR5 with RCD. In Mux mode, **dfi\_2n\_mode** = 'b0 in both 1N and 2N mode, however in 1N mode **dfi\_cmd\_freq\_ratio** equals **dfi\_data\_freq\_ratio** and in 2N mode **dfi\_cmd\_freq\_ratio** is half of **dfi\_data\_freq\_ratio**. Refer to Section 4.7.6, "CA Bus Timing" for more information. The PHY does not make additional adjustments to the DCA to DCK timing.

The signal associated with the 2N mode interface is listed in Table 13, "Command Interface Signals".

Table 14, "Command Interface Timing Parameters" defines a 2N mode timing parameter.

The programmable parameter associated with the 2N mode is listed in Table 11, "2N Mode Programmable Parameter".

---

**TABLE 11. 2N Mode Programmable Parameter**

| Parameter                    | Defined By | Description                                                                                                                                                                                               |
|------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi<sub>2n</sub>_mode</b> | SYS        | Indicates the initial operating state following the boot sequence when the PHY asserts <b>dfi_init_complete</b> . <ul style="list-style-type: none"><li>• 'b0 = 1N Mode</li><li>• 'b1 = 2N Mode</li></ul> |

### 3.1.6 DDR5 CS Gardown Mode Interface

Some DDR5 DRAMs include a CS gardown mode for easing CS timing at high frequencies. With CS gardown mode, CS bus signals can benefit from larger setup and hold times. In addition, for DDR5 memories operating in CS gardown mode, the 2N command timing is required. As a result, CA signals also benefit from larger setup and hold times.

Larger setup and hold times are accomplished by operating the CS bus at half the frequency of the memory clock. This means that the DRAM internally samples the bus every other clock. For DDR5 devices operating in CS gardown mode, the MC can change CS signals only every other Command clock cycle as defined by the CS Gardown synchronization pulse from the PHY.

For CS gardown mode, the PHY might need to change the alignment of the memory command's CS relative to the memory clock. In normal operation, the CS is generally aligned to the falling edge of the memory clock to center on the following rising edge. In CS gardown mode, the CS should be aligned to the command's first clock rising edge to center on the command's second clock rising edge. To accomplish this, the PHY receives notice when the memory changes between normal mode and CS gardown mode via the **dfi\_cs\_gardown** signal.

---

## Interface Signal Groups

---

The signal associated with CS geardown mode interface is listed in Table 13, “Command Interface Signals”.

Table 14, “Command Interface Timing Parameters” defines a CS geardown mode timing parameter.

The programmable parameter associated with CS geardown mode is listed in Table 12, “DDR5 CS Geardown Mode Programmable Parameter”.

---

**TABLE 12. DDR5 CS Geardown Mode Programmable Parameter**

| Parameter                        | Defined By | Description                                                                                                                                                                                                                                  |
|----------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi<sub>cs</sub>_geardown</b> | SYS        | Indicates the initial operating state following the boot sequence when the PHY asserts <b>dfi_init_complete</b> . <ul style="list-style-type: none"><li>• 'b0 = CS geardown mode disabled</li><li>• 'b1 = CS geardown mode enabled</li></ul> |

### 3.1.7 Command Signals and Parameters

The signals and parameters associated with the command interface are listed in Table 13, “Command Interface Signals”, Table 14, “Command Interface Timing Parameters”, and Table 11, “2N Mode Programmable Parameter”. For more information on the command interface, refer to Section 4.3, “Command Interface Signals”. For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

---

**TABLE 13. Command Interface Signals**

| Signal                                                        | From | Width | Default        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------|------|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_2n_mode</b><br>or<br><b>dfi_2n_mode_pN<sup>a</sup></b> | MC   | 1 bit | 0x0            | <u>DFI 2N Mode</u> . When de-asserted, the MC and PHY operate normally. When asserted, the MC and PHY operate in 2N mode.<br><br>When asserted for DDR4, the MC can change CA and CS signals only every other Command clock as defined by the synchronization pulse from the PHY.<br><br>When asserted for DDR5 without RCD, the MC must hold the CA signals for at least 1 Command clock cycle after the CS is active. There is no alignment requirement between commands.<br><br>For DDR5 with RCD, the MC must switch from double data rate to single data rate format. |
| <b>dfi_act_n</b><br>or<br><b>dfi_act_n_pN<sup>a</sup></b>     | MC   | 1 bit | - <sup>b</sup> | <u>DFI activate signal</u> . This signal is used for encoding DRAM commands. The following signals define all or a subset of the command encoding: <b>dfi_act_n</b> , <b>dfi_cas_n</b> , <b>dfi_ras_n</b> , <b>dfi_we_n</b> .                                                                                                                                                                                                                                                                                                                                              |

**TABLE 13.** Command Interface Signals

| Signal                                                        | From | Width                | Default          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------------|------|----------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_address</b><br>or<br><b>dfi_address_pN<sup>a</sup></b> | MC   | DFI Address Width    | - <sup>b,c</sup> | <p><u>DFI address bus</u>. These signals define the address information.</p> <p>The PHY must preserve the bit ordering of the <b>dfi_address</b> signals when it sends this data to the DRAM devices.</p> <p>For DDR4 DRAMs, the <b>dfi_address</b> bus defines the column address and a portion of the row address. DDR4 devices do not use the <b>dfi_address</b> bits [16:14] since DDR4 devices transmit the row address bits [16:14] on <b>dfi_ras_n</b>, <b>dfi_cas_n</b> and <b>dfi_we_n</b>.</p> <p>For larger density devices, <b>dfi_address</b> bits A17 and above are utilized. Consequently, when a larger density device interfaces with a DDR4 system, there can be gaps in the address bus.</p> <p>For systems that support multiple DRAM classes, all or a subset of the <b>dfi_address</b> bits [16:14] can be used to address a non-DDR4 DRAM.</p> <p>For memories that use a CA bus, the CA bus maps to the <b>dfi_address</b> bus as described in Section 3.1.1, “Mapping the CA Bus to the <b>dfi_address</b> Bus”.</p> |
| <b>dfi_alert_n</b><br>or<br><b>dfi_alert_n_aN<sup>a</sup></b> | PHY  | DFI Alert Width      | 0x1              | <p><u>CRC or parity error indicator</u>. This signal is driven when a CRC or command parity error is detected in the memory system. The PHY is not required to distinguish between a CRC and command parity error. The PHY holds the current state until the PHY error input transitions to a new value; the pulse width of the <b>dfi_alert_n</b> signal matches the pulse width of the DRAM subsystem error signal, plus or minus synchronization cycles.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>dfi_bank</b><br>or<br><b>dfi_bank_pN<sup>a</sup></b>       | MC   | DFI Bank Width       | - <sup>b</sup>   | <p><u>DFI bank bus</u>. These signals define the bank information.</p> <p>The PHY must preserve the bit ordering of the <b>dfi_bank</b> signals when it sends the DFI bank data to the DRAM devices.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>dfi_bg</b><br>or<br><b>dfi_bg_pN<sup>a</sup></b>           | MC   | DFI Bank Group Width | - <sup>b</sup>   | <p><u>DFI bank group</u>. This signal defines the bank group of a command. The PHY must preserve the bit ordering of the <b>dfi_bg</b> signals when it sends the DFI bank group data to the DRAM devices.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>dfi_cas_n</b><br>or<br><b>dfi_cas_n_pN<sup>a</sup></b>     | MC   | 1 bit                | 0x1 <sup>d</sup> | <p><u>DFI column address strobe</u>. This signal is used for encoding DRAM commands. The following signals define all or a subset of the command encoding: <b>dfi_act_n</b>, <b>dfi_cas_n</b>, <b>dfi_ras_n</b>, <b>dfi_we_n</b>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>dfi_cid</b><br>or<br><b>dfi_cid_pN<sup>a</sup></b>         | MC   | DFI Chip ID Width    | 0 <sup>e</sup>   | <p><u>DFI chip ID</u>. This signal defines the chip ID. This signal is required for 3D stacked solutions.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>dfi_cke</b><br>or<br><b>dfi_cke_pN<sup>a</sup></b>         | MC   | DFI CKE Width        | - <sup>f</sup>   | <p><u>DFI clock enable</u>. This signal defines the clock enable.</p> <p>The MC must drive CKE signals in all phases. The PHY must be able to accept a command on any and all phases for DFI frequency ratio compliance.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**TABLE 13.** Command Interface Signals

| Signal                                                                          | From | Width                      | Default                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------------------------------------------|------|----------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_cs</b><br>or<br><b>dfi_cs_pN<sup>a</sup></b>                             | MC   | DFI Chip Select Width      | 0x1                                  | <u>DFI chip select</u> . This signal defines the chip select. The polarity of this signal is defined by the polarity of the corresponding memory signal. For 3DS operation, also refer to the <b>dfi_cid</b> signal.                                                                                                                                                                                                                                                                                                                                                                        |
| <b>dfi_cs_gardown</b><br>or<br><b>dfi_cs_gardown_pN<sup>a</sup></b>             | MC   | 1 bit                      | 0x0                                  | <u>DFI CS gardown</u> . When de-asserted, the MC and PHY operate normally. When asserted, the MC and PHY operate in CS Gardown mode. When asserted, the MC must hold the CS signals for at least 2 Command clock cycles.                                                                                                                                                                                                                                                                                                                                                                    |
| <b>dfi_dram_clk_disable</b><br>or<br><b>dfi_dram_clk_disable_pN<sup>a</sup></b> | MC   | DFI DRAM Clk Disable Width | 0x0 <sup>g</sup>                     | <u>DRAM clock disable</u> . When active, this indicates to the PHY that the Command clocks to the memory devices must be disabled such that the clock signals hold a constant value. When the <b>dfi_dram_clk_disable</b> signal is inactive, the memories should be clocked normally.                                                                                                                                                                                                                                                                                                      |
| <b>dfi_odt</b><br>or<br><b>dfi_odt_pN<sup>a</sup></b>                           | MC   | DFI ODT Width              | 0x0                                  | <u>DFI on-die termination control bus</u> . These signals define the ODT. The MC must drive ODT signals in all phases. The PHY must be able to accept a command on any and all phases for DFI frequency ratio compliance.                                                                                                                                                                                                                                                                                                                                                                   |
| <b>dfi_parity_in</b><br>or<br><b>dfi_parity_in_pN<sup>a</sup></b>               | MC   | 1 bit                      | 0x0 <sup>h</sup><br>0x1 <sup>e</sup> | <u>Parity value</u> . This signal has a one-to-one correspondence with each DFI command and is valid for 1 cycle. This value applies to the <b>dfi_address</b> , <b>dfi_bank</b> , <b>dfi_bg</b> , <b>dfi_act_n</b> , <b>dfi_cas_n</b> , <b>dfi_cid</b> , <b>dfi_ras_n</b> and <b>dfi_we_n</b> signals. This signal is relevant for only systems that support command parity. <ul style="list-style-type: none"> <li>• 'b0 = An even number of the parity value signals are electrically high.</li> <li>• 'b1 = An odd number of the parity value signals are electrically high.</li> </ul> |
| <b>dfi_ras_n</b><br>or<br><b>dfi_ras_n_pN<sup>a</sup></b>                       | MC   | 1 bit                      | 0x1 <sup>d</sup>                     | <u>DFI row address strobe</u> . This signal is used for encoding DRAM commands. The following signals define all or a subset of the command encoding: <b>dfi_act_n</b> , <b>dfi_cas_n</b> , <b>dfi_ras_n</b> , <b>dfi_we_n</b> .                                                                                                                                                                                                                                                                                                                                                            |
| <b>dfi_reset_n</b><br>or<br><b>dfi_reset_n_pN<sup>a</sup></b>                   | MC   | DFI Reset Width            | - <sup>i</sup>                       | <u>DFI reset bus</u> . These signals define the RESET. The PHY must preserve the bit ordering of the <b>dfi_reset_n</b> signals when it sends the DFI chip ID data to the DRAM devices.                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>dfi_we_n</b><br>or<br><b>dfi_we_n_pN<sup>a</sup></b>                         | MC   | 1 bit                      | 0x1 <sup>d</sup>                     | <u>DFI write enable signal</u> . This signal is used for encoding DRAM commands. The following signals define all or a subset of the command encoding: <b>dfi_act_n</b> , <b>dfi_cas_n</b> , <b>dfi_ras_n</b> , <b>dfi_we_n</b> .                                                                                                                                                                                                                                                                                                                                                           |

- a. For frequency ratio systems, replicates signals into phase/data word/clock cycle-specific buses that define the validity of the data for each phase N (pN)/data word N (wN)/clock cycle N (aN), as applicable. The phase 0 suffixes are not required.
- b. This signal is not meaningful during initialization; no default value is required.
- c. For memory systems that use a CA bus, the **dfi\_address** bus must be driven with a DES until **dfi\_init\_complete** is asserted.

---

## Interface Signal Groups

---

- d. This signal has multiple purposes with DDR4 devices. For all commands that have **dfi\_act\_n** de-asserted, this signal communicates command encoding similar to the functionality defined for other DRAM devices. When **dfi\_act\_n** is asserted, the signal transmits upper row address bits with the following address mapping: **dfi\_cas\_n** → A15, **dfi\_ras\_n** → A16, **dfi\_we\_n** → A14.
- e. This signal initializes to 0 during initialization; a default value of 0 is required.
- f. The MC is expected to drive the **dfi\_cke** signal with appropriate value as per the state of the memory defined in the **dfi\_boot\_state** programmable parameter.
- g. When **dfi\_init\_start** is asserted during initialization, **dfi\_dram\_clk\_disable** must indicate the clocks that are being used. In normal operation, this signal can dynamically change.
- h. The value of this signal must be driven with the correct parity for the selected command interface signals.
- i. The MC is expected to drive the **dfi\_reset\_n** signal with appropriate value as per the state of the memory defined in the **dfi\_boot\_state** programmable parameter.

The timing parameters associated with the command interface are listed in Table 14, “Command Interface Timing Parameters”.

---

**TABLE 14. Command Interface Timing Parameters**

| Parameter                                        | Defined By | Min | Max               | Unit                 | Description                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------|------------|-----|-------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>2n_mode</sub>_delay</b>                 | PHY        | 0x0 | - <sup>a</sup>    | Command clock cycles | The delay from <b>dfi_2n_mode</b> assertion to the time that the PHY is ready to receive commands.                                                                                                                                                                                                                             |
| <b>t<sub>cmd</sub>_lat</b>                       | MC         | 0x0 | - <sup>a</sup>    | Command clock cycles | Specifies the number of Command clocks after the <b>dfi_cs</b> signal is asserted until the associated CA signals are driven.                                                                                                                                                                                                  |
| <b>t<sub>cs_gardown</sub>_delay</b>              | PHY        | 0x0 | - <sup>a</sup>    | Command clock cycles | The delay from <b>dfi_cs_gardown</b> assertion to the time that the PHY is ready to receive <b>dfi_cs</b> with gardown timing.                                                                                                                                                                                                 |
| <b>t<sub>ctrl</sub>_delay</b>                    | PHY        | 0x0 | - <sup>a</sup>    | Command clock cycles | Specifies the number of Command clock cycles from the time that any command signal changes and when the change reaches the host command interface.<br>If the DFI clock and the host command clock are not phase-aligned, this timing parameter should be rounded up to the next integer value.                                 |
| <b>t<sub>dram_clk_disable</sub></b> <sup>b</sup> | PHY        | 0x1 | - <sup>b, c</sup> | Command clock cycles | Specifies the number of Command clock cycles from the assertion of the first phase of the <b>dfi_dram_clk_disable_pN</b> signal on the DFI until the clock on the host interface maintains a low value.<br>NOTE: This parameter may be specified as a fixed value, or as a constant based on other fixed values in the system. |

**TABLE 14.** Command Interface Timing Parameters

| Parameter                            | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------|------------|-----|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{dram\_clk\_enable}$ <sup>b</sup> | PHY        | 0x1 | - <sup>c</sup> | Command clock cycles | <p>Specifies the number of Command clock cycles from the de-assertion of the first phase of the <b>dfi_dram_clk_disable_pN</b> signal on the DFI until the first valid rising edge of the clock on the host interface.</p> <p>NOTE: This parameter may be specified as a fixed value, or as a constant based on other fixed values in the system.</p> |
| $t_{parin\_lat}$                     | MC         | 0x0 | -              | Command clock cycles | Specifies the number of Command clocks between when the DFI command is asserted and when the associated <b>dfi_parity_in</b> signal is driven.                                                                                                                                                                                                        |
| $t_{phy\_paritylat}$                 | PHY        | 0x4 | -              | Command clock cycles | Specifies the maximum number of Command clock cycles between when the <b>dfi_parity_in</b> signal is driven and when the associated <b>dfi_alert_n</b> signal is returned.                                                                                                                                                                            |

- a. The minimum supportable value is 0; the DFI specification does not specify a maximum value. The range of values supported is implementation-specific.
- b. If the DFI clock and the host clock are not phase-aligned, this timing parameter should be rounded up to the next integer value.
- c. The minimum supportable value is 1; the DFI specification does not specify a maximum value. The range of values supported is implementation-specific.

## 3.2 Write Data Interface

The write data interface handles the transmission of write data across the DFI from the MC to the PHY; this interface includes signals, timing parameters and programmable parameters related to write data transfers.

Table 15, “Write Data Interface Signals” describes the signals **dfi\_wrdata** (write data bus), **dfi\_wrdata\_crc** (write data link CRC), **dfi\_wrdata\_cs** (write data chip select), **dfi\_wrdata\_ecc** (write data link ECC), **dfi\_wrdata\_en** (write data enable) and **dfi\_wrdata\_mask** (write data byte mask or DBI).

The **dfi\_wrdata** bus transfers write data from the MC to the PHY. The **dfi\_wrdata\_en** signal indicates to the PHY that valid **dfi\_wrdata**, **dfi\_wrdata\_crc**, and **dfi\_wrdata\_mask** will be transmitted in  $t_{phy\_wrdata}$  cycles.

In DDR5 MRDIMM Mux Mode, two pseudo-channels (PS0 and PS1) are interleaved on the same host interface. On the write data interface, the combination of both pseudo-channels together forms a single, extra-long burst, delimited by a common **dfi\_wrdata\_en** signal. Each phase of the **dfi\_wrdata** bus represents a single double-data-rate cycle on the host interface. To achieve pseudo-channel interleaving, the write data is interleaved per-strobe-edge; therefore, each phase contains data for both pseudo-channels. (i.e. Rising edge data is used for pseudo-channel 0, and falling edge data is used for pseudo-channel 1.)

### 3.2.1 Write Data Mask/Write DBI

The **dfi\_wrdata\_mask** signal has two functions. If the DBI feature (described in Section 4.6, “Data Bus Inversion”) is not enabled, **dfo\_wrdata\_mask** defines the bytes within the **dfo\_wrdata** signals that will be written to DRAM. Alternately, if

the DBI feature is enabled and `phy_dbi_mode` = 0, the `dfi_wrdata_mask` signal becomes a write DBI signal and indicates whether the write data is inverted. When both functions are enabled, refer to the JEDEC specification for the use of the `dfi_wrdata_mask` signal.

### 3.2.2 Write Data Chip Select

If data chip select is enabled, the `dfi_wrdata_es` signal indicates the corresponding chip select which is accessed for the associated write data to independently compensate for timing differences on the data interface accessing different chip selects.

- In a 3DS solution, control and MRW activities are to be limited to physical ranks.
- For UDIMM or RDIMM solutions, each physical rank requires its own `dfi_wrdata_es` signal to select the host interface timing for the required update when transitioning between ranks. For example, a 2 DIMM-per-channel system of 2-rank UDIMMs or RDIMMs requires `dfi_wrdata_es` signal bits.
- For DDR5 MRDIMM solutions:
  - DDR5 MRDIMM is similar to 3DS; logical rank switching does not require any host timing update.
  - Each MRDIMM / MDB device set provides a single host interface timing for the entire DIMM, regardless of the PS or rank that is being accessed. The number of active `dfi_wrdata_es` signal bits is per-DIMM regardless of the number of active `dfi_es` signal bits within a single DIMM. Back-side switching from one PS or rank to another PS or rank is handled transparently by the MDB.
  - For a single DIMM-per-channel system, the MDBs control the timing to the DRAMs on that DIMM. The host (PHY) interface timing does not have to be updated based on the PS or rank. This requires 1 `dfi_wrdata_es` signal bit.
  - For 2 DIMM-per-channel systems, each DIMM's MDBs control the timing to the DRAMs on that DIMM. The host (PHY) interface timing will need to be updated based on the DIMM selected. This requires 2 `dfi_wrdata_es` signal bits.
- Refer to section Section 4.23, “Use of the `dfi_rddata_es` / `dfi_wrdata_es` Signal with DDR5 DIMMs” for more examples.

### 3.2.3 Write Data CRC

#### 3.2.3.1 Write DRAM CRC

Write DRAM CRC and Write Link CRC are mutually exclusive.

If the MC generates the DRAM CRC, the MC sends the appropriate CRC data word across the DFI bus using the existing `dfi_wrdata` signals and adjusts command signal timing to handle the additional data word.

Table 16, “Write Data Interface Timing Parameters” describes the write timing parameters  $t_{phy\_wresgap}$ ,  $t_{phy\_wreslat}$ ,  $t_{phy\_wrdata}$ ,  $t_{phy\_wrlat}$ ,  $t_{wrdata\_delay}$ ,  $t_{phy\_cremax\_lat}$  and  $t_{phy\_cremin\_lat}$ .

The  $t_{phy\_wresgap}$  timing parameter specifies the minimum number of additional Data clocks required between commands when changing the target chip select driven on the `dfi_wrdata_es` signal and defines a minimum additional delay between commands when changing the target chip select as required by the PHY. The  $t_{phy\_wreslat}$  parameter specifies the number of Data clocks between when a write command is sent on the DFI command interface and when the associated `dfi_wrdata_es` signal is asserted and has a delay defined relative to the command to maximize timing flexibility.

The **t<sub>phy\_wrdata</sub>** parameter specifies the number of Data clock cycles between when the **d<sub>fi\_wrdata\_en</sub>** signal is asserted to when the associated write data is driven on the **d<sub>fi\_wrdata</sub>** bus. The **t<sub>phy\_wrlat</sub>** parameter specifies the number of Data clock cycles between when a write command is sent on the DFI command interface and when the **d<sub>fi\_wrdata\_en</sub>** signal is asserted. The **t<sub>wrdata\_delay</sub>** parameter specifies the number of Data clocks from the time that the **d<sub>fi\_wrdata\_en</sub>** signal is asserted and when the corresponding write data transfer completes on the host interface. The PHY-defined **t<sub>phy\_cremax\_lat</sub>** and **t<sub>phy\_cremin\_lat</sub>** timing parameters create a time window around an error occurrence on the DFI bus. The sequence of events occurs as follows:

1. The PHY sends a write command, followed by associated data and CRC values to the DRAM or DIMM. A problem could arise during transmission of the values.
2. When the DRAM or DIMM compares the data and CRC values to each other, if it detects mismatch(es), it asserts the **ALERT\_N** signal on the host interface.
3. The PHY propagates the **ALERT\_N** value to the MC through the **d<sub>fi\_alert\_n</sub>** signal.

The MC can use these timing parameters to pinpoint the command or set of commands associated with the error condition and reissue commands after the CRC error is addressed. The CRC error timing parameters define the relationship between **d<sub>fi\_wrdata\_en</sub>** and **d<sub>fi\_alert\_n</sub>** signals.

Table 17, “Write Data Interface Programmable Parameters” describes the programmable parameters applicable when CRC and DBI features are enabled. When the optional CRC feature is enabled in DFI, the parameter determines whether the MC or the PHY performs CRC generation and validation. When the optional DBI feature is enabled in DFI, the PHY-defined **phy\_dbm\_mode** parameter determines whether DBI generation and data inversion is performed by the MC or the PHY.

### 3.2.3.2 Write Link CRC

Write DRAM CRC and Write Link CRC are mutually exclusive.

If the MC generates the Link CRC, the MC sends the appropriate CRC data word across the DFI bus using the **d<sub>fi\_wrdata\_crc</sub>** signal, concurrent with the **d<sub>fi\_wrdata</sub>** signal. There is one bit of the **d<sub>fi\_wrdata\_crc</sub>** signal for each byte of **d<sub>fi\_wrdata</sub>** signal.

In DDR5 MRDIMM DQ Link CRC, each byte lane uses an 8-bit CRC on 64-bit Data, transferred in 8 consecutive “pseudo-channel beats.” If only one pseudo-channel is active, the MC must drive 1’s on the **d<sub>fi\_wrdata\_crc</sub>** signal for the inactive pseudo-channel. Therefore, there is one complete CRC code word in each 8 consecutive transfers to the same pseudo-channel. Note that each pseudo-channel must be considered independently.

Table 16, “Write Data Interface Timing Parameters” describes the write timing parameters **t<sub>phy\_wresgap</sub>**, **t<sub>phy\_wreslat</sub>**, **t<sub>phy\_wrdata</sub>**, **t<sub>phy\_wrlat</sub>**, **t<sub>wrdata\_delay</sub>**, **t<sub>phy\_cremax\_lat</sub>** and **t<sub>phy\_cremin\_lat</sub>**.

The **t<sub>phy\_wrdata</sub>** parameter specifies the number of Data clock cycles between when the **d<sub>fi\_wrdata\_en</sub>** signal is asserted to when the associated write data is driven on the **d<sub>fi\_wrdata</sub>** bus. The **t<sub>phy\_wrlat</sub>** parameter specifies the number of Data clock cycles between when a write command is sent on the DFI command interface and when the **d<sub>fi\_wrdata\_en</sub>** signal is asserted. The **t<sub>wrdata\_delay</sub>** parameter specifies the number of Data clocks from the time that the **d<sub>fi\_wrdata\_en</sub>** signal is asserted and when the corresponding write data transfer completes on the host interface. The PHY-defined **t<sub>phy\_cremax\_lat</sub>** and **t<sub>phy\_cremin\_lat</sub>** timing parameters create a time window around an error occurrence on the DFI bus. The sequence of events occurs as follows:

1. The PHY sends a write command, followed by associated data and CRC values to the DIMM. A problem could arise during transmission of the values.

2. When the DIMM compares the data and CRC values to each other, if it detects mismatch(es), it asserts the ALERT\_N signal on the host interface.
3. The PHY propagates the ALERT\_N value to the MC through the **dfi\_alert\_n** signal.

The MC can use these timing parameters to pinpoint the command or set of commands associated with the error condition and reissue commands after the CRC error is addressed. The CRC error timing parameters define the relationship between **dfi\_wrdata\_en** and **dfi\_alert\_n** signals.

### **3.2.4 Frequency Ratio**

For frequency ratio systems, the signals are replicated into phase-specific signals with a suffix of “\_pN” that defines the signal value for each phase N of the DFI clock. Phase 0 may exclude the suffix if desired.

### **3.2.5 MRDIMM Mux Mode**

In DDR5 MRDIMM Mux Mode, two pseudo-channels (PS0 and PS1) are interleaved on the same host interface. The host command bus is interleaved per-clock-cycle, with one PS0 and one PS1 opportunity per pair of host command cycles. The host data bus is interleaved per-strobe-edge, with both PS0 and PS1 data in every host Data cycle and a shared burst preamble/postamble. Since the interleaving difference creates a different delay between command and data for PS0 vs PS1, the **t<sub>phy\_wrdata</sub>** parameter is nominally defined only for PS0, and PS1’s effective delay is derived relative to the paired PS0 cycle. In 1N mode, this is a 1 Data cycle difference and in 2N mode, this is a 2 Data cycle difference.

The PHY is only responsible for transferring the data bursts between the DFI and host interface, in the same manner as any other protocol. The MC is responsible for combining PS0 and PS1 data into a shared burst and generating any alignment-padding data.

### **3.2.6 Write Data Signals and Parameters**

The signals and parameters associated with the write data interface are listed in Table 15, “Write Data Interface Signals”, Table 16, “Write Data Interface Timing Parameters”, and Table 17, “Write Data Interface Programmable Parameters”.

For more information on the write data interface, refer to Section 4.7, “Write Transactions”. For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

---

**TABLE 15. Write Data Interface Signals**

| <b>Signal</b>                                               | <b>From</b> | <b>Width</b>   | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                                                                             |
|-------------------------------------------------------------|-------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_wrdata</b><br>or<br><b>dfi_wrdata_pN<sup>a</sup></b> | MC          | DFI Data Width | - <sup>b</sup> | <u>Write data</u> . These signals transfer write data from the MC to the PHY <b>t<sub>phy_wrdata</sub></b> cycles after the <b>dfi_wrdata_en</b> signal is asserted and continues transferring data for the number of cycles that the <b>dfi_wrdata_en</b> signal is asserted. |

**TABLE 15.** Write Data Interface Signals

| Signal                                                                | From | Width                                | Default        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------|------|--------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_wrdata_crc</b><br>or<br><b>dfi_wrdata_crc_pN<sup>a</sup></b>   | MC   | DFI Data Width / 8                   | - <sup>b</sup> | <u>Write data link CRC</u> . This bus is used for transferring the DQ Link CRC information, depending on system/DIMM settings. It uses the same timing as the <b>dfi_wrdata</b> signal. When the <b>dfi_wrdata_crc</b> signal is used, it is sent with the <b>dfi_wrdata</b> signal. <ul style="list-style-type: none"> <li>• <b>dfi_wrdata_crc [0]</b> = Link CRC for the <b>dfi_wrdata [7:0]</b> signals</li> <li>• <b>dfi_wrdata_crc [1]</b> = Link CRC for the <b>dfi_wrdata [15:8]</b> signals, etc.</li> </ul>                                                                                                                                                                                                                       |
| <b>dfi_wrdata_cs</b><br>or<br><b>dfi_wrdata_cs_pN<sup>a</sup></b>     | MC   | DFI Physical Rank Width <sup>c</sup> | - <sup>b</sup> | <u>Write data chip select</u> . The polarity of this signal is the same as the polarity of the <b>dfi_cs</b> signal. This signal indicates the chip select that is accessed or targeted for associated write data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>dfi_wrdata_ecc</b><br>or<br><b>dfi_wrdata_ecc_pN<sup>a</sup></b>   | MC   | DFI Data Width / 8                   | - <sup>b</sup> | <u>Write Data Link ECC</u> . This signal is sent with <b>dfi_wrdata</b> bus indicating link ECC functionality. This signal is used by the MC only when <b>phylinkecc_mode</b> = 1.<br>The polarity of this signal is defined by the polarity of the corresponding memory signal.<br>When the <b>dfi_wrdata_ecc</b> signal is used, it is sent with the <b>dfi_wrdata</b> signal.                                                                                                                                                                                                                                                                                                                                                           |
| <b>dfi_wrdata_en</b><br>or<br><b>dfi_wrdata_en_pN<sup>a</sup></b>     | MC   | DFI Data Enable Width <sup>d</sup>   | 0x0            | <u>Write data enable</u> . This signal indicates to the PHY that valid <b>dfi_wrdata</b> will be transmitted in <b>tphy_wrdata</b> cycles. Both <b>tphy_wrlat</b> and <b>tphy_wrdata</b> may be defined as zero.<br>Ideally, there is a one-to-one correspondence between <b>dfi_wrdata_en</b> bits and PHY data slices. The <b>dfi_wrdata_en [0]</b> signal corresponds to the lowest segment of <b>dfi_wrdata</b> signals.                                                                                                                                                                                                                                                                                                               |
| <b>dfi_wrdata_mask</b><br>or<br><b>dfi_wrdata_mask_pN<sup>a</sup></b> | MC   | DFI Data Width / 8                   | - <sup>b</sup> | <u>Write data byte mask or DBI</u> . This bus is used for transferring either the write data mask or the write DBI information, depending on system/DRAM settings. It uses the same timing as the <b>dfi_wrdata</b> signal. The polarity of this signal is defined by the polarity of the corresponding memory signal. <ul style="list-style-type: none"> <li>• <b>dfi_wrdata_mask [0]</b> = Masking or DBI for the <b>dfi_wrdata [7:0]</b> signals</li> <li>• <b>dfi_wrdata_mask [1]</b> = Masking or DBI for the <b>dfi_wrdata [15:8]</b> signals, etc.</li> </ul> If the <b>dfi_wrdata</b> bus is not a multiple of 8, the uppermost bit of the <b>dfi_wrdata_mask</b> signal corresponds to the most significant partial byte of data. |

a. For frequency ratio systems, replicates signals into phase/data word/clock cycle-specific buses that define the validity of the data for each phase N (pN)/data word N (wN)/clock cycle N (aN), as applicable. The phase 0 suffixes are not required.

b. This signal is not meaningful during initialization; no default value is required.

c. In a 3DS solution, control and MRW activity are limited to Physical Ranks.

---

## Interface Signal Groups

---

- d. Since all bits of the **dfi\_wrdata\_en** signal are identical, the width of the signal on the MC side and the PHY side may be different; the PHY is not required to use all of the bits.

The timing parameters that are associated with the write data interface are listed in Table 16, “Write Data Interface Timing Parameters”. For protocols with separate command and data clocks, special handling is required for timing parameters that cross clock domains. Refer to the LPDDR5 and DDR5-MRDIMM examples in Section 4.7.6, “CA Bus Timing”.

---

**TABLE 16. Write Data Interface Timing Parameters**

| Parameter                         | Defined By | Min | Max            | Unit                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------|------------|-----|----------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>phy_cremax_lat</sub></b> | System     | 0x1 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | This parameter specifies the maximum number of Data cycle clocks between <b>dfi_wrdata_en</b> (the Data cycle that is associated with the DRAM CRC code, or the end of the Link CRC code word, being transmitted) and the associated CRC error that is transmitted on <b>dfi_alert_n</b> . The PHY samples the CRC code on the DFI Write Data interface. The MC samples the associated CRC error on <b>dfi_alert_n</b> .<br>Use this parameter with <b>t<sub>phy_cremin_lat</sub></b> to determine a window of time that the erroneous data transmits across the DFI bus. |
| <b>t<sub>phy_cremin_lat</sub></b> | System     | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | This parameter specifies the minimum number of Data cycle clocks between <b>dfi_wrdata_en</b> (the Data cycle that is associated with the DRAM CRC code, or the end of the Link CRC code word, being transmitted) and the associated CRC error that is transmitted on <b>dfi_alert_n</b> . The PHY samples the CRC code on the DFI Write Data interface. The MC samples the associated CRC error on <b>dfi_alert_n</b> .<br>Use this parameter with <b>t<sub>phy_cremax_lat</sub></b> to determine a window of time that the erroneous data transmits across the DFI bus. |
| <b>t<sub>phy_wrcgap</sub></b>     | PHY        | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | This parameter specifies the minimum number of additional Data clock cycles that are required between commands when changing the target physical rank that is driven on the <b>dfi_wrdata_cs</b> signal.<br>This parameter must be supported in the MC transaction-to-transaction timing. The minimum assertion duration of <b>dfi_wrdata_cs</b> is determined by <b>t<sub>phy_wrcgap</sub> + dfi_rw_length<sup>c</sup></b> .                                                                                                                                             |
| <b>t<sub>phy_wreslat</sub></b>    | PHY        | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | This parameter specifies the number of Data clock cycles from the time that a write command is sent on the DFI command interface and when the associated <b>dfi_wrdata_cs</b> signal is asserted.                                                                                                                                                                                                                                                                                                                                                                         |

---

## Interface Signal Groups

---

**TABLE 16.** Write Data Interface Timing Parameters

| Parameter           | Defined By | Min              | Max            | Unit                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|------------|------------------|----------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{phy\_wrdata}$   | PHY        | 0x0 <sup>a</sup> | - <sup>a</sup> | Data clock cycles <sup>b</sup> | <p>This parameter specifies the number of Data clock cycles from the time that the <b>dfi_wrdata_en</b> signal is asserted and when the associated write data is driven on the <b>dfi_wrdata</b> signal. The parameter adjusts the relative time between enable and data transfer with no effect on performance.</p> <p>DFI 1.0 and DFI 2.0 MCs support a <math>t_{phy\_wrdata}</math> value of only 1.</p> <p>The MC should support a range of <math>t_{phy\_wrdata}</math> values. A PHY is designed to operate at a single <math>t_{phy\_wrdata}</math> value.</p> |
| $t_{phy\_wrlat}$    | PHY        | 0x0 <sup>a</sup> | - <sup>a</sup> | Data clock cycles <sup>b</sup> | <p>This parameter specifies the number of Data clock cycles from the time that a write command is sent on the DFI command interface and when the <b>dfi_wrdata_en</b> signal is asserted.</p> <p>NOTE: This parameter may be specified as a fixed value, or as a constant that is based on other fixed values in the system.</p> <p>NOTE: In DDR5 MRDIMM Mux Mode, this parameter describes PS0.</p>                                                                                                                                                                  |
| $t_{wrdata\_delay}$ | System     | 0x0              | -              | Data clock cycles              | This parameter specifies the number of Data clocks from the time that the <b>dfi_wrdata_en</b> signal is asserted and when the corresponding write data transfer completes on the host interface.                                                                                                                                                                                                                                                                                                                                                                     |

- a. The minimum supportable value is 0; the DFI does not specify a maximum value. The range of values supported is implementation-specific.
- b. This timing parameter is defined in terms of Data clock cycles for frequency ratio systems. For matched frequency systems, a Data clock is identical to the DFI clock.
- c. The **dfi\_rw\_length** value is the total number of Data clocks required to transfer one DFI read or write command worth of data. For a matched frequency system, **dfi\_rw\_length** would typically equal (burst length/2). For a frequency ratio system, **dfi\_rw\_length** is defined in terms of Data clocks and would typically equal (burst length/2). Additional Data clock cycles must be added for the DRAM CRC data transfer.

The programmable parameters associated with the write data interface are listed in Table 17, “Write Data Interface Programmable Parameters”.

**TABLE 17.** Write Data Interface Programmable Parameters

| Parameter          | Defined By | Description                                                                                                                                                                                                                                  |
|--------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phycrc_mode</b> | PHY        | <p>Sends CRC data as part of the data burst.</p> <ul style="list-style-type: none"> <li>• 'b0 = CRC code generation and validation performed in the MC.</li> <li>• 'b1 = CRC code generation and validation performed in the PHY.</li> </ul> |

**TABLE 17.** Write Data Interface Programmable Parameters

| Parameter                | Defined By | Description                                                                                                                                                                                                                                       |
|--------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phy_dbm_mode</b>      | PHY        | Determines which device generates DBI and inverts the data. <ul style="list-style-type: none"> <li>'b0 = DBI generation and data inversion performed in the MC.</li> <li>'b1 = DBI generation and data inversion performed in the PHY.</li> </ul> |
| <b>phy_linkdqrc_mode</b> | PHY        | DQ Link CRC Support. Defines whether DQ Link CRC is supported on the DFI. <ul style="list-style-type: none"> <li>'b0 = DQ Link CRC control is not supported.</li> <li>'b1 = DQ Link CRC control is handled in the MC.</li> </ul>                  |

### 3.3 Read Data Interface

The read data transaction handles the capture and return of data across the DFI; the interface includes signals, timing parameters and a programmable parameter.

The width is defined to be replicated and multiply driven to each of the PHY data slices for interconnect simplicity.

Table 18, “Read Data Interface Signals” describes the signals **dfi\_rddata** (read data bus), **dfi\_rddata\_crc** (read data link CRC), **dfi\_rddata\_cs** (read data chip select), **dfi\_rddata\_dbm** (read data DBI or link ECC), **dfi\_rddata\_dnv** (read data not valid), **dfi\_rddata\_en** (read data enable), and **dfi\_rddata\_valid** (read data valid).

In DDR5 MRDIMM Mux Mode, two pseudo-channels (PS0 and PS1) are interleaved on the same host interface. On the read data interface, the combination of both pseudo-channels together forms a single, extra-long burst, delimited by a common **dfi\_rddata\_en** signal. Each phase of the **dfi\_rddata** bus represents a single double-data-rate cycle on the host interface. To achieve pseudo-channel interleaving, the write data is interleaved per-strobe-edge; therefore, each phase contains data for both pseudo-channels. (i.e. Rising edge data is used for pseudo-channel 0, and falling edge data is used for pseudo-channel 1.)

#### 3.3.1 Read DBI

If the DBI feature is enabled and **phy\_dbm\_mode** = 0, the MC captures read DBI data transmitted from the PHY and selectively inverts the read data based on DBI as required.

#### 3.3.2 Read Data CRC

##### 3.3.2.1 Read DRAM CRC

Read DRAM CRC and Read Link CRC are mutually exclusive.

If the Read DRAM CRC feature is enabled, the MC must adjust command signal timing to handle the extended data burst from memory, regardless of the **phy\_crc\_mode** value. If **phy\_crc\_mode** = 0, the MC must extend the duration of the **dfi\_rddata\_en** signal. If **phy\_crc\_mode** = 1, the **dfi\_rddata\_en** signal duration is not extended.

If **phy\_crc\_mode** = 0, the MC captures and validates the CRC data transmitted across the DFI bus as additional data words on the existing **dfi\_rddata** signals. If **phy\_crc\_mode** = 1 the PHY validates the CRC data without transmitting it across the DFI.

### 3.3.2.2 Read Link CRC

Read DRAM CRC and Read Link CRC are mutually exclusive.

If the Read DQ Link CRC feature is enabled and `phylinkdqcrc_mode` = 1, the MC captures the CRC data transmitted from the PHY on the `dfi_rddata_crc` signal, following the same timing as the `dfi_rddata` signal. There is one bit of the `dfi_rddata_crc` signal for each byte of the `dfi_rddata` signal.

In DDR5-MRDIMM DQ Link CRC, each byte lane uses an 8-bit CRC on 64-bit Data, transferred in 8 consecutive “pseudo-channel beats.” If only one pseudo-channel is active, the DIMM will drive 1’s, which the PHY will forward on the `dfi_rddata_crc` signal, for the inactive pseudo-channel. Therefore, there is one complete CRC code word in each 8 consecutive transfers to the same pseudo-channel. Note that each pseudo-channel must be considered independently.

### 3.3.3 Read Data Chip Select

When accessing different chip-selects, it may be desirable to independently compensate for timing differences on the data interface. In this case, the PHY may require knowledge of the target chip select for each read transaction. The `dfi_rddata_cs` signal provides the target data path chip select value to each of the PHY data slices.

- In a 3DS solution, control and MRW activities are to be limited to physical ranks.
- For UDIMM or RDIMM solutions, each physical rank requires its own `dfi_rddata_cs` signal to select the host interface timing for the required update when transitioning between ranks. For example, for 2 DIMM-per-channel UDIMM/RDIMMs, 2 ranks/DIMM requires 4 `dfi_rddata_cs` signal bits.
- For DDR5 MRDIMM solutions:
  - DDR5 MRDIMM is similar to 3DS; logical rank switching does not require any host timing update.
  - Each MRDIMM / MDB device set provides a single host interface timing for the entire DIMM, regardless of the PS or rank that is being accessed. The number of active `dfi_rddata_cs` signal bits is per-DIMM regardless of the number of active `dfi_cs` signal bits within a single DIMM. Back-side switching from one PS or rank to another PS or rank is handled transparently by the MDB.
  - For a single DIMM-per-channel system, the MDBs control the timing to the DRAMs on that DIMM. The host (PHY) interface timing does not have to be updated based on the PS or rank. This requires 1 `dfi_rddata_cs` signal bit.
  - For 2 DIMM-per-channel systems, each DIMM’s MDBs control the timing to the DRAMs on that DIMM. The host (PHY) interface timing will need to be updated based on the DIMM selected. This requires 2 `dfi_rddata_cs` signal bits.
- Refer to section Section 4.23, “Use of the `dfi_rddata_cs` / `dfi_wrdata_cs` Signal with DDR5 DIMMs” for more examples.

The data path chip select signal `dfi_rddata_cs` is defined similar to the `dfi_cs` signal and has a separate timing parameter, `tphy_rdeslat`. The delay is defined relative to the command to maximize timing flexibility. Additionally, the `tphy_rdcsgap` timing parameter defines a minimum additional delay, in Data clocks, between commands when changing the target chip select as required by the PHY.

### 3.3.4 Read Data Valid

The `dfi_rddata_valid` signal allows each PHY data slice to return `dfi_rddata` independently. The `dfi_rddata_valid` signal width is equivalent to the number of PHY data slices.

When valid data is being transferred, the **dfi\_rddata\_valid** signal must be asserted. This signal is a response from the PHY to **dfi\_rddata\_en** assertion by the MC. Additionally, there is a one-to-one correspondence between **dfi\_rddata\_en** assertion clocks and **dfi\_rddata\_valid** assertion clocks.

DFI dictates a timing relationship from **dfi\_rddata\_en** to **dfi\_rddata\_valid**, specified by **t<sub>phy\_rdlat</sub>**; DFI does not dictate an exact number of cycles. The **dfi\_rddata\_valid** signal can assert earlier than the maximum delay, and does not need to be held for consecutive cycles if the **t<sub>phy\_rdlat</sub>** value is met for every transfer.

Table 19, “Read Data Interface Timing Parameters” describes the timing parameters **t<sub>phy\_rdesgap</sub>**, **t<sub>phy\_rdeslat</sub>**, **t<sub>rddata\_en</sub>** and **t<sub>phy\_rdlat</sub>**.

The **t<sub>phy\_rdlat</sub>** parameter defines the maximum number of Data clock cycles allowed from the assertion of the **dfi\_rddata\_en** signal to the assertion of the **dfi\_rddata\_valid** signal for all data slices. This parameter is specified by the system, but the exact value of this parameter is not determined by the DFI specification.

The **t<sub>rddata\_en</sub>** and **t<sub>phy\_rdlat</sub>** timing parameters must be held constant while commands are being executed on the DFI bus; however, if necessary, the timing parameters may be changed when the bus is in the idle state. These parameters work together to define a maximum number of Data clock cycles from the assertion of a read command on the DFI command interface to the assertion of the **dfi\_rddata\_valid** signal, indicating the first cycle of the read data. Read data may be returned earlier by asserting the **dfi\_rddata\_valid** signal before **t<sub>phy\_rdlat</sub>** cycles have expired. When the signal **dfi\_rddata\_valid** is asserted, the entire DFI read data word from the associated data slice must be valid.

### 3.3.5 Frequency Ratio

For frequency ratio systems, the read data enable signal is replicated into phase-specific signals with a suffix of “\_pN” that defines the signal value for each phase N of the DFI clock. The read data, read data valid and read data not valid signals are replaced with DFI data word-specific signals with a suffix of “\_wN” to specify the DFI data word N. For all signal types, the suffix for phase 0/data word 0/clock cycle 0 is optional.

### 3.3.6 MRDIMM Mux Mode

In DDR5 MRDIMM Mux Mode, two pseudo-channels (PS0 and PS1) are interleaved on the same host interface. The host command bus is interleaved per-clock-cycle, with one PS0 and one PS1 opportunity per pair of host command cycles. The host data bus is interleaved per-strobe-edge, with both PS0 and PS1 data in every host Data cycle and a shared burst preamble/postamble. Since the interleaving difference creates a different delay between command and data for PS0 vs PS1, the **t<sub>rddata\_en</sub>** parameter is nominally defined only for PS0, and PS1’s effective delay is derived relative to the paired PS0 cycle. In 1N mode, this is a 1 Data cycle difference and in 2N mode, this is a 2 Data cycle difference.

The PHY is only responsible for transferring the data bursts between the DFI and host interface, in the same manner as any other protocol. The MC is responsible for resolving the shared burst into PS0 and PS1 data.

### 3.3.7 Read Data Signals and Parameters

The signals and parameters associated with the read data interface are listed in Table 18, “Read Data Interface Signals”, Table 19, “Read Data Interface Timing Parameters”, and Table 20, “Read Data Interface Programmable Parameter”. The programmable parameter **phy\_dbm\_mode** applies to both write and read signals.

---

## Interface Signal Groups

---

For more information on the read data interface, refer to Section 4.8, “Read Transactions”. For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

**TABLE 18. Read Data Interface Signals**

| Signal                                                              | From | Width                                | Default        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------------|------|--------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_rddata</b><br>or<br><b>dfi_rddata_wN<sup>a</sup></b>         | PHY  | DFI Data Width                       | - <sup>b</sup> | <u>Read data bus</u> . This bus transfers read data from the PHY to the MC. Read data is expected to be received at the MC within $t_{phy\_rdlat}$ cycles after the <b>dfi_rddata_en</b> signal is asserted.                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>dfi_rddata_crc</b><br>or<br><b>dfi_rddata_crc_wN<sup>a</sup></b> | MC   | DFI Data Width / 8                   | - <sup>b</sup> | <u>Read data Link CRC</u> . This bus is used for transferring the DQ Link CRC information, depending on system/DIMM settings. It uses the same timing as the <b>dfi_rddata</b> signal. When the <b>dfi_rddata_crc</b> signal is used, it is sent with the <b>dfi_rddata</b> signal. <ul style="list-style-type: none"> <li>• <b>dfi_rddata_crc [0]</b> = Link CRC for the <b>dfi_rddata [7:0]</b> signals</li> <li>• <b>dfi_rddata_crc [1]</b> = Link CRC for the <b>dfi_rddata [15:8]</b> signals, etc.</li> </ul>                                                                                              |
| <b>dfi_rddata_cs</b><br>or<br><b>dfi_rddata_cs_pN<sup>a</sup></b>   | MC   | DFI Physical Rank Width <sup>c</sup> | - <sup>d</sup> | <u>Read data chip select</u> . The polarity of this signal is the same as the polarity of the <b>dfi_cs</b> signal. This signal indicates which chip select is accessed or targeted for associated read data.                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>dfi_rddata_dbi</b><br>or<br><b>dfi_rddata_dbi_wN<sup>a</sup></b> | PHY  | DFI DBI Width                        | - <sup>b</sup> | <u>Read data DBI or Link ECC</u> . This signal is sent with <b>dfi_rddata</b> bus indicating DBI functionality or link ECC information. This signal is used by the MC only when <b>phydbi_mode</b> = 0 or when <b>phylinkecc_mode</b> = 1 and the read data copy function is disabled. In LPDDR5, link ECC and the read data copy function, or the link ECC and read DBI functions are mutually exclusive. <p>The polarity of this signal is defined by the polarity of the corresponding memory signal.</p> <p>When the <b>dfi_rddata_dbi</b> signal is used, it is sent with the <b>dfi_rddata</b> signal.</p> |
| <b>dfi_rddata_dnv</b><br>or<br><b>dfi_rddata_dnv_wN<sup>a</sup></b> | PHY  | DFI Data Width / 8                   | 0x0            | <u>Read data not valid</u> . The timing is the same as for the <b>dfi_rddata_valid</b> signal. <p>The <b>dfi_rddata_dnv [0]</b> signal correlates to the <b>dfi_rddata [7:0]</b> signals, the <b>dfi_rddata_dnv [1]</b> signal correlates to the <b>dfi_rddata [15:8]</b> signals, etc. If the <b>dfi_rddata</b> bus is not a multiple of 8, the uppermost bit of the <b>dfi_rddata_dnv</b> signal corresponds to the most significant partial byte of data. This must be sent with the read data signal <b>dfi_rddata</b> when the <b>dfi_rddata_valid</b> signal is asserted.</p>                              |

---

## Interface Signal Groups

---

**TABLE 18.** *Read Data Interface Signals*

| Signal                                                                  | From | Width                              | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------|------|------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_rddata_en</b><br>or<br><b>dfi_rddata_en_pN<sup>a</sup></b>       | MC   | DFI Data Enable Width <sup>e</sup> | 0x0     | <u>Read data enable</u> . This signal indicates to the PHY that a read operation to memory is underway and identifies the number of data words to be read. The <b>dfi_rddata_en</b> signal must be asserted $t_{rddata\_en}$ cycles after the assertion of a read command on the DFI command interface and remains valid for the duration of read data expected on the <b>dfi_rddata</b> bus. Ideally, there is a single <b>dfi_rddata_en</b> bit for each PHY data slice. The <b>dfi_rddata_en[0]</b> signal corresponds to the lowest segment of <b>dfi_rddata</b> signals.          |
| <b>dfi_rddata_valid</b><br>or<br><b>dfi_rddata_valid_wN<sup>a</sup></b> | PHY  | DFI Read Data Valid Width          | 0x0     | <u>Read data valid indicator</u> . Each bit of the <b>dfi_rddata_valid</b> signal is asserted with the corresponding <b>dfi_rddata</b> for the number of cycles that data is being sent. The timing is the same as for the <b>dfi_rddata</b> bus.<br><br>The width of the <b>dfi_rddata_valid</b> signal is equivalent to the number of PHY data slices. Ideally, there is a one-to-one correspondence between a <b>dfi_rddata_valid</b> signal bit and each PHY data slice. The <b>dfi_rddata_valid[0]</b> signal corresponds to the lowest segment of the <b>dfi_rddata</b> signals. |

- a. For frequency ratio systems, replicates signals into phase/data word/clock cycle-specific buses that define the validity of the data for each phase N (pN)/data word N (wN)/clock cycle N (aN), as applicable. The phase 0 suffixes are not required.
- b. This signal is not meaningful during initialization; no default value is required.
- c. In a 3DS solution, control and MRW activity are limited to Physical Ranks.
- d. The default state for this signal is the inactive value. The polarity of this signal is dependent on the memory.
- e. Since all bits of the **dfi\_rddata\_en** signal are identical, the width of the signal on the MC side and the PHY side may be different; the PHY is not required to use all of the bits.

The timing parameters associated with the read data interface are listed in Table 19, “Read Data Interface Timing Parameters”.

**TABLE 19.** *Read Data Interface Timing Parameters*

| Parameter                      | Defined By | Min | Max            | Unit                           | Description                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------|------------|-----|----------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>phy_rdsgap</sub></b>  | PHY        | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | Specifies the minimum number of additional Data clocks required between commands when changing the target physical rank driven on the <b>dfi_rddata_cs</b> signal. This parameter needs to be supported in the MC transaction-to-transaction timing. The minimum assertion duration of <b>dfi_rddata_cs</b> is determined by $t_{phy\_rdsgap} + dfi_{rw\_length}^c$ . |
| <b>t<sub>phy_rdeslat</sub></b> | PHY        | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | Specifies the number of Data clocks between when a read command is sent on the DFI command interface and when the associated <b>dfi_rddata_cs</b> signal is asserted.                                                                                                                                                                                                 |

**TABLE 19.** Read Data Interface Timing Parameters

| Parameter        | Defined By | Min | Max            | Unit                           | Description                                                                                                                                                                                                                                                                                                                                   |
|------------------|------------|-----|----------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{phy\_rdlat}$ | PHY        | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | Specifies the maximum number of Data clock cycles allowed from the assertion of the <b>dfi_rddata_en</b> signal to the assertion of each of the corresponding bits of the <b>dfi_rddata_valid</b> signal.                                                                                                                                     |
| $t_{rddata\_en}$ | System     | 0x0 | - <sup>a</sup> | Data clock cycles <sup>b</sup> | Specifies the number of Data clock cycles from the assertion of a read command on the DFI to the assertion of the <b>dfi_rddata_en</b> signal.<br><br>NOTE: This parameter may be specified as a fixed value, or as a constant based on other fixed values in the system.<br><br>NOTE: In DDR5 MRDIMM Mux Mode, this parameter describes PS0. |

- a. The minimum supportable value is 0; the DFI does not specify a maximum value. The range of values supported is implementation-specific.
- b. For matched frequency systems, a Data clock is identical to the DFI clock. For frequency ratio systems, this timing parameter is defined in terms of Data clock cycles.
- c. The **dfi\_rw\_length** value is the total number of Data clocks required to transfer one DFI read or write command worth of data. For a matched frequency system, **dfi\_rw\_length** would typically equal (burst length/2). For a frequency ratio system, **dfi\_rw\_length** is defined in terms of Data clocks and would typically equal (burst length/2). Additional Data clock cycles must be added for the CRC data transfer.

The programmable parameter associated with the read data interface is listed in Table 20, “Read Data Interface Programmable Parameter”.

**TABLE 20.** Read Data Interface Programmable Parameter

| Parameter               | Defined By | Description                                                                                                                                                                                                                                           |
|-------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phycrc_mode</b>      | PHY        | Sends CRC data as part of the data burst. <ul style="list-style-type: none"> <li>• 'b0 = CRC code generation and validation performed in the MC.</li> <li>• 'b1 = CRC and code generation validation performed in the PHY.</li> </ul>                 |
| <b>phydbi_mode</b>      | PHY        | Determines which device generates DBI and inverts the data. <ul style="list-style-type: none"> <li>• 'b0 = DBI generation and data inversion performed in the MC.</li> <li>• 'b1 = DBI generation and data inversion performed in the PHY.</li> </ul> |
| <b>phylinkdqrc_mode</b> | PHY        | DQ Link CRC Support. Defines whether DQ Link CRC is supported on the DFI. <ul style="list-style-type: none"> <li>• 'b0 = DQ Link CRC control is not supported.</li> <li>• 'b1 = DQ Link CRC control is handled in the MC.</li> </ul>                  |

### 3.4 Update Interface

The update interface facilitates various commands that might require interruption of DRAM signal transmission on the DFI. These commands include timing adjustments, calibration, etc. This interface defines signals and timing parameters.

To ensure that updates do not interfere with signals on the DRAM interface, the DFI supports update modes when the DFI bus is placed in an idle state. The update interface does not define a required state of memory.

When the DFI bus is in an idle state, the command interface is not sending any commands and all read and write data has transferred on the DFI bus. The data has reached its destination (DRAM or MC) and the write data transfer has completed on the DRAM bus; The state of the DRAM bus is unchanged. The DFI specification supports both MC-initiated and PHY-initiated updates. For more information on the update interface, refer to *Section 4.9, “Update”*.

The **t\_ctrlupd\_interval** parameter defines the maximum interval at which the MC can assert **dfi\_ctrlupd\_req** signals. A MC-initiated update request via **dfi\_ctrlupd\_req** is required immediately before a self-refresh exit command runs.

If a PHY initiates an update request by asserting the **dfi\_phyupd\_req** signal, the MC must acknowledge the request by asserting the **dfi\_phyupd\_ack** signal unless the PHY de-asserts the **dfi\_phyupd\_req** signal. The PHY is permitted to de-assert this request when **dfi\_ctrlupd\_req** is asserted or the **dfi\_init\_start** signal is asserted. The DFI specifies up to 4 different update PHY-initiated request modes. Each mode differs only in the number of cycles that the DFI interface must be suspended while the update occurs. During this time, the MC is responsible for placing the system in a state where the DFI bus is suspended from all activity other than activity specifically related to the update process being executed. For more details, refer to *Section 4.9.2, “PHY-Initiated Update”*.

The DFI specification does not require the PHY to issue update requests nor does the specification specify an interval in which requests must be offered. If the PHY offers update requests, it must follow the specified protocol.

It is possible that both update request signals (**dfi\_ctrlupd\_req** and **dfi\_phyupd\_req**) could be asserted at the same time. When both request signals are driven, the MC and the PHY could violate the protocol by simultaneously acknowledging the other’s request. To prevent this situation, the MC is not permitted to assert both **dfi\_ctrlupd\_req** and **dfi\_phyupd\_ack** at the same time. If **dfi\_ctrlupd\_req** is asserted at the same time as **dfi\_phyupd\_req**, the PHY is permitted to de-assert **dfi\_phyupd\_req**, though it is not required to be de-asserted. Since it is the PHY (not the MC) that uses the Update interface to request the DFI bus to be IDLE, the PHY should not de-assert **dfi\_phyupd\_req** unless the signal is no longer required due to the assertion of **dfi\_ctrlupd\_req**. The acknowledged request must follow the appropriate protocol.

The signals and parameters associated with the update interface are listed in Table 21, “Update Interface Signals”, and Table 22, “Update Interface Timing Parameters”. For more information on the update interface, refer to *Section 4.9, “Update”*. For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

**TABLE 21.** Update Interface Signals

| Signal                 | From | Width | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------|------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_ctrlupd_ack</b> | PHY  | 1 bit | 0x0     | <p><u>MC-initiated update acknowledge.</u> The <b>dfi_ctrlupd_ack</b> signal is asserted to acknowledge an MC-initiated update request. The PHY is not required to acknowledge this request.</p> <p>While this signal is asserted, the DFI bus must remain in the idle state except for transactions specifically associated with the update process.</p> <p>If the PHY acknowledges the request, the <b>dfi_ctrlupd_ack</b> signal must be asserted before <math>t_{ctrlupd\_min}</math> occurs and the <b>dfi_ctrlupd_req</b> signal de-asserts. If the PHY ignores the request, the <b>dfi_ctrlupd_ack</b> signal must remain de-asserted until the <b>dfi_ctrlupd_req</b> signal is de-asserted.</p> <p>The <b>dfi_ctrlupd_req</b> signal is guaranteed to be asserted for at least <math>t_{ctrlupd\_min}</math> cycles. The <b>dfi_ctrlupd_ack</b> signal cannot be asserted after <math>t_{ctrlupd\_min}</math> occurs, even if <b>dfi_ctrlupd_req</b> is still asserted.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>dfi_ctrlupd_req</b> | MC   | 1 bit | 0x0     | <p><u>MC-initiated update request.</u> The <b>dfi_ctrlupd_req</b> signal is used with an MC-initiated update to indicate that the DFI will be in the idle state for some time, in which case the PHY may perform an update.</p> <p>The <b>dfi_ctrlupd_req</b> signal must be asserted for a minimum of <math>t_{ctrlupd\_min}</math> cycles and a maximum of <math>t_{ctrlupd\_max}</math> cycles.</p> <p>A <b>dfi_ctrlupd_req</b> signal assertion is an invitation for the PHY to update and does not require a response.</p> <p>The behavior of the <b>dfi_ctrlupd_req</b> signal is dependent on the <b>dfi_ctrlupd_ack</b> signal:</p> <ul style="list-style-type: none"> <li>• If the update is acknowledged by the PHY, the <b>dfi_ctrlupd_req</b> signal remains asserted as long as the <b>dfi_ctrlupd_ack</b> signal is asserted, but <b>dfi_ctrlupd_ack</b> must de-assert before <math>t_{ctrlupd\_max}</math> expires. While <b>dfi_ctrlupd_req</b> is asserted, the DFI bus remains in the idle state except for transactions specifically associated with the update process.</li> <li>• If the update is not acknowledged, the <b>dfi_ctrlupd_req</b> signal may de-assert at any time after <math>t_{ctrlupd\_min}</math> occurs and before <math>t_{ctrlupd\_max}</math> expires.</li> <li>• The MC may de-assert the <b>dfi_ctrlupd_req</b> signal to disconnect the handshake through the disconnect protocol.</li> </ul> |

**TABLE 21.** Update Interface Signals

| Signal                | From | Width | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------|------|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_phyupd_ack</b> | MC   | 1 bit | 0x0     | <p><u>PHY-initiated update acknowledge.</u> The <b>dfi_phyupd_ack</b> signal is used for a PHY-initiated update to indicate that the DFI is idle and remains in the idle state until the <b>dfi_phyupd_req</b> signal de-asserts.</p> <p>In most cases, the MC must assert the <b>dfi_phyupd_ack</b> signal within <math>t_{phyupd\_resp}</math> cycles of the <b>dfi_phyupd_req</b> signal; exceptions are granted when the <b>dfi_phymngd_req</b> signal is also asserted (refer to Section 4.21, “DFI Interactions” for details). When the <b>dfi_phyupd_ack</b> signal is asserted, it should remain asserted as long as the <b>dfi_phyupd_req</b> signal remains asserted. The <b>dfi_phyupd_ack</b> signal must de-assert upon the detection of <b>dfi_phyupd_req</b> signal de-assertion. The <b>dfi_phyupd_req</b> cannot be re-asserted prior to the de-assertion of <b>dfi_phyupd_ack</b> for the previous transaction.</p> <p>The MC may de-assert the <b>dfi_phyupd_ack</b> signal to disconnect the handshake through the disconnect protocol.</p> <p>The <math>t_{phyupd\_resp}</math> duration should be sufficiently large to allow for all cases, including a Controller Update occurring before the PHY Update is acknowledged. While <b>dfi_phyupd_ack</b> is asserted, the DFI bus must remain in the idle state except for transactions specifically associated with the update process.</p> <p>The time period from when the <b>dfi_phyupd_ack</b> signal is asserted to when the <b>dfi_phyupd_req</b> signal is de-asserted is a maximum of <math>t_{phyupd\_typeX}</math> cycles, based on the <b>dfi_phyupd_type</b> signal.</p> |
| <b>dfi_phyupd_req</b> | PHY  | 1 bit | 0x0     | <p><u>PHY-initiated update request.</u> The <b>dfi_phyupd_req</b> signal is used for a PHY-initiated update to indicate that the PHY requires the DFI bus to be placed in an idle state and not send control, read or write commands or data for a specified period of time. The maximum time required is specified by the <math>t_{phyupd\_typeX}</math> parameter associated with the <b>dfi_phyupd_type</b> signal.</p> <p>Once asserted, the <b>dfi_phyupd_req</b> signal must generally remain asserted until the request is acknowledged by the assertion of the <b>dfi_phyupd_ack</b> signal and the PHY’s internal update procedure has been completed. Exceptions are granted if the <b>dfi_ctrlupd_req</b>, <b>dfi_phymngd_req</b> or <b>dfi_init_start</b> signals are also asserted - refer to Section 4.21, “DFI Interactions” for details.</p> <p>While this signal is asserted, the DFI bus must remain in the idle state other than any transactions specifically associated with the update process.</p> <p>The de-assertion of the <b>dfi_phyupd_req</b> signal triggers the de-assertion of the <b>dfi_phyupd_ack</b> signal.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

---

## Interface Signal Groups

---

**TABLE 21.** *Update Interface Signals*

| Signal                 | From | Width  | Default        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------|------|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_phyupd_type</b> | PHY  | 2 bits | - <sup>a</sup> | <u>PHY-initiated update select.</u> The <b>dfi_phyupd_type</b> signal indicates which one of the 4 types of PHY update times is being requested by the <b>dfi_phyupd_req</b> signal. The value of the <b>dfi_phyupd_type</b> signal determines which of the timing parameters ( $t_{phyupd\_type0}$ , $t_{phyupd\_type1}$ , $t_{phyupd\_type2}$ , $t_{phyupd\_type3}$ ) is relevant. The <b>dfi_phyupd_type</b> signal must remain constant during the entire time the <b>dfi_phyupd_req</b> signal is asserted. |

a. This signal is not meaningful during initialization; no default value is required.

The timing parameters associated with the update interface are listed in Table 22, “Update Interface Timing Parameters”.

**TABLE 22.** *Update Interface Timing Parameters*

| Parameter                | Defined By | Min            | Max            | Unit                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------|------------|----------------|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>tctrlupd_interval</b> | MC         | - <sup>a</sup> | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the MC may wait between assertions of the <b>dfi_ctrlupd_req</b> signal.                                                                                                                                                                                                                                                                                                                                                                          |
| <b>tctrlupd_max</b>      | MC         | - <sup>a</sup> | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>dfi_ctrlupd_req</b> signal can assert.                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>tctrlupd_min</b>      | MC         | 0x1            | - <sup>a</sup> | Control clock cycles | Specifies the minimum number of Control clock cycles that the <b>dfi_ctrlupd_req</b> signal must be asserted.                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>tphyupd_resp</b>      | PHY        | 0x1            | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles after the assertion of the <b>dfi_phyupd_req</b> signal to the assertion of the <b>dfi_phyupd_ack</b> signal.<br><br>Exceptions are granted if <b>dfi_init_start</b> , <b>dfi_ctrlupd_req</b> , or <b>dfi_phymngd_req</b> are active along with <b>dfi_phyupd_req</b> . Refer to Section 4.9.2, “PHY-Initiated Update” for details.<br><br>This timing parameter should be greater than <b>tinit_resp</b> and much greater than <b>tctrlupd_resp</b> . |
| <b>tphyupd_type0</b>     | PHY        | 0x1            | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>dfi_phyupd_req</b> signal may remain asserted after the assertion of the <b>dfi_phyupd_ack</b> signal for <b>dfi_phyupd_type</b> = 0x0. The <b>dfi_phyupd_req</b> signal may de-assert at any cycle after the assertion of the <b>dfi_phyupd_ack</b> signal.                                                                                                                                                                               |

**TABLE 22.** Update Interface Timing Parameters

| Parameter           | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                                                                                                                                                                                   |
|---------------------|------------|-----|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{phyupd\_type1}$ | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>dfi_phyupd_req</b> signal may remain asserted after the assertion of the <b>dfi_phyupd_ack</b> signal for <b>dfi_phyupd_type</b> = 0x1. The <b>dfi_phyupd_req</b> signal may de-assert at any cycle after the assertion of the <b>dfi_phyupd_ack</b> signal. |
| $t_{phyupd\_type2}$ | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>dfi_phyupd_req</b> signal may remain asserted after the assertion of the <b>dfi_phyupd_ack</b> signal for <b>dfi_phyupd_type</b> = 0x2. The <b>dfi_phyupd_req</b> signal may de-assert at any cycle after the assertion of the <b>dfi_phyupd_ack</b> signal. |
| $t_{phyupd\_type3}$ | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>dfi_phyupd_req</b> signal may remain asserted after the assertion of the <b>dfi_phyupd_ack</b> signal for <b>dfi_phyupd_type</b> = 0x3. The <b>dfi_phyupd_req</b> signal may de-assert at any cycle after the assertion of the <b>dfi_phyupd_ack</b> signal. |

a. The minimum supportable value is 1; the DFI does not specify a maximum value. The range of values supported is implementation-specific.

## 3.5 Status Interface

The status interface signal conveys status information between the MC and the PHY for initialization and clock control to the DRAM devices.

### 3.5.1 Initialization

Initialization uses the **dfi\_init\_start** and **dfi\_init\_complete** signals. These signals are also used during a frequency change request, which Section 3.5.4, “Frequency Change” describes in detail. At initialization, the **dfi\_init\_start** signal indicates to the PHY that the optional DFI frequency signals (**dfi\_cmd\_freq\_ratio**, **dfi\_data\_freq\_ratio**, **dfi\_frequency**, and **dfi\_freq\_fsp**) from the MC is defined and valid and the **dfi\_init\_complete** signal indicates that the PHY is ready to accept DFI transactions. The MC de-asserts the **dfi\_init\_start** signal before sending DFI transactions.

For more information on initialization, refer to Section 4.1, “Initialization”.

### 3.5.2 Reduced Data Buses

Not all bits of the DFI data buses (**dfi\_wrdata** and **dfi\_rddata**) are required to be used for data transfers. However, the MC and the PHY must both support the same partial use of data signals to remain compatible. This information is conveyed through the **dfi\_data\_bit\_enable** programmable parameter. For example, if the MC disables the upper bits (most significant bits) of the data bus, the PHY must be able to operate accurately with the remaining byte lanes. The DFI specification does not define supported active/inactive patterns, and therefore care must be taken to insure the interoperability of the MC and the PHY.

### 3.5.3 Frequency Ratio

The **dfi\_cmd\_freq\_ratio** signal and the **dfi\_data\_freq\_ratio** signal convey frequency ratio information to the PHY. These signals indicate the ratio between the MC and the PHY for the control to command and control to data signals, respectively, operating at a ratio across the DFI. These optional signals are required if the MC and/or PHY support frequency ratios. For more information on the frequency ratio protocol, refer to Section 4.10, “Frequency Ratios Across the DFI”.

### 3.5.4 Frequency Change

The DFI specification defines a frequency change protocol between the MC and the PHY to allow the devices to change the clock frequency and frequency ratio of the MC and the PHY during operation.

The signals used in the frequency change protocol are **dfi\_init\_start** and **dfi\_init\_complete** during normal operation. The behavior of the **dfi\_init\_start** signal depends on the **dfi\_init\_complete** signal. A frequency change request is triggered when the MC asserts **dfi\_init\_start**. The PHY indicates the acceptance of the frequency change by de-asserting **dfi\_init\_complete**. The associated timing parameters are **t<sub>init\_start</sub>** and **t<sub>init\_complete</sub>**.

During a frequency change, the frequency ratio between the MC and the PHY for command signals can be changed using the **dfi\_cmd\_freq\_ratio** and **dfi\_data\_freq\_ratio** signals and for data signals using the **dfi\_data\_freq\_ratio** signal. For memories that have multiple FSPs, the **dfi\_freq\_fsp** signal should be driven indicating the FSP associated with the new target frequency. The **dfi\_frequency** signal reports the operating frequency for the system. The timing of the **dfi\_freq\_fsp** signal is similar to the **dfi\_frequency** signal while the **dfi\_init\_start** signal is asserted during a frequency change operation.

For more information on the frequency change protocol, refer to Section 4.11, “Frequency Change”.

### 3.5.5 Frequency Indicator

The MC initiates a frequency change operation and reports the new frequency through the encoding of the **dfi\_frequency** signal, the new frequency set point through the **dfi\_freq\_fsp** signal, the new command frequency ratio through the encoding of the **dfi\_cmd\_freq\_ratio** signal, and the new data frequency ratio through the encoding of the **dfi\_data\_freq\_ratio** signal to the PHY. The encoding of the **dfi\_frequency** signal is defined by the PHY, the system, or both; the DFI specification does not impose any fixed frequency mapping. However, it is recommended that frequencies are mapped so that frequencies increase with increasing values of the **dfi\_frequency** signal which will allow for setting up thresholds. 64 unique frequencies can be defined through this signal.

There is no initial value defined for the **dfi\_frequency**, **dfi\_freq\_fsp**, **dfi\_cmd\_freq\_ratio** or **dfi\_data\_freq\_ratio** signals; the system must determine the initial frequency, FSP and data frequency ratio and the MC drives those initial values when it asserts the **dfi\_init\_start** signal during initialization. Similar to existing signals, the PHY must wait for the **dfi\_init\_start** signal to assert.

While the MC can support up to 64 unique values of the **dfi\_frequency** signal, the **phyfreq\_range** parameter defines the number of frequencies that the PHY supports. The frequency range must be a number between 1 and 64, inclusive, and must start from the value of ZERO to one less than the defined range. The PHY may only support a subset of these frequencies; if so, the PHY should clearly define supported encodings. The MC must be able to support the full range of values as defined by DFI and must never drive a value outside the selected range nor any value within the range that is defined as unsupported by the PHY.

The **dfi\_frequency** signal can change any time when **dfi\_init\_start** is low and should be ignored at this time. Once the **dfi\_init\_start** signal is asserted, the **dfi\_frequency** signal must be set to a legal value and remain unchanged.

### 3.5.6 Status Interface Signals and Parameters

The signals and parameters in the status interface are listed in Table 23, “Status Interface Signals”, Table 24, “Status Interface Timing Parameters”, and Table 25, “Status Interface Programmable Parameters”.

For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

**TABLE 23. Status Interface Signals**

| Signal                     | From | Width  | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------|------|--------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_cmd_freq_ratio</b>  | MC   | 2 bits | ?       | <p><u>DFI command frequency ratio indicator</u>. This signal defines the command frequency ratio for the system.</p> <p>This signal is required for MCs and PHYs that support command frequency ratios. This signal is optional for MCs and PHYs that support only matched command frequency.</p> <p>This signal is only valid when the <b>dfi_init_start</b> signal is asserted during initialization and frequency changes.</p> <ul style="list-style-type: none"> <li>• 'b00 = 1:1 MC:PHY frequency ratio (matched frequency)</li> <li>• 'b01 = 1:2 MC:PHY frequency ratio</li> <li>• 'b10 = 1:4 MC:PHY frequency ratio</li> <li>• 'b11 = 1:8 MC:PHY frequency ratio</li> </ul> |
| <b>dfi_data_freq_ratio</b> | MC   | 2 bits | ?       | <p><u>DFI data frequency ratio indicator</u>. This signal defines the data frequency ratio for the system.</p> <p>This signal is required for MCs and PHYs that support data frequency ratios. This signal is optional for MCs and PHYs that support only matched data frequency.</p> <p>This signal is only valid when the <b>dfi_init_start</b> signal is asserted during initialization and frequency changes.</p> <ul style="list-style-type: none"> <li>• 'b00 = 1:1 MC:PHY frequency ratio (matched frequency)</li> <li>• 'b01 = 1:2 MC:PHY frequency ratio</li> <li>• 'b10 = 1:4 MC:PHY frequency ratio</li> <li>• 'b11 = 1:8 MC:PHY frequency ratio</li> </ul>             |

**TABLE 23.** Status Interface Signals

| Signal                   | From | Width         | Default          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------|------|---------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_freq_fsp</b>      | MC   | DFI FSP Width | ?                | <p><u>DFI frequency set point</u>. Indicates the operating frequency set point for the system. This signal should change only at initialization or during a DFI frequency change operation. This signal is required for MCs and PHYs that support multiple frequency set points. This signal is required only for the DRAMs that support FSP. This signal is optional for MCs and PHYs that support only a single frequency.</p> <p>This signal is valid when <b>dfi_init_start</b> is asserted during initialization and during frequency change operations.</p> <ul style="list-style-type: none"> <li>• For a DFI FSP Width of 1 bit:                     <ul style="list-style-type: none"> <li>• 'b0 = FSP0</li> <li>• 'b1 = FSP1</li> </ul> </li> <li>• For a DFI FSP Width of 2 bits:                     <ul style="list-style-type: none"> <li>• 'b00 = FSP0</li> <li>• 'b01 = FSP1</li> <li>• 'b10 = FSP2</li> <li>• 'b11 = Reserved</li> </ul> </li> </ul> |
| <b>dfi_frequency</b>     | MC   | Up to 6 bits  | ?                | <p><u>DFI frequency</u>. This signal indicates the operating frequency for the system. This signal should change only at initialization, during a DFI frequency change operation, or other times that the system defines. The number of supported frequencies and the mapping of signal values to clock frequencies are defined by the PHY, system, or both.</p> <p>This signal should be constant during normal operation.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>dfi_init_complete</b> | PHY  | 1 bit         | 0x0 <sup>a</sup> | <p><u>PHY initialization complete</u>. The <b>dfi_init_complete</b> signal indicates that the PHY is able to respond to any proper stimulus on the DFI. All DFI signals that communicate commands or status must be held at their default values until the <b>dfi_init_complete</b> signal asserts. During a PHY re-initialization request (such as a frequency change), this signal is de-asserted.</p> <p>For a frequency change request, the de-assertion of the <b>dfi_init_complete</b> signal acknowledges the frequency change protocol. Once de-asserted, the signal should only be re-asserted within <math>t_{init\_complete}</math> cycles after the <b>dfi_init_start</b> signal has de-asserted, and once the PHY has completed re-initialization.</p> <p>When the DFI interface is reset the <b>dfi_init_complete</b> signal resets to its default value.</p>                                                                                           |

## Interface Signal Groups

---

**TABLE 23.** *Status Interface Signals*

| Signal                | From | Width | Default                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------|------|-------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_init_start</b> | MC   | 1 bit | 0x0 <sup>a</sup><br>0x1 | <p><u>DFI setup stabilization or frequency change initiation.</u> This signal can perform two functions.</p> <p>When <b>dfi_init_start</b> is asserted during initialization, the MC is indicating that the <b>dfi_frequency</b>, <b>dfi_freq_fsp</b>, <b>dfi_cmd_freq_ratio</b> and <b>dfi_data_freq_ratio</b> signals are driven with valid values.</p> <p>When <b>dfi_init_start</b> is asserted during normal operation, the MC is requesting a frequency change.</p> <p>During initialization, once both <b>dfi_init_start</b> and <b>dfi_init_complete</b> are asserted for at least one DFI clock cycle, the MC de-asserts the <b>dfi_init_start</b> signal before sending DFI transactions.</p> <p>For frequency change, the <b>dfi_init_start</b> signal must assert to trigger the event. After the rising edge of <b>dfi_init_start</b> occurs, the behavior of the <b>dfi_init_start</b> signal depends on the <b>dfi_init_complete</b> signal as follows:</p> <ul style="list-style-type: none"> <li>If the PHY accepts the frequency change request, it must de-assert the <b>dfi_init_complete</b> signal within <math>t_{init\_start}</math> cycles of the <b>dfi_init_start</b> assertion. The MC continues to hold the <b>dfi_init_start</b> signal asserted until the clock frequency change has been completed. The de-assertion should be used by the PHY to re-initialize on the new clock frequency.</li> </ul> <p>If the frequency change is not acknowledged (the <b>dfi_init_complete</b> signal remains asserted), the <b>dfi_init_start</b> signal must de-assert after <math>t_{init\_start}</math> cycles.</p> <p>When the DFI interface is reset, the <b>dfi_init_start</b> signal resets to its default value.</p> |

a. The PHY should wait for the **dfi\_init\_start** signal assertion before asserting the **dfi\_init\_complete** signal.

The timing parameters associated with the status interface are listed in Table 24, “Status Interface Timing Parameters”.

**TABLE 24.** *Status Interface Timing Parameters*

| Parameter                              | Defined By | Min | Max            | Unit                              | Description                                                                                                                                                                                                      |
|----------------------------------------|------------|-----|----------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b><math>t_{init\_complete}</math></b> | PHY        | 0x0 | - <sup>b</sup> | Control clock cycles <sup>c</sup> | During a frequency change operation, specifies the maximum number of Control clock cycles after the de-assertion of the <b>dfi_init_start</b> signal to the re-assertion of the <b>dfi_init_complete</b> signal. |

---

## Interface Signal Groups

---

**TABLE 24.** *Status Interface Timing Parameters*

| Parameter                         | Defined By | Min | Max            | Unit                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------|------------|-----|----------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>init_start</sub></b>     | MC         | 0x0 | - <sup>b</sup> | Control clock cycles <sup>c</sup> | <p>During a frequency change operation, this parameter specifies the number of Control clock cycles from the assertion of the <b>dfi_init_start</b> signal on the DFI until the PHY must respond by de-asserting the <b>dfi_init_complete</b> signal. If the <b>dfi_init_complete</b> signal is not de-asserted within this time period, the PHY indicates that it can not support the frequency change at this time. In this case, the MC must abort the request and release the <b>dfi_init_start</b> signal. After <b>t<sub>init_start</sub></b> expires, the PHY must not de-assert the <b>dfi_init_complete</b> signal. The MC can re-assert <b>dfi_init_start</b> at a later point.</p> <p>The PHY may complete memory setup before de-asserting the <b>dfi_init_complete</b> signal. In this case, <b>t<sub>init_start</sub></b> should be programmed to larger values.</p> |
| <b>t<sub>init_start_min</sub></b> | MC         | 0x1 | - <sup>a</sup> | Control clock cycles              | Minimum number of Control clocks before <b>dfi_init_start</b> can be driven after a previous command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

The programmable parameters associated with the status interface are listed in Table 25, “Status Interface Programmable Parameters”.

**TABLE 25.** *Status Interface Programmable Parameters*

| Parameter                 | Defined By | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_boot_state</b>     | PHY        | <p>Defines the state of memory when the DFI bus ownership is passed to the controller after PHY initialization/training.</p> <ul style="list-style-type: none"> <li>• 'b0 = Memory is in Idle</li> <li>• 'b1 = Memory is in Self-Refresh</li> </ul>                                                                                                                                                                                                                                                                            |
| <b>dfi_cmd_freq_ratio</b> | SYS        | <p>Defines the ratio of the DFI Clock and the host command clock. This is referred to as the command frequency ratio. This is the state when the DFI bus ownership is passed back to the controller.</p> <ul style="list-style-type: none"> <li>• 'b000 = 1:1</li> <li>• 'b001 = 1:2</li> <li>• 'b010 = 1:4</li> <li>• 'b011 = 1:8</li> <li>• All other settings reserved</li> </ul> <p>This value will not necessarily be correct post-initialization; the <b>dfi_cmd_freq_ratio</b> signal is used for frequency change.</p> |

**TABLE 25.** Status Interface Programmable Parameters

| Parameter                    | Defined By | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_data_bit_enable</b>   | MC/PHY     | <p>Defines the bits that are used for transferring valid data on both the <b>dfi_wrdata</b> and <b>dfi_rd़data</b> buses. This parameter is defined by both the MC and the PHY. The parameter can have different values for different operating modes for each device. The parameter width is defined as the DFI data width.</p> <p>Previous DFI specifications included a <b>dfi_data_byte_disable</b> signal. That signal has been removed for lack of usefulness and been replaced by this programmable parameter. In a system where the MC supports an earlier version of the DFI specification and the PHY is a DFI 4.0 PHY, the MC's <b>dfi_data_byte_disable</b> signal would not be connected and the PHY programmable parameter would be programmed to match the definition of that signal. In a system where a DFI 4.0 MC connects to an older DFI version PHY will require a programmable register that emulates the behavior of the <b>dfi_data_byte_disable</b> signal, and the <b>dfi_data_byte_disable</b> signal input on the PHY would be driven by external logic or be hardwired.</p> |
| <b>dfi_data_freq_ratio</b>   | SYS        | <p>Defines the ratio of the DFI Clock and the host data clock. This is referred to as the data frequency ratio. This is the state when the DFI bus ownership is passed back to the controller.</p> <ul style="list-style-type: none"> <li>• 'b000 = 1:1</li> <li>• 'b001 = 1:2</li> <li>• 'b010 = 1:4</li> <li>• 'b011 = 1:8</li> <li>• All other settings reserved</li> </ul> <p>This value will not necessarily be correct post-initialization; the <b>dfi_data_freq_ratio</b> signal is used for frequency change.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>dfi_freq_change_state</b> | PHY        | <p>Defines the state of memory when the MC initiates a frequency change operation by asserting the <b>dfi_init_start</b> signal or when PHY asserts the <b>dfi_init_complete</b> signal after completing re-initialization and re-training during a frequency change operation. This is the state when the DFI bus ownership is passed back to the controller.</p> <ul style="list-style-type: none"> <li>• 'b0 = Memory is in Idle</li> <li>• 'b1 = Memory is in Self refresh</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>dfi_fspx_freq</b>         | SYS        | FSPx Frequency, where x is defined by the number of FSPs supported in the DRAM. Defines the frequency for each FSP. This is an encoded value as defined by the <b>dfi_frequency</b> signal and the <b>phyfreq_range</b> programmable parameter. These values will not necessarily be correct post-initialization; the <b>dfi_freq_fsp</b> signal is used for frequency change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>dfi_init_freq</b>         | SYS        | Defines the Control clock frequency during initialization with the <b>dfi_init_start</b> signal. This is an encoded value as defined by the <b>dfi_frequency</b> signal and the <b>phyfreq_range</b> programmable parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>phyfreq_range</b>         | PHY        | Defines the range of frequency values supported by the PHY. The frequency range must be a number between 1 and 64 inclusive and must start from the value of ZERO to one less than the defined range. The PHY may only support a subset of these frequencies and the PHY must clearly define supported encodings.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

The status interface provides multiple programmable parameters to convey information between the MC and PHY. The **dfi\_data\_bit\_enable** programmable parameter defines the valid data bits for both the MC and PHY on both the **dfi\_wrdata** and **dfi\_rd़data** interfaces. The parameter must be the same for both read and write data.

Memory devices can have multiple operating modes where the value of this parameter might be different in different modes. In this case, the device must define the parameter for each operating mode. For example, a device might operate with ECC on and ECC off. If so, the value of the parameter differs for both modes. If the parameter is defined the same for both the MC and PHY, then they will be compatible.

However, in some cases, the devices may define the parameter differently such that the devices can still operate together but the differences would be resolved at the bus interconnection of the devices. For example, in an ECC system, the two devices might place the ECC data in different locations within the data bus, which can be resolved by interconnecting the devices to the bus for aligning these signals as necessary.

### 3.6 Low Power Control Interface

The low power control interface handles transmission of signals to enter and exit an idle state; the interface includes signals and timing parameters. Low power control is an optional feature for both the MC and the PHY unless the system requires a low power interface. It may be advantageous to place the PHY in a low power state when the MC has knowledge that the memory subsystem will remain in the idle state for a period of time. Depending on the state of the system, the MC communicates state information to the PHY allowing the PHY to enter the appropriate power saving state.

The low power control interface consists of timing parameters and signals that inform the PHY of a low power mode opportunity, as well as how quickly the MC will require the PHY to resume normal operation. Table 26, “Low Power Control Interface Signals” describes the signals used in the low power control interface: **dfi\_lp\_ctrl\_req** (control low power opportunity request), **dfi\_lp\_data\_req** (data low power opportunity request), **dfi\_lp\_ctrl\_ack** (control low power acknowledge), **dfi\_lp\_data\_ack** (data low power acknowledge), **dfi\_lp\_ctrl\_wakeup** (control low power wakeup time) and **dfi\_lp\_data\_wakeup** (data low power wakeup time).

The low power requests (control and data) are independent interfaces which can be acknowledged without any dependency between them. Once asserted, a low power (control/data) request cannot be de-asserted unless the corresponding acknowledge is not asserted within **t<sub>lp\_resp</sub>**. Table 27, “Low Power Control Interface Timing Parameters” describes the timing parameters: **t<sub>lp\_resp</sub>** and **t<sub>lp\_ctrl\_wakeup</sub>** and **t<sub>lp\_data\_wakeup</sub>**.

The signals and parameters associated with the low power interface are listed in Table 26, “Low Power Control Interface Signals”, Table 27, “Low Power Control Interface Timing Parameters”, and Table 28, “Low Power Control Interface Programmable Parameters”. More information on the low power control interface is provided in Section 4.13, “Low

---

## Interface Signal Groups

---

Power Control Handshaking". For more information on which signals are required and which signals are optional, refer to Table 4, "DFI Signal Requirements".

---

**TABLE 26.** *Low Power Control Interface Signals*

| Signal                 | From | Width | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------|------|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_ctrl_ack</b> | PHY  | 1 bit | 0x0     | <p><u>Control low power acknowledge</u>. The <b>dfi_lp_ctrl_ack</b> signal is asserted to acknowledge the MC control low power opportunity request. The PHY is not required to acknowledge this request.</p> <p>If the PHY acknowledges the request, the <b>dfi_lp_ctrl_ack</b> signal must be asserted within <math>t_{lp\_resp}</math> cycles after the <b>dfi_lp_ctrl_req</b> signal assertion. Once asserted, this signal remains asserted until the <b>dfi_lp_ctrl_req</b> signal de-asserts. The signal de-asserts within <math>t_{lp\_ctrl\_wakeup}</math> cycles after the <b>dfi_lp_ctrl_req</b> signal de-asserts, indicating that the PHY is able to resume normal operation.</p> <p>If the PHY ignores the request, the <b>dfi_lp_ctrl_ack</b> signal must remain de-asserted for the remainder of the low power mode opportunity. The <b>dfi_lp_ctrl_req</b> signal is asserted for at least <math>t_{lp\_resp}</math> cycles.</p> |
| <b>dfi_lp_ctrl_req</b> | MC   | 1 bit | 0x0     | <p><u>Control low power opportunity request</u>. The <b>dfi_lp_ctrl_req</b> signal is used by the MC to inform the PHY of an opportunity to switch to a low power mode. When asserted, the MC indicates that no more commands will be sent on the command interface.</p> <p>The MC must assert a constant value on the <b>dfi_lp_ctrl_wakeup</b> signal while this signal is asserted before the request is acknowledged by the PHY through the assertion of the <b>dfi_lp_ctrl_ack</b> signal or until <math>t_{lp\_resp}</math> cycles have elapsed.</p> <p>The MC may increase the value of the <b>dfi_lp_ctrl_wakeup</b> signal while the <b>dfi_lp_ctrl_req</b> signal is asserted.</p> <p>Following the de-assertion of the <b>dfi_lp_ctrl_req</b> signal, the PHY has <math>t_{lp\_ctrl\_wakeup}</math> cycles to resume normal operation and de-assert the <b>dfi_lp_ctrl_ack</b> signal.</p>                                           |

**TABLE 26.** Low Power Control Interface Signals

| Signal                    | From | Width                                           | Default        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------|------|-------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_ctrl_wakeup</b> | MC   | up to 6 bits depending on <b>dfi_lp_version</b> | - <sup>a</sup> | <p>Control low power wakeup time. The <b>dfi_lp_ctrl_wakeup</b> signal indicates which one of the 16 wakeup times the MC is requesting for the PHY.</p> <p>The signal is only valid when the <b>dfi_lp_ctrl_req</b> signal is asserted. The <b>dfi_lp_ctrl_wakeup</b> signal must remain constant until the <b>dfi_lp_ctrl_ack</b> signal is asserted. Once the request has been acknowledged, the MC may increase the <b>dfi_lp_ctrl_wakeup</b> signal, permitting the PHY to enter a lower power state. The PHY is not required to change power states in response to the wakeup time change.</p> <p>The MC may not decrease this value once the request has been acknowledged. The value of the <b>dfi_lp_ctrl_wakeup</b> signal at the time that the <b>dfi_lp_ctrl_req</b> signal is de-asserted sets the <b>t<sub>lp_ctrl_wakeup</sub></b> time.</p> <ul style="list-style-type: none"> <li>• If <b>dfi_lp_version</b> = 'b00: <ul style="list-style-type: none"> <li>• 'b000000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 1 cycle</li> <li>• 'b000001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 2 cycles</li> <li>• 'b000010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 4 cycles</li> <li>• 'b000011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 8 cycles</li> <li>• 'b000100 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 16 cycles</li> <li>• 'b000101 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 32 cycles</li> <li>• 'b000110 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 64 cycles</li> <li>• 'b000111 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 128 cycles</li> <li>• 'b001000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 256 cycles</li> <li>• 'b001001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 512 cycles</li> <li>• 'b001010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 1024 cycles</li> <li>• 'b001011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 2048 cycles</li> <li>• 'b001100 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 4096 cycles</li> <li>• 'b001101 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 8192 cycles</li> <li>• 'b001110 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 16384 cycles</li> <li>• 'b001111 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 32768 cycles</li> <li>• 'b010000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 65536 cycles</li> <li>• 'b010001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 131072 cycles</li> <li>• 'b010010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 262144 cycles</li> <li>• 'b010011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is unlimited</li> <li>• 'b100000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [0]</li> <li>• 'b100001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [1]</li> <li>• 'b100010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [2]</li> <li>• 'b100011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [3]</li> <li>• 'b100100 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [4]</li> <li>• 'b100101 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [5]</li> <li>• 'b100110 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [6]</li> <li>• 'b100111 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [7]</li> </ul> </li> </ul> |

**TABLE 26.** Low Power Control Interface Signals

| Signal                                   | From | Width | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------|------|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_ctrl_wakeup</b><br>(continued) |      |       |         | <ul style="list-style-type: none"> <li>• If <b>dfi_lp_version</b> = 'b01:                     <ul style="list-style-type: none"> <li>• 'b0000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 16 cycles</li> <li>• 'b0001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 32 cycles</li> <li>• 'b0010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 64 cycles</li> <li>• 'b0011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 128 cycles</li> <li>• 'b0100 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 256 cycles</li> <li>• 'b0101 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 512 cycles</li> <li>• 'b0110 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 1024 cycles</li> <li>• 'b0111 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 2048 cycles</li> <li>• 'b1000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 4096 cycles</li> <li>• 'b1001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 8192 cycles</li> <li>• 'b1010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 16384 cycles</li> <li>• 'b1011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 32768 cycles</li> <li>• 'b1100 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 65536 cycles</li> <li>• 'b1101 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 131072 cycles</li> <li>• 'b1110 = <b>t<sub>lp_ctrl_wakeup</sub></b> is 262144 cycles</li> <li>• 'b1111 = <b>t<sub>lp_ctrl_wakeup</sub></b> is unlimited</li> </ul> </li> <li>• If <b>dfi_lp_version</b> = 'b10:                     <ul style="list-style-type: none"> <li>• 'b000 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [0]</li> <li>• 'b001 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [1]</li> <li>• 'b010 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [2]</li> <li>• 'b011 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [3]</li> <li>• 'b100 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [4]</li> <li>• 'b101 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [5]</li> <li>• 'b110 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [6]</li> <li>• 'b111 = <b>t<sub>lp_ctrl_wakeup</sub></b> is <b>t<sub>lp_ctrl_wakeup_option</sub></b> [7]</li> </ul> </li> </ul> |
| <b>dfi_lp_data_ack</b>                   | PHY  | 1 bit | 0x0     | <p><u>Data low power acknowledge</u>. The <b>dfi_lp_data_ack</b> signal is asserted to acknowledge the MC data low power opportunity request. The PHY is not required to acknowledge this request.</p> <p>If the PHY acknowledges the request, the <b>dfi_lp_data_ack</b> signal must be asserted within <b>t<sub>lp_resp</sub></b> cycles after the <b>dfi_lp_data_req</b> signal assertion. Once asserted, this signal remains asserted until the <b>dfi_lp_data_req</b> signal de-asserts. The signal de-asserts within <b>t<sub>lp_data_wakeup</sub></b> cycles after the <b>dfi_lp_data_req</b> signal de-asserts, indicating that the PHY is able to resume normal operation.</p> <p>If the PHY ignores the request, the <b>dfi_lp_data_ack</b> signal must remain de-asserted for the remainder of the low power mode opportunity. The <b>dfi_lp_data_req</b> signal is asserted for at least <b>t<sub>lp_resp</sub></b> cycles.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**TABLE 26.** *Low Power Control Interface Signals*

| Signal                 | From | Width | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------|------|-------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_data_req</b> | MC   | 1 bit | 0x0     | <p><u>Data low power opportunity request.</u> The <b>dfi_lp_data_req</b> signal is used by the MC to inform the PHY of an opportunity to switch to a low power mode. When asserted, the MC indicates that no more commands will be sent on the Data Interface.</p> <p>The MC must assert a constant value on the <b>dfi_lp_data_wakeup</b> signal while this signal is asserted before the request is acknowledged by the PHY through the assertion of the <b>dfi_lp_data_ack</b> signal or until <math>t_{lp\_resp}</math> cycles have elapsed.</p> <p>The MC may increase the value of the <b>dfi_lp_data_wakeup</b> signal while the <b>dfi_lp_data_req</b> signal is asserted.</p> <p>Following the de-assertion of the <b>dfi_lp_data_req</b> signal, the PHY has <math>t_{lp\_data\_wakeup}</math> cycles to resume normal operation and de-assert the <b>dfi_lp_data_ack</b> signal.</p> |

**TABLE 26.** Low Power Control Interface Signals

| Signal                    | From | Width                                           | Default        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------|------|-------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_data_wakeup</b> | MC   | up to 6 bits depending on <b>dfi_lp_version</b> | - <sup>b</sup> | <p><u>Data low power wakeup time</u>. The <b>dfi_lp_data_wakeup</b> signal indicates which one of the 16 wakeup times the MC is requesting for the PHY.</p> <p>The signal is only valid when the <b>dfi_lp_data_req</b> signal is asserted. The <b>dfi_lp_data_wakeup</b> signal must remain constant until the <b>dfi_lp_data_ack</b> signal is asserted. Once the request has been acknowledged, the MC may increase the <b>dfi_lp_data_wakeup</b> signal, permitting the PHY to enter a lower power state. The PHY is not required to change power states in response to the wakeup time change.</p> <p>The MC may not decrease this value once the request has been acknowledged. The value of the <b>dfi_lp_data_wakeup</b> signal at the time that the <b>dfi_lp_data_req</b> signal is deasserted sets the <b>t<sub>lp_data_wakeup</sub></b> time.</p> <ul style="list-style-type: none"> <li>• If <b>dfi_lp_version</b> = 'b00:                     <ul style="list-style-type: none"> <li>• 'b000000 = <b>t<sub>lp_data_wakeup</sub></b> is 1 cycle</li> <li>• 'b000001 = <b>t<sub>lp_data_wakeup</sub></b> is 2 cycles</li> <li>• 'b000010 = <b>t<sub>lp_data_wakeup</sub></b> is 4 cycles</li> <li>• 'b000011 = <b>t<sub>lp_data_wakeup</sub></b> is 8 cycles</li> <li>• 'b000100 = <b>t<sub>lp_data_wakeup</sub></b> is 16 cycles</li> <li>• 'b000101 = <b>t<sub>lp_data_wakeup</sub></b> is 32 cycles</li> <li>• 'b000110 = <b>t<sub>lp_data_wakeup</sub></b> is 64 cycles</li> <li>• 'b000111 = <b>t<sub>lp_data_wakeup</sub></b> is 128 cycles</li> <li>• 'b001000 = <b>t<sub>lp_data_wakeup</sub></b> is 256 cycles</li> <li>• 'b001001 = <b>t<sub>lp_data_wakeup</sub></b> is 512 cycles</li> <li>• 'b001010 = <b>t<sub>lp_data_wakeup</sub></b> is 1024 cycles</li> <li>• 'b001011 = <b>t<sub>lp_data_wakeup</sub></b> is 2048 cycles</li> <li>• 'b001100 = <b>t<sub>lp_data_wakeup</sub></b> is 4096 cycles</li> <li>• 'b001101 = <b>t<sub>lp_data_wakeup</sub></b> is 8192 cycles</li> <li>• 'b001110 = <b>t<sub>lp_data_wakeup</sub></b> is 16384 cycles</li> <li>• 'b001111 = <b>t<sub>lp_data_wakeup</sub></b> is 32768 cycles</li> <li>• 'b010000 = <b>t<sub>lp_data_wakeup</sub></b> is 65536 cycles</li> <li>• 'b010001 = <b>t<sub>lp_data_wakeup</sub></b> is 131072 cycles</li> <li>• 'b010010 = <b>t<sub>lp_data_wakeup</sub></b> is 262144 cycles</li> <li>• 'b010011 = <b>t<sub>lp_data_wakeup</sub></b> is unlimited</li> <li>• 'b100000 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [0]</li> <li>• 'b100001 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [1]</li> <li>• 'b100010 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [2]</li> <li>• 'b100011 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [3]</li> <li>• 'b100100 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [4]</li> <li>• 'b100101 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [5]</li> <li>• 'b100110 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [6]</li> <li>• 'b100111 = <b>t<sub>lp_data_wakeup</sub></b> is <b>t<sub>lp_data_wakeup_option</sub></b> [7]</li> </ul> </li> </ul> |

---

## Interface Signal Groups

---

**TABLE 26.** Low Power Control Interface Signals

| Signal                                    | From | Width | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------|------|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_data_wakeup<br/>(continued)</b> |      |       |         | <ul style="list-style-type: none"> <li>• If <b>dfi_lp_version</b> = 'b01:           <ul style="list-style-type: none"> <li>• 'b0000 = <b>t<sub>lp</sub>_data_wakeup</b> is 16 cycles</li> <li>• 'b0001 = <b>t<sub>lp</sub>_data_wakeup</b> is 32 cycles</li> <li>• 'b0010 = <b>t<sub>lp</sub>_data_wakeup</b> is 64 cycles</li> <li>• 'b0011 = <b>t<sub>lp</sub>_data_wakeup</b> is 128 cycles</li> <li>• 'b0100 = <b>t<sub>lp</sub>_data_wakeup</b> is 256 cycles</li> <li>• 'b0101 = <b>t<sub>lp</sub>_data_wakeup</b> is 512 cycles</li> <li>• 'b0110 = <b>t<sub>lp</sub>_data_wakeup</b> is 1024 cycles</li> <li>• 'b0111 = <b>t<sub>lp</sub>_data_wakeup</b> is 2048 cycles</li> <li>• 'b1000 = <b>t<sub>lp</sub>_data_wakeup</b> is 4096 cycles</li> <li>• 'b1001 = <b>t<sub>lp</sub>_data_wakeup</b> is 8192 cycles</li> <li>• 'b1010 = <b>t<sub>lp</sub>_data_wakeup</b> is 16384 cycles</li> <li>• 'b1011 = <b>t<sub>lp</sub>_data_wakeup</b> is 32768 cycles</li> <li>• 'b1100 = <b>t<sub>lp</sub>_data_wakeup</b> is 65536 cycles</li> <li>• 'b1101 = <b>t<sub>lp</sub>_data_wakeup</b> is 131072 cycles</li> <li>• 'b1110 = <b>t<sub>lp</sub>_data_wakeup</b> is 262144 cycles</li> <li>• 'b1111 = <b>t<sub>lp</sub>_data_wakeup</b> is unlimited</li> </ul> </li> <li>• If <b>dfi_lp_version</b> = 'b10:           <ul style="list-style-type: none"> <li>• 'b000 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [0]</li> <li>• 'b001 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [1]</li> <li>• 'b010 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [2]</li> <li>• 'b011 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [3]</li> <li>• 'b100 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [4]</li> <li>• 'b101 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [5]</li> <li>• 'b110 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [6]</li> <li>• 'b111 = <b>t<sub>lp</sub>_data_wakeup</b> is <b>t<sub>lp</sub>_data_wakeup_option</b> [7]</li> </ul> </li> </ul> |

a. This signal is not meaningful during initialization; no default value is required.

b. This signal is not meaningful during initialization; no default value is required.

The timing parameters associated with the low power interface are listed in Table 27, “Low Power Control Interface Timing Parameters”.

**TABLE 27.** Low Power Control Interface Timing Parameters

| Parameter                                | Defined By | Min              | Max                | Unit                 | Description                                                                                                                                                                                                                                                                                                   |
|------------------------------------------|------------|------------------|--------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>lp</sub>_ctrl_wakeup</b>        | MC         | 1<br>(0x1)       | 262144<br>(0x4000) | Control clock cycles | Specifies the target maximum number of Control clock cycles that the <b>dfi_lp_ctrl_ack</b> signal may remain asserted after the de-assertion of the <b>dfi_lp_ctrl_req</b> signal. The <b>dfi_lp_ctrl_ack</b> signal may de-assert at any cycle after the de-assertion of the <b>dfi_lp_ctrl_req</b> signal. |
| <b>t<sub>lp</sub>_ctrl_wakeup_option</b> | PHY        | 0x1 <sup>a</sup> | -                  | Control clock cycles | Defines a set of eight predefined coordinated values between the MC and PHY for a target maximum number of Control clock cycles that the <b>dfi_lp_ctrl_ack</b> signal may remain asserted after the de-assertion of the <b>dfi_lp_ctrl_req</b> signal.                                                       |

---

## Interface Signal Groups

---

**TABLE 27.** Low Power Control Interface Timing Parameters

| Parameter                      | Defined By | Min              | Max                | Unit                 | Description                                                                                                                                                                                                                                                                                                   |
|--------------------------------|------------|------------------|--------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{lp\_data\_wakeup}$         | MC         | 1<br>(0x1)       | 262144<br>(0x4000) | Control clock cycles | Specifies the target maximum number of Control clock cycles that the <b>dfi_lp_data_ack</b> signal may remain asserted after the de-assertion of the <b>dfi_lp_data_req</b> signal. The <b>dfi_lp_data_ack</b> signal may de-assert at any cycle after the de-assertion of the <b>dfi_lp_data_req</b> signal. |
| $t_{lp\_data\_wakeup\_option}$ | PHY        | 0x1 <sup>a</sup> | -                  | Control clock cycles | Defines a set of eight predefined coordinated values between the MC and PHY for a target maximum number of Control clock cycles that the <b>dfi_lp_data_ack</b> signal may remain asserted after the de-assertion of the <b>dfi_lp_data_req</b> signal.                                                       |
| $t_{lp\_resp}$                 | MC         | 0x1 <sup>b</sup> | 16                 | Control clock cycles | Specifies the maximum number of Control clock cycles after the assertion of the <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> signal to the assertion of the associated <b>dfi_lp_ctrl_ack</b> or <b>dfi_lp_data_ack</b> signal.                                                                           |

a. It is recommended to allocate increasing values for parameter bits [0] to [7].

b. It is recommended to fix this timing parameter at 7 cycles.

The programmable parameters associated with the low power control interface are listed in Table 28, “Low Power Control Interface Programmable Parameters”. The **dfi\_lp\_version** parameter defines which wakeup time definition is used by both the MC and PHY. The **dfi\_lp\_wakeup\_threshold** defines the wakeup time at which the PHY is in a low power state where it can no longer respond to DFI interface requests from the controller - this includes controller updates, controller messages, and frequency change requests. Once the wakeup time meets or exceeds this value, no more commands should be sent on these interfaces. If any of these command requests are pending or currently acknowledged, the command should be allowed to complete as usual. If the PHY has no limitation, the **dfi\_lp\_wakeup\_threshold** can be set to 0 indicating that the parameter is not applicable.

**TABLE 28.** Low Power Control Interface Programmable Parameters

| Parameter                | Defined By | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_max_wakeup</b> | PHY        | Defines if the low power interface wakeup times are a max value or an average value. <ul style="list-style-type: none"><li>• 'b0 = <math>t_{lp\_ctrl\_wakeup} / t_{lp\_data\_wakeup}</math> time may be an average or estimated delay; therefore, exceeding the wakeup time should not be treated as an error condition.</li><li>• 'b1 = <math>t_{lp\_ctrl\_wakeup} / t_{lp\_data\_wakeup}</math> time is a maximum. The PHY always de-asserts the relevant <b>dfi_lp_ctrl_ack</b>/<b>dfi_lp_data_ack</b> signal within the negotiated wakeup cycles.</li></ul> |
| <b>dfi_lp_version</b>    | MC/PHY     | DFI low power version parameter. <ul style="list-style-type: none"><li>• 'b00 = Both fixed and system-predefined set of latencies.</li><li>• 'b01 = A smaller set of latencies for compatibility with older DFI versions.</li><li>• 'b10 = A set of system-predefined latencies.</li><li>• 'b11 = Reserved.</li></ul>                                                                                                                                                                                                                                           |

**TABLE 28.** Low Power Control Interface Programmable Parameters

| Parameter                      | Defined By | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_lp_wakeup_threshold</b> | MC         | Defines the low power wakeup value at which (or above) the PHY is no longer able to respond to commands including controller updates, controller messages, and frequency change requests. <ul style="list-style-type: none"><li>• 'b0 = PHY has no limitations based on wakeup time for these commands.</li><li>• All Other Values = PHY defines a wakeup threshold for accepting these commands.</li></ul> |

### 3.7 Error Interface

The error interface handles the transmission of error information. The interface includes signals and timing parameters. The error interface is an optional feature for both the MC and the PHY.

In a DDR memory sub-system, the PHY may detect various error conditions including DRAM errors (e.g., ECC errors) or PHY-specific errors (e.g., loss of DLL lock or a read DQS error). In error-condition scenarios, it may be desirable to communicate the error information from the PHY to the MC for error reporting and other possible error responses. The MC is not required to take any action other than reporting errors.

The error interface defines two signals and a timing parameter. The PHY may support the **dfi\_error** signal with or without **dfi\_error\_info**. The PHY may use a subset of the **dfi\_error\_info** signal. Signals that are not being driven must be tied LOW at the MC.

The signals and parameter associated with the error interface are listed in Table 29, “Error Interface Signals”, and Table 30, “Error Interface Timing Parameter”. The error signals are not phased for Frequency Ratio. For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

**TABLE 29.** Error Interface Signals

| Signal                | From | Width               | Default | Description                                                                                                                                                |
|-----------------------|------|---------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_error</b>      | PHY  | DFI Error Width     | 0x0     | <u>DFI error</u> . Indicates that the PHY has detected an error condition.                                                                                 |
| <b>dfi_error_info</b> | PHY  | DFI Error Width x 4 | 0x0     | <u>DFI error source</u> . Provides additional information about the source of the error detected. Only considered valid when <b>dfi_error</b> is asserted. |

Typically, the width of the **dfi\_error** signal would be equal to 1 bit per data slice plus 1 bit for control. The PHY may implement **dfi\_error** as a single bit or any other width not exceeding the sum of the data slices + 1 bit for control. The MC should accept 1 bit per instance as defined by the sum of data slices plus 1 bit for control.

The **dfi\_error\_info** signal is 4 bits per instance. The number of instances should be the same for the **dfi\_error** and **dfi\_error\_info** signals. The **dfi\_error\_info** signal is defined for some error types in this specification and may be further defined as design-specific errors by the PHY.

The error interface defines a maximum timing parameter,  $t_{error\_resp}$ . The timing parameter defines the maximum delay between receiving a command / data and detection of an error associated with that command / data.

The timing parameter associated with the error interface is listed in Table 30, “Error Interface Timing Parameter”.

**TABLE 30.** Error Interface Timing Parameter

| Parameter         | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                                                                 |
|-------------------|------------|-----|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{error\_resp}$ | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that may occur from the DFI bus transaction(s) which are known to be affected by the error condition and the assertion of the <b>dfi_error</b> signal. |

a. The minimum supportable value is 1; the DFI does not specify a maximum value. The range of values supported is implementation-specific.

## 3.8 PHY Managed Interface

The PHY managed interface provides a means for the PHY to take control of the DFI and DRAM buses, with the DRAM in a defined state. When the PHY has control of the bus, it performs all operations independent of the MC with or without accessing the DRAM. The PHY will request control and provide information on the desired state of the DRAMs when control is handed over. The MC will perform the requested action and then hand over control.

The PHY may request that the memories be placed in a specific state (such as idle or self-refresh) prior to being given control of the buses, or the PHY can indicate that the MC may transfer control in any of the supported states. The DFI bus must remain idle while the PHY is in control except that the MC may send memory refreshes if required as the MC will maintain the memory refresh timing for the system. The PHY will be responsible for forwarding all refresh information to the DRAMs before releasing the DFI bus back to the MC.

The DFI specification does not dictate any training methodology, however training may be accomplished using the PHY managed interface through PHY Independent Mode. In this mode, the controller temporarily relinquishes control of the DFI bus, except for refresh commands (if necessary) and the PHY can execute any training sequences independent of the Controller.

### 3.8.1 Inactive Chip Selects

When requesting control of the DFI/DRAM buses, the PHY will request that the memories be placed in a specific state. However, this only applies to active chip selects. Inactive chip selects are reflected by the associated **sys<sub>cs</sub>\_state** bit being cleared to 'b0. When the PHY requests control of the bus, the MC should follow these guidelines for inactive chip selects:

- Maximum power saving mode (MPSM) or deep power-down (DPD) mode  
The MC should not unnecessarily bring the memory out of the low power mode to an IDLE or SREF state. In MPSM/DPD modes, the memory contents might not be maintained by the DRAM. The MC should retain the memory in its current state.
- Uninitialized memory  
The memory should be left uninitialized until the system determines otherwise.
- Chip select that is unpopulated or powered off  
Chip select should remain off-line until the system determines otherwise.

Since the **dfi\_phymngd\_req** / **dfi\_phymngd\_ack** signals are only a single-bit, and the PHY requires that the MC will not assert the acknowledge until all chip selects are in the requested state, it is possible that a long time may pass before the

acknowledge can occur. This is particularly true for uninitialized chip selects or a chip select in MPSM or DPD, which may require a software intervention with a full initialization routine. This could result in a violation of the  $t_{phymngd\_resp}$  parameter. The behavior of the system on a  $t_{phymngd\_resp}$  violation is system-dependent and out of the scope of this document.

### 3.8.2 PHY Managed Interface Signals and Parameters

The signals and parameters associated with the PHY managed interface are listed in Table 31, “PHY Managed Interface Signals”, Table 32, “PHY Managed Interface Timing Parameters”, and Table 33, “PHY Managed Interface Programmable Parameter”.

For more information on which signals are required and which signals are optional, refer to Table 4, “DFI Signal Requirements”.

**TABLE 31. PHY Managed Interface Signals**

| Signal                      | From | Width                 | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------|------|-----------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_phymngd_ack</b>      | MC   | 1 bit                 | 0x0     | <p><u>DFI PHY managed acknowledge.</u> When asserted, the MC places the DRAM in a known state (IDLE, self-refresh, or self-refresh power-down).</p> <p>When the <b>dfi_phymngd_ack</b> signal is asserted, the PHY is the manager of DRAM bus. If required by the DRAM, the controller continues sending refresh commands on the DFI bus.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>dfi_phymngd_cs_state</b> | PHY  | DFI Chip Select Width | 0x0     | <p><u>DFI PHY managed CS state.</u> This signal indicates the state of the DRAM when the PHY becomes the manager. Each memory rank uses one bit.</p> <ul style="list-style-type: none"> <li>• 'b0 = IDLE or self-refresh. The PHY specifies the required state, using the <b>dfi_phymngd_state_sel</b> signal. For memories that support self-refresh without being in the power-down state, this state must be self-refresh without power-down.</li> <li>• 'b1 = IDLE or self-refresh or self-refresh with power-down. The PHY does not specify the state; the MC can optionally choose any supported state.</li> </ul> <p>The MC closes all the pages prior to acknowledging the request from the PHY.</p> <p>This signal is valid only when the <b>dfi_phymngd_req</b> signal is asserted by the PHY and should remain constant while the <b>dfi_phymngd_req</b> signal is asserted.</p> <p>The <b>dfi_phymngd_cs_state</b> bit values are not relevant for chip selects with <b>sys<sub>cs_state</sub></b> set to 'b0 (inactive chip selects). The MC can leave the chip selects with <b>sys<sub>cs_state</sub></b> set to 'b0 in their current, inactive state, regardless of the corresponding <b>dfi_phymngd_cs_state</b> bit value. The PHY must not require these chip selects to be in IDLE or self-refresh states.</p> <p>The system must maintain a consistent, stable view of <b>sys<sub>cs_state</sub></b> after <b>dfi_phymngd_req</b> is asserted to ensure synchronization between the MC and PHY.</p> |

**TABLE 31.** *PHY Managed Interface Signals*

| Signal                       | From | Width  | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------|------|--------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_phymngd_req</b>       | PHY  | 1 bit  | 0x0     | <p><u>DFI PHY managed request</u>. When asserted, the PHY requests control of the DFI bus.</p> <p>The systems must maintain a consistent, stable view of <b>sys<sub>cs</sub>_state</b> after <b>dfi_phymngd_req</b> is asserted for ensuring synchronization between the MC and PHY.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>dfi_phymngd_state_sel</b> | PHY  | 1 bit  | 0x0     | <p><u>DFI PHY managed state select</u>. Indication from the PHY to the MC whether the requested memory state is IDLE or self-refresh. If the per-CS <b>dfi_phymngd_cs_state</b> = 1, this signal does not apply for that chip select. The PHY does not place any requirement on the low power state of the memory, the state may be IDLE, self-refresh, or self-refresh with power-down.</p> <ul style="list-style-type: none"> <li>• If the per-CS <b>dfi_phymngd_cs_state</b> = 0, for that chip select: <ul style="list-style-type: none"> <li>• 'b0 = The MC must place the memory on the associated CS in the IDLE state.</li> <li>• 'b1 = The MC must place the memory on the associated CS in the self-refresh state. For memories that support self-refresh without being in the power-down state, this state must be self-refresh without power-down.</li> </ul> </li> </ul> <p>This signal is valid only when the <b>dfi_phymngd_req</b> signal is asserted by the PHY and should remain constant while that signal is asserted.</p> |
| <b>dfi_phymngd_type</b>      | PHY  | 2 bits | 0x0     | <p><u>DFI PHY managed request type</u>. Indicates which one of the 4 types of PHY managed interface times the <b>dfi_phymngd_req</b> signal is requesting. The value of the <b>dfi_phymngd_type</b> signal determines which one of the timing parameters (<math>t_{phymngd\_type0}</math>, <math>t_{phymngd\_type1}</math>, <math>t_{phymngd\_type2}</math>, <math>t_{phymngd\_type3}</math>) is relevant.</p> <p>The <b>dfi_phymngd_type</b> signal must remain constant during the entire time that the <b>dfi_phymngd_req</b> signal is asserted.</p> <p>The <b>dfi_phymngd_type</b> bit values are not relevant for chip selects with <b>sys<sub>cs</sub>_state</b> set to 'b0 (inactive chip selects).</p> <p>The MC can continue keeping the chip selects with <b>sys<sub>cs</sub>_state</b> set to 'b0 in their current, inactive state, regardless of the corresponding <b>dfi_phymngd_type</b> bit value. The PHY must not require these chip selects to be in IDLE or SREF states.</p>                                               |

---

## Interface Signal Groups

---

The timing parameters associated with the PHY managed interface are listed in Table 32, “PHY Managed Interface Timing Parameters”.

**TABLE 32. PHY Managed Interface Timing Parameters**

| Parameter                        | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|------------|-----|----------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>phymngd_resp</sub></b>  | MC         | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles after the <b>d<sub>fi_phymngd_req</sub></b> signal asserts to the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal. Exceptions are granted if <b>d<sub>fi_init_start</sub></b> , <b>d<sub>fi_lp_ctrl_req</sub></b> or <b>d<sub>fi_lp_data_req</sub></b> is active along with <b>d<sub>fi_phymngd_req</sub></b> . Refer to Section 4.21, “DFI Interactions” for details.<br>This timing parameter should be greater than <b>t<sub>init_resp</sub></b> . |
| <b>t<sub>phymngd_rfsh</sub></b>  | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the PHY requires for generating a refresh command to the DRAM after the PHY receives the refresh command from the MC.                                                                                                                                                                                                                                                                                                                                      |
| <b>t<sub>phymngd_type0</sub></b> | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>d<sub>fi_phymngd_req</sub></b> signal may remain asserted after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal for <b>d<sub>fi_phymngd_type</sub> = 0x0</b> . The <b>d<sub>fi_phymngd_req</sub></b> signal may de-assert at any cycle after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal.                                                                                                                           |
| <b>t<sub>phymngd_type1</sub></b> | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>d<sub>fi_phymngd_req</sub></b> signal may remain asserted after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal for <b>d<sub>fi_phymngd_type</sub> = 0x1</b> . The <b>d<sub>fi_phymngd_req</sub></b> signal may de-assert at any cycle after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal.                                                                                                                           |
| <b>t<sub>phymngd_type2</sub></b> | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>d<sub>fi_phymngd_req</sub></b> signal may remain asserted after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal for <b>d<sub>fi_phymngd_type</sub> = 0x2</b> . The <b>d<sub>fi_phymngd_req</sub></b> signal may de-assert at any cycle after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal.                                                                                                                           |
| <b>t<sub>phymngd_type3</sub></b> | PHY        | 0x1 | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles that the <b>d<sub>fi_phymngd_req</sub></b> signal may remain asserted after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal for <b>d<sub>fi_phymngd_type</sub> = 0x3</b> . The <b>d<sub>fi_phymngd_req</sub></b> signal may de-assert at any cycle after the assertion of the <b>d<sub>fi_phymngd_ack</sub></b> signal.                                                                                                                           |

a. The actual value depends on the system.

The programmable parameter associated with the PHY managed interface is listed in Table 33, “PHY Managed Interface Programmable Parameter”.

---

**TABLE 33. PHY Managed Interface Programmable Parameter**

| Parameter                           | Defined By | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>sys<sub>cs</sub>_state</code> | MC/PHY     | <p>Global parameter that defines the state of each chip select in the system. The width of <code>sys<sub>cs</sub>_state</code> is DFI Chip Select Width, with each bit corresponding to a chip select in ascending order.</p> <ul style="list-style-type: none"><li>• <code>sys<sub>cs</sub>_state[0]</code>: State of chip select 0</li><li>• <code>sys<sub>cs</sub>_state[1]</code>: State of chip select 1, etc.</li></ul> <p>The value of each bit defines the current state of the corresponding chip select with the following encoding:</p> <ul style="list-style-type: none"><li>• 'b0 = Inactive chip select that is in one of the following states:<ul style="list-style-type: none"><li>• Unpopulated, uninitialized, or powered off</li><li>• Low power state where contents are not guaranteed for the DRAM, such as deep power-down mode or maximum power savings mode</li></ul></li><li>• 'b1 = Active chip select: An active chip select can be in an active, IDLE, or low power state for which the memory contents are maintained by the DRAM, MC, or both.</li></ul> <p>The system must maintain a consistent, stable view of <code>sys<sub>cs</sub>_state</code> between the PHY and MC for ensuring synchronization between the MC and PHY.</p> |

### 3.9 Disconnect Protocol

The DFI specification defines several interface handshakes between the MC and the PHY. In some cases, the interface handshake can be terminated by only one of the devices, and the disconnect timing might be long or indeterminate. In some circumstances, it may be desirable for a device to disconnect the handshake. Some circumstances which might warrant a disconnect are:

- A high-priority operation that the system must continue to be fully operational
- To respond to an error condition even if the system stops being fully operational
- A timing or other such violation that would occur if the system did not disconnect in a reasonable time

When such a situation occurs, the disconnect should be relatively short, with a predictable disconnect time, leaving the system in a known state. The disconnect time is defined through multiple timing parameters, and the state is defined through the `dfi_disconnect_error` signal.

A MC that uses the disconnect protocol with an earlier DFI version PHY violates the earlier protocol and produces unpredictable results. For a DFI 4.0 MC to work with an earlier version of the PHY, the MC should implement a method for disabling the disconnect protocol. A PHY that works with a MC that is earlier than DFI 4.0 does not detect a disconnect and therefore will have no issues.

DFI 4.0 PHYs must be able to tolerate a disconnect requests on all interfaces. However, the PHY is not required to disconnect and can define the disconnect timing accordingly. The PHY can support either the error or QOS disconnect on any of the interfaces. However, if the PHY goes into an error state, it should not disconnect if `dfi_disconnect_error` = 'b0. The PHY should clearly define support for disconnect on all interfaces.

---

## Interface Signal Groups

---

Presently, there are multiple interface handshakes in the DFI 4.0 specification as shown in Table 34, “MC / PHY Handshaking Interfaces and Signals”.

---

**TABLE 34. MC / PHY Handshaking Interfaces and Signals**

| Interface         | Handshaking Description | Signals                                                                              | Supports the Disconnect Protocol |
|-------------------|-------------------------|--------------------------------------------------------------------------------------|----------------------------------|
| Update            | Controller Update       | <b>dfi_ctrlupd_req / dfi_ctrlupd_ack</b>                                             | Yes                              |
|                   | PHY Update              | <b>dfi_phyupd_req / dfi_phyupd_ack</b>                                               | Yes                              |
| Low Power Control | Low Power Control       | <b>dfi_lp_ctrl_req / dfi_lp_ctrl_ack</b><br><b>dfi_lp_data_req / dfi_lp_data_ack</b> | No                               |
| PHY Managed       | PHY Managed             | <b>dfi_phymngd_req / dfi_phymngd_ack</b>                                             | Yes                              |
| Status            | Frequency Change        | <b>dfi_init_start / dfi_init_complete</b>                                            | No                               |

The signal associated with the disconnect protocol is listed in Table 35, “Disconnect Protocol Signal”.

---

**TABLE 35. Disconnect Protocol Signal**

| Signal                      | From | Width | Default | Description                                                                                                                                                                                                                                                                                               |
|-----------------------------|------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_disconnect_error</b> | MC   | 1 bit | 0x0     | <u>DFI disconnect error</u> . Indicates if the current disconnect is an error or a QOS (fully operational) request. If de-asserted, the disconnect request requires that the PHY remain fully operational after the disconnect. If asserted, the PHY might not be fully operational after the disconnect. |

The disconnect protocol defines eight pairs of timing parameters; each affected interface has a **t\*\_disconnect** and **t\*\_disconnect\_error** timing parameter. The **t\*\_disconnect** timing parameter is associated with **dfi\_disconnect\_error = 'b0** and the **t\*\_disconnect\_error** timing parameter is associated with **dfi\_disconnect\_error = 'b1**. Both parameters define the maximum number of clocks to disconnect.

The timing parameters associated with the disconnect protocol are listed in Table 36, “Disconnect Protocol Timing Parameters”.

---

**TABLE 36. Disconnect Protocol Timing Parameters**

| Parameter                  | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                                                                                                                      |
|----------------------------|------------|-----|----------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>tctrlupd_disconnect</b> | PHY        | 0x0 | - <sup>a</sup> | Control clock cycles | Defines the maximum number of Control clocks that are required to disconnect the PHY during a controller update sequence, from the de-assertion of <b>dfi_ctrlupd_req</b> to the de-assertion of <b>dfi_ctrlupd_ack</b> when <b>dfi_disconnect_error = 'b0</b> . |

**TABLE 36.** Disconnect Protocol Timing Parameters

| Parameter                        | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                                                                                                                     |
|----------------------------------|------------|-----|----------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>tctrlupd_disconnect_error</b> | PHY        | 0x0 | - <sup>a</sup> | Control clock cycles | Defines the maximum number of Control clocks that are required to disconnect the PHY during a controller update sequence, from the de-assertion of <b>dfi_ctrlupd_req</b> to the de-assertion of <b>dfi_ctrlupd_ack</b> when <b>dfi_disconnect_error</b> = 'b1. |
| <b>tphymngd_disconnect</b>       | PHY        | 0x0 | - <sup>a</sup> | Control clock cycles | Defines the maximum number of Control clocks that are required to disconnect the PHY during a PHY managed request, from the de-assertion of <b>dfi_phymngd_req</b> to the de-assertion of <b>dfi_phymngd_ack</b> when <b>dfi_disconnect_error</b> = 'b0.        |
| <b>tphymngd_disconnect_error</b> | PHY        | 0x0 | - <sup>a</sup> | Control clock cycles | Defines the maximum number of Control clocks that are required to disconnect the PHY during a PHY managed request, from the de-assertion of <b>dfi_phymngd_req</b> to the de-assertion of <b>dfi_phymngd_ack</b> when <b>dfi_disconnect_error</b> = 'b1.        |
| <b>tphyupd_disconnect</b>        | PHY        | 0x0 | - <sup>a</sup> | Control clock cycles | Defines the maximum number of Control clocks that are required to disconnect the PHY during a PHY update sequence, from the de-assertion of <b>dfi_phyupd_ack</b> to the de-assertion of <b>dfi_phyupd_req</b> when <b>dfi_disconnect_error</b> = 'b0.          |
| <b>tphyupd_disconnect_error</b>  | PHY        | 0x0 | - <sup>a</sup> | Control clock cycles | Defines the maximum number of Control clocks that are required to disconnect the PHY during a PHY update sequence, from the de-assertion of <b>dfi_phyupd_ack</b> to the de-assertion of <b>dfi_phyupd_req</b> when <b>dfi_disconnect_error</b> = 'b1.          |

- a. The minimum supportable value is 1; the DFI does not specify a maximum value. The range of values supported is implementation-specific.

### 3.10 MC to PHY Message Interface

The MC to PHY message interface handles the transmission of messages from the MC to the PHY; the interface includes signals and timing parameters. The communication interface is an optional feature for both the MC and the PHY.

In a DDR memory sub-system, the memory subsystem functions may be supported in the controller, PHY, or both. In some instances, a function executed by the controller may result in the need to send a message to the PHY. The MC to PHY message interface encodes messages from the MC to the PHY. The messaging includes both pre-defined messages and device-specific messages. The controller and PHY should support the same encodings.

The signals and parameters associated with the MC to PHY Message interface are listed in Table 37, “MC to PHY Message Interface Signals” and Table 38, “MC to PHY Message Interface Timing Parameters”.

**TABLE 37.** MC to PHY Message Interface Signals

| Signal                  | From | Width   | Default | Description                                                                                                                                                                                                                                                                                                                                            |
|-------------------------|------|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_ctrlmsg</b>      | MC   | 8 bits  | 0x00    | <u>DFI Controller Message Command</u> . Valid only when the <b>dfi_ctrlmsg_req</b> signal is asserted. Encodes messages from the MC to the PHY.                                                                                                                                                                                                        |
| <b>dfi_ctrlmsg_ack</b>  | PHY  | 1 bit   | 0x0     | <u>DFI Controller Message Acknowledge</u> . When asserted, indicates that the PHY received the MC message. If the message is to be acknowledged, the <b>dfi_ctrlmsg_ack</b> signal must assert by within <b>t_ctrlmsg_resp</b> clock cycles. Once asserted, the <b>dfi_ctrlmsg_ack</b> signal must de-assert within <b>t_ctrlmsg_max</b> clock cycles. |
| <b>dfi_ctrlmsg_data</b> | MC   | 16 bits | 0x0000  | <u>DFI Controller Message Data</u> . Valid only when the <b>dfi_ctrlmsg_req</b> signal is asserted. Data associated with the info command from the MC to the PHY.                                                                                                                                                                                      |
| <b>dfi_ctrlmsg_req</b>  | MC   | 1 bit   | 0x0     | <u>DFI Controller Message Request</u> . When asserted, indicates a valid MC to PHY message. If acknowledged, the request must remain asserted until the <b>dfi_ctrlmsg_ack</b> signal is de-asserted. If not acknowledged within <b>t_ctrlmsg_resp</b> , the request should be de-asserted.                                                            |

The timing parameters associated with the MC to PHY message interface are listed in Table 38, “MC to PHY Message Interface Timing Parameters”.

**TABLE 38.** MC to PHY Message Interface Timing Parameters

| Parameter             | Defined By | Min | Max            | Unit                 | Description                                                                                                                                                            |
|-----------------------|------------|-----|----------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t_ctrlmsg_max</b>  | MC         | N/A | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clocks that the <b>dfi_ctrlmsg_ack</b> signal can remain asserted.                                                             |
| <b>t_ctrlmsg_resp</b> | MC         | 1   | - <sup>a</sup> | Control clock cycles | Specifies the maximum number of Control clock cycles between the assertion of the <b>dfi_ctrlmsg_req</b> signal to the assertion of the <b>dfi_ctrlmsg_ack</b> signal. |

a. There is no maximum value defined by the specification. The range of values supported is implementation-specific.

### 3.11 WCK Control Interface

For DRAM devices that utilize a Write Clock (WCK) clocking system, signals are defined to control the WCK synchronization sequence turning the WCK on, the toggle modes, the static states, and turning the WCK off. The signals are sent from the controller to the PHY data slices and are phased signals defined by the data frequency ratio. The **dfi\_wck\_en** signal defines when the clock is enabled and disabled. The **dfi\_wck\_toggle** signal is a 2-bit encoded value that communicates the states of the WCK: STATIC\_LOW, STATIC\_HIGH, TOGGLE and FAST\_TOGGLE. Timing parameters are defined in the Data clock domain to allow PHY-specific timing requirements to be reflected in the signal timing across the interface.

---

## Interface Signal Groups

---

The signals and parameters associated with the WCK control interface are listed in Table 39, “WCK Control Interface Signals” and Table 40, “WCK Control Interface Timing Parameters”. These are always phased signals supporting the WCK to CK ratio of 2:1, 4:1 or both. The number of instances of the signals is defined by the term DFI WCK Width which is generally defined by the number of WCK’s on the memory bus. If there are multiple WCK’s to the memory bus, the entire WCK control signal group will be replicated per WCK instance. All WCK control signals are replicated per data slice.

---

**TABLE 39. WCK Control Interface Signals**

| Signal                                                              | From | Width                                                    | Default | Description                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------------|------|----------------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>dfi_wck_cs</b><br>or<br><b>dfi_wck_cs_pN<sup>a</sup></b>         | MC   | DFI WCK Width x DFI CS Width x DFI Data Slice Count (3X) | 0x0     | <u>WCK chip select</u> . This signal indicates which chip selects currently have the WCK active. More than one chip select can be active at a time. There is one bit per chip select. This signal is only valid when the <b>dfi_wck_en</b> signal is asserted.                                                                             |
| <b>dfi_wck_en</b><br>or<br><b>dfi_wck_en_pN<sup>a</sup></b>         | MC   | DFI WCK Width x Data Slice Count                         | 0x0     | <u>WCK clock enable</u> . This signal defines when the WCK clock is driven or disabled (tri-state). <ul style="list-style-type: none"> <li>• 'b0 = WCK disabled</li> <li>• 'b1 = WCK enabled</li> </ul>                                                                                                                                    |
| <b>dfi_wck_toggle</b><br>or<br><b>dfi_wck_toggle_pN<sup>a</sup></b> | MC   | DFI WCK Width x 2 x Data Slice Count                     | 0x0     | <u>WCK toggle</u> . This is a 2-bit encoded value defining the state of the WCK clock. This signal is only valid when the <b>dfi_wck_en</b> signal is asserted. <ul style="list-style-type: none"> <li>• 'b00 = WCK static low</li> <li>• 'b01 = WCK static high</li> <li>• 'b10 = WCK toggle</li> <li>• 'b11 = WCK fast-toggle</li> </ul> |

- a. For frequency ratio systems, replicates signals into phase/data word/clock cycle-specific buses that define the validity of the data for each phase N (pN)/data word N (wN)/clock cycle N (aN), as applicable. The phase 0 suffixes are not required.

The timing parameters associated with the WCK control interface are listed in Table 40, “WCK Control Interface Timing Parameters”.

---

**TABLE 40. WCK Control Interface Timing Parameters**

| Parameter                    | Defined By | Min | Max            | Unit              | Description                                                                                                                                                                                                                            |
|------------------------------|------------|-----|----------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>t<sub>wck_dis</sub></b>   | PHY        | ?   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clock cycles between the last command (LAST CMD) without a WCK synchronization required (assuming no command issued) or any command that disables the WCK to when the <b>dfi_wck_en</b> signal is disabled. |
| <b>t<sub>wck_en_fs</sub></b> | PHY        | ?   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clocks between the CAS_WS_FS command to when the <b>dfi_wck_en</b> signal is driven.                                                                                                                        |

**TABLE 40.** WCK Control Interface Timing Parameters

| Parameter               | Defined By | Min | Max            | Unit              | Description                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------|------------|-----|----------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{wck\_en\_rd}$       | PHY        | ?   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clocks between the CAS_WS_RD command to when the <b>dfi_wck_en</b> signal is driven.                                                                                                                                                                                                                                                       |
| $t_{wck\_en\_wr}$       | PHY        | 0   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clocks between the CAS_WS_WR command to when the <b>dfi_wck_en</b> signal is driven.                                                                                                                                                                                                                                                       |
| $t_{wck\_en\_wrX}$      | PHY        | 0   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clocks between the CAS_WS_WRX command to when the <b>dfi_wck_en</b> signal is driven.                                                                                                                                                                                                                                                      |
| $t_{wck\_fast\_toggle}$ | PHY        | 1   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clock cycles between the <b>dfi_wck_toggle</b> signal being driven to TOGGLE to when the <b>dfi_wck_toggle</b> signal is driven to FAST_TOGGLE. This timing is only applicable when the WCK transitions from the slow to fast toggle. Otherwise, this timing parameter should be set to 0x0.                                               |
| $t_{wck\_toggle}$       | PHY        | 1   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clock cycles between the <b>dfi_wck_en</b> signal being enabled to when the <b>dfi_wck_toggle</b> signal is driven to TOGGLE.                                                                                                                                                                                                              |
| $t_{wck\_toggle\_cs}$   | PHY        | 0   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clock cycles between a read or write command to when the <b>dfi_wck_cs</b> signal must be stable. This timing is applicable when the WCK is synchronized for multiple CS's and commands are to different CS's. During WCK synchronization, the CS should be static from the CAS command to the completion of the synchronization sequence. |
| $t_{wck\_toggle\_post}$ | PHY        | 0   | - <sup>a</sup> | Data clock cycles | Defines the number of Data clock cycles after a read or write command data burst completion during which the WCK must remain in the current toggle state. During this time, the <b>dfi_wck_es</b> signal must also remain stable.                                                                                                                                     |

a. There is no maximum value defined by the specification. The range of values supported is implementation-specific.

### 3.12 Channels for Multi-Channel Memories

Certain memories define the host interface signaling in terms of channels or subchannels. For example, a single DRAM device may have two channels that operate independently except for the reset. In this case, the system can organize the memory channels as two “independent” 16-bit memory interfaces, or “combined” as a single 32-bit memory. As another example, a single DIMM may have two subchannels that are semi-independent, but share a resource like an RCD. In this case, the system can treat the subchannels as “independent” for certain operations, but “shared” for others, or “combined” as a single wide memory.

It might be desirable to support various options in the MC and PHY. Furthermore, it may be desirable to implement such a system with multiple MC and/or PHY instances connected to one memory interface. A DFI channel may represent a

---

## Interface Signal Groups

---

channel or subchannel. The DFI signal width parameters describe a single DFI channel. A single MC and/or PHY may connect to one or more DFI channels.

In a combined interface, multiple DFI channels will operate in lock-step. The DFI read and write data and WCK sub-interfaces will be used together for transferring multiple channels' worth of data. For all other DFI sub-interfaces, the PHY can optionally connect to a single instance or to multiple instances of the sub-interface.

In combined mode, the **phy\_channel\_en** programmable parameter indicates which interface instance(s) the PHY connects to. All subinstances in combined mode must use the same instance. For independent mode, all channels must always be enabled. Table 41, “DFI Channel Programmable Parameters” defines this programming parameter.

NOTE: The timing parameters for all interfaces operating in lock-step must be programmed identically.

---

**TABLE 41.** *DFI Channel Programmable Parameters*

| Parameter             | Defined By   | Description                                                                                                                                                                                                                        |
|-----------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phy_channel_en</b> | System / PHY | Defines which DFI channels are enabled. <ul style="list-style-type: none"><li>• 'b00 = Reserved</li><li>• 'b01 = Only Channel 0 enabled.</li><li>• 'b10 = Only Channel 1 enabled.</li><li>• 'b11 = All channels enabled.</li></ul> |

In an independent interface, multiple DFI channels will operate independently or semi-independently. The DFI read and write data and WCK sub-interfaces are assumed to always operate independently. For all other DFI sub-interfaces, a parameter indicates whether that sub-interface operates independently per-DFI-channel or in lock-step. Table 42, “DFI Sub-interface Channel Mode Parameters” defines these parameters. Note: Due to restrictions within a protocol, certain individual signals may be required to operate in combined or lock-step mode regardless of the sub-interface mode. Examples include **dfi\_reset\_n**, **dfi\_dram\_clk\_disable**, **dfi\_alert\_n**, etc.

---

**TABLE 42.** *DFI Sub-interface Channel Mode Parameters*

| Interface | Associated Parameters         | Defined by    | Description                                                                                                                                |
|-----------|-------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| command   | <b>dfi_cmd_dfich_mode</b>     | MC and/or PHY | <ul style="list-style-type: none"><li>• 'b0 = Independent per-DFI channel mode</li><li>• 'b1 = Combined/Shared or Lock-step mode</li></ul> |
| ctrlupd   | <b>dfi_ctrlupd_dfich_mode</b> | MC and/or PHY | <ul style="list-style-type: none"><li>• 'b0 = Independent per-DFI channel mode</li><li>• 'b1 = Combined/Shared or Lock-step mode</li></ul> |
| phyupd    | <b>dfi_phyupd_dfich_mode</b>  | MC and/or PHY | <ul style="list-style-type: none"><li>• 'b0 = Independent per-DFI channel mode</li><li>• 'b1 = Combined/Shared or Lock-step mode</li></ul> |

**TABLE 42.** DFI Sub-interface Channel Mode Parameters

|            |                                  |               |                                                                                                                                               |
|------------|----------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| status     | <b>dfi_status_dfich_mode</b>     | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |
| phymngd    | <b>dfi_phymngd_dfich_mode</b>    | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |
| ctrlmsg    | <b>dfi_ctrlmsg_dfich_mode</b>    | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |
| lp_ctrl    | <b>dfi_lpctrl_dfich_mode</b>     | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |
| lp_data    | <b>dfi_lpdata_dfich_mode</b>     | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |
| disconnect | <b>dfi_disconnect_dfich_mode</b> | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |
| error      | <b>dfi_error_dfich_mode</b>      | MC and/or PHY | <ul style="list-style-type: none"> <li>• 'b0 = Independent per-DFI channel mode</li> <li>• 'b1 = Combined/Shared or Lock-step mode</li> </ul> |

Each IP may specify which mode (or modes) it supports for each sub-interface. If an IP only supports lock-step mode, it may optionally implement only a single copy of that sub-interface. A system connecting an MC and PHY supporting different modes on a sub-interface may require some glue logic. It is assumed that support for combined and independent modes, and current mode of operation, are defined outside of DFI.

### 3.13 Link ECC

LPDDR5 DRAM memories support Link ECC between a DRAM and the controller/SOC. During a write burst, ECC will be generated and checked across 128 data bits and sent to the DRAM on the RDQS\_t pin. During a read burst, ECC will be generated and checked across 128 data bits and sent to the controller on the DMI (DBI) pin. In LPDDR5, link ECC and Read DBI & link ECC and the read data copy functions are mutually exclusive. Link ECC is an optional feature used with write and read bursts transmissions to generate ECC.

If the programmable parameter **phylinkecc\_mode** = 1, the MC controls the link ECC functionality and the **dfi\_rddata\_db1** signal is required for read transactions and the **dfi\_wrdata\_ecc** signal is required for write transactions. If the programmable parameter **phylinkecc\_mode** = 0, the PHY controls link ECC functionality or link ECC is not supported. If

link ECC is required in a system, either the MC or the PHY is able to generate ECC outputs for write commands and check EC C inputs for read commands.

The PHY defines the programmable parameter **phy<sub>linkecc\_mode</sub>** value to determine how link ECC is handled, as defined in Table 43, “DFI Link ECC Programmable Parameters”.

---

**TABLE 43. DFI Link ECC Programmable Parameters**

| Parameter                         | Defined By | Description                                                                                                                                                                                                                                  |
|-----------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phy<sub>linkecc_mode</sub></b> | PHY        | PHY Link ECC Responsibility. Defines which device controls link ECC. <ul style="list-style-type: none"><li>• 'b0 = Link ECC control is handled in the PHY or not supported.</li><li>• 'b1 = Link ECC control is handled in the MC.</li></ul> |

If the MC supports link ECC on the DFI, the MC must support both settings of the **phy<sub>linkecc\_mode</sub>** parameter; the MC must be able to generate ECC for the write data, check and correct ECC for the read data. If the memory subsystem supports link ECC on the DFI, the PHY can optionally support either setting of the **phy<sub>linkecc\_mode</sub>** parameter; the PHY can optionally generate ECC for write data, check and correct ECC for the read data as required or not support the function at all. If the PHY does not support Link ECC, then PHY must be able to interface to a MC that has link ECC support. In LPDDR5, link ECC and read DBI & link ECC and the Read Data Copy functions are mutually exclusive.

When the **phy<sub>linkecc\_mode</sub>** = 1, the PHY transfers the read ECC on the **dfi\_rddata\_dbi** signal coincident with the **dfi\_rddata** signal. The MC transfers the write ECC on the **dfi\_wrdata\_ecc** signal coincident with the **dfi\_wrdata** signal. The link ECC information transferred on the **dfi\_rddata\_dbi** and **dfi\_wrdata\_ecc** signals in relationship with data follows the JEDEC LPDDR5 specification.

The **dfi\_rddata\_dbi** signal has two mutually exclusive functions. If the DBI is enabled, **dfi\_rddata\_dbi** defines the DBI of the **dfi\_rddata** signal. If DBI is disabled and Link ECC is enabled, **dfi\_rddata\_dbi** defines ECC of the **dfi\_rddata** signal.

### 3.14 Link DQ CRC

DDR5 MRDIMMs in Mux Mode support an optional DQ Bus CRC on the link between host and Data Buffer. During a write or read burst, an 8-bit CRC is generated and checked across every 64-bits of data transmitted to or from the same pseudo-channel of the same data buffer, and is transmitted in parallel on the unused DQS1 pins. Write Link CRC and DRAM Write CRC are mutually exclusive. Since link CRC data is pseudo-channel interleaved like DQ data, if only one pseudo-channel is active, the DQS1 of the inactive pseudo-channel must be “1” (like DQ).

If the data buffer detects an error on the write CRC, the DIMM will use the **ALERT\_N** signal to notify the host. The response time can be determined from the JEDEC DDR5MRCD and DDR5MDB specifications.

If the programmable parameter **phy<sub>linkdqrc\_mode</sub>** = 1, the MC controls the link CRC functionality and the **dfi\_rddata\_crc** signal is required for read transactions and the **dfi\_wrdata\_crc** signal is required for write transactions. If the programmable parameter **phy<sub>linkdqrc\_mode</sub>** = 0, link CRC is not supported.

The PHY defines the programmable parameter **phy<sub>linkdqrc\_mode</sub>** value to determine how link ECC is handled, as defined in Table 43, “DFI Link ECC Programmable Parameters”.

---

## Interface Signal Groups

---

**TABLE 44.** DFI DQ Link CRC Programmable Parameters

| Parameter               | Defined By | Description                                                                                                                                                                                                                          |
|-------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>phylinkdqrc_mode</b> | PHY        | DQ Link CRC Support. Defines whether DQ Link CRC is supported on the DFI. <ul style="list-style-type: none"> <li>• 'b0 = DQ Link CRC control is not supported.</li> <li>• 'b1 = DQ Link CRC control is handled in the MC.</li> </ul> |

If the MC supports link CRC on the DFI, the MC must be able to generate CRC for the write data, check CRC for the read data, and respond to write CRC errors detected by the data buffer.

When the **phylinkdqrc\_mode** = 1, the PHY transfers the read CRC on the **dfi\_rddata\_crc** signal coincident with the **dfi\_rddata** signal. The MC transfers the write CRC on the **dfi\_wrdata\_crc** signal coincident with the **dfi\_wrdata** signal. The link CRC information transferred on the **dfi\_rddata\_crc** and **dfi\_wrdata\_crc** signals in relationship with data follows the JEDEC DDR5MDB specification. The PHY also transfers the error indicator on the **dfi\_alert\_n** signal.

Figure 3, “Link DQ CRC Packet” shows how the data is organized at the DRAM for each pseudo-channel when the data is not aligned and the burst length is 16.

**FIGURE 3.** Link DQ CRC Packet



## 4.0 Functional Use

While some of the diagrams illustrate DFI PHY signals, these signals are only an interpretive example of internal PHY signals, they are not signals on the DFI.

### 4.1 Initialization

The DFI signals that communicate commands or status, shown in Figure 4, “Dependency on **dfi\_init\_complete**”, must maintain their default value until the **dfi\_init\_complete** signal is asserted.

**FIGURE 4.** Dependency on **dfi\_init\_complete**



The default value for each signal is listed in the corresponding interface table. For example, the default for command signals are listed in the default column of Table 13, “Command Interface Signals”.

1. High active signals have a default value of 0 (e.g., **dfi\_odt**, **dfi\_wrdata\_en**).
2. Low active signals have a default value of 1 (e.g., **dfi\_we\_n**).
3. Signal buses have an unspecified default value (e.g., **dfi\_address**, **dfi\_cid**). For protocols that use a CA bus, the **dfi\_address** signal does not have a default value. For protocols that use a CA bus, the **dfi\_address** bus must drive a DES command until the **dfi\_init\_complete** signal is asserted
4. State-specific signals have state-specific values (e.g. **dfi\_dram\_clk\_disable\_pN**, **dfi\_parity\_in**).

The **dfi\_init\_start** signal is used for indicating that the MC is driving valid values on the DFI signals and that the optional **dfi\_cmd\_freq\_ratio** and **dfi\_data\_freq\_ratio** signals of the status interface are valid. The **dfi\_cmd\_freq\_ratio** signal identifies the MC:PHY control to command frequency ratio and the **dfi\_data\_freq\_ratio** signal identifies the MC:PHY control to data frequency ratio. The PHY must use the **dfi\_init\_start** signal assertion to know that this status signal is valid.

Figure 5, “System Setting Signals - **dfi\_init\_start** Asserts Before **dfi\_init\_complete**” shows that during initialization, if the frequency ratio protocol is implemented, the **dfi\_init\_start** signal should only be asserted after the **dfi\_cmd\_freq\_ratio** and/or **dfi\_data\_freq\_ratio** signals have been defined. The PHY must wait for the **dfi\_init\_start** assertion before asserting the **dfi\_init\_complete** signal. When both **dfi\_init\_start** and **dfi\_init\_complete** signals are asserted for at least one DFI clock cycle, the MC de-asserts the **dfi\_init\_start** signal before sending DFI transactions. On the initial run of **dfi\_init\_start**, the user should also define the initial frequency for the system on the **dfi\_frequency** signal and define the value for the **dfi\_init\_freq** timing parameter.

**FIGURE 5.** System Setting Signals - ***dfi\_init\_start*** Asserts Before ***dfi\_init\_complete***

Note: “Initial Value” is the expected value at which the PHY initially transfers DFI bus ownership to the MC with the ***dfi\_init\_complete*** assertion.

The DFI specification does not impose or dictate a reset sequence or any type of signal training for either the PHY or the MC prior to DFI signal assertion. However, the assertion of the ***dfi\_init\_complete*** signal signifies that the PHY is ready to respond to any assertions on the DFI by the MC and ensures appropriate responses on the DFI. The PHY must guarantee the integrity of the command interface to the DRAMs prior to asserting the ***dfi\_init\_complete*** signal.

During initialization, the MC and PHY must ensure that all the memory and DFI timing requirements are met prior to transitioning corresponding ***dfi\_init\_start*** and ***dfi\_init\_complete*** signals. For DRAMs that use a CA bus, the signals of the command interface must drive a DES (de-select) command until the ***dfi\_init\_complete*** signal is asserted

## 4.2 PHY Independent Training Boot Sequence

The PHY executes the memory boot sequence by programming memory, executing training sequences, etc. before asserting the ***dfi\_init\_complete*** signal to the MC. The ***dfi\_phymngd\_req*** signal is not asserted as part of the boot sequence for training. However, when the MC asserts the ***dfi\_init\_start*** signal, the MC is also expected to de-assert the ***dfi\_reset\_n*** signal and/or drive the ***dfi\_cke*** signal with an appropriate value in the ***dfiboot\_state*** programmable parameter.

Figure 6, “MC De-Asserting ***dfi\_reset\_n*** and/or Asserting ***dfi\_cke*** along with ***dfi\_init\_start***” illustrates the MC changing the state of the ***dfi\_reset\_n*** signal and/or ***dfi\_cke*** signal on the same cycle as the ***dfi\_init\_start*** signal is asserted.

**FIGURE 6.** MC De-Asserting ***dfi\_reset\_n*** and/or Asserting ***dfi\_cke*** along with ***dfi\_init\_start***

Note: The MC is expected to drive the ***dfi\_cke*** signal with appropriate value as per the state of the memory defined in the ***dfiboot\_state*** programmable parameter.  
Note: The PHY is responsible for driving the RESET and/or CKE IOs on the memory with appropriate values until the ***dfi\_init\_complete*** signal is asserted.

Once the PHY asserts the ***dfi\_init\_complete*** signal and the MC de-asserts the ***dfi\_init\_start*** signal, the MC may execute any command including MRR, MRW, ZQ, etc. The controller is NOT required to execute any of the commands. Any boot

sequence commands that are not required prior to training are not defined by the DFI specification. Memory state information must be known including refresh state, bank states, low power state, etc. The memory must be given to the MC as defined in the **dfiboot\_state** programmable parameter. Refer to Section 3.11, “WCK Control Interface” for the WCK state that must be maintained before the PHY asserts the **dfi\_init\_complete** signal during initialization for DRAMs which support WCK.

#### **4.2.1 Refresh Requirements**

Following the PHY boot sequence, the MC will assume the following regarding refresh:

- Refresh is enabled and must be maintained.
- The refresh count is not at a credit or deficit.
- The next refresh can be issued after tREFIab; if using Per Bank Refresh, a new sequence can be started and the first refresh can be issued after tREFIpb.
- All DFI timers, such as **tctrlupd\_interval**, should start counting; no DFI commands should be required prior to the associated timer expiring.

The PHY must give the DFI to the controller without any refresh requirements - for example, the PHY cannot be in a refresh deficit.

#### **4.2.2 Boot Into Self-Refresh**

The **dfiboot\_state** programmable parameter defines the state of memory as either Idle or Self-Refresh (but not Self-Refresh Power-down) when the PHY completes its boot sequence. The same refresh rules apply even when passing the memory back in the Self-Refresh state.

### **4.3 Command Interface Signals**

The DFI command signals consist of the Command Address (CA) signals **dfi\_act\_n**, **dfi\_address**, **dfi\_bank**, **dfi\_bg**, **dfi\_cas\_n**, **dfi\_ras\_n**, **dfi\_we\_n**, **dfi\_cid**, **dfi\_cke**, **dfi\_cs**, **dfi\_odt** and **dfi\_reset\_n**. The DFI command interface signals correlate to the DRAM command signals, and are driven according to the timing parameters **tctrl\_delay** and **tcmd\_lat**. For more information on command signals and parameters, refer to Section 3.1, “Command Interface”.

Figure 7, “DFI Command Interface Signal Relationships” shows that the command signals are driven to the DRAMs and the DFI relationship of the command signals is expected to be maintained at the PHY-DRAM boundary so any delays should be consistent across all signals and defined through the timing parameter **tctrl\_delay**. All command signals are

---

## Functional Use

---

illustrated but might not all be required, depending on system requirements. Refer to Table 4, “DFI Signal Requirements” to determine the signals that are relevant for a specific system.

---

**FIGURE 7. DFI Command Interface Signal Relationships**



NOTE: The system might not use all of the pins on the DRAM interface, such as additional bank and chip selects. If these signals are never used in a system, they are not required on the DFI. However, if multiple memory sub-systems are supported, the union of the required signals must exist on DFI. In this case, signals unused for a specific topology must be driven through the DFI and must not be left floating.

Based on current DRAM settings, the MC defines  $t_{cmd\_lat}$  with the parameter value defining when the CA bus is driven for each command. The timing of the CA bus assertion is relative to the assertion of **dfi\_es**.

Figure 8, “Example of  $t_{cmd\_lat}$  ( $t_{cmd\_lat} = 1$ ,  $t_{phy\_wrlat} = 2$ )” illustrates how the  $t_{cmd\_lat}$  parameter relates the DFI command to the DFI chip select. This figure also shows how DFI timing parameters, such as  $t_{phy\_wrlat}$ , relate to the DFI command when  $t_{cmd\_lat}$  is defined as a non-zero value.

For more information on  $t_{cmd\_lat}$ , refer to Table 14, “Command Interface Timing Parameters”.

**FIGURE 8.** Example of  $t_{cmd\_lat}$  ( $t_{cmd\_lat} = 1$ ,  $t_{phy\_wrlat} = 2$ )



## 4.4 DFI Clock Disabling

The DFI contains a **dfi\_dram\_clk\_disable** signal which controls the host command clock. In the default state, the host clock functions normally and the **dfi\_dram\_clk\_disable** bits are all de-asserted. If the system requires the clocks of the memory device(s) to be disabled, the **dfi\_dram\_clk\_disable** signal is asserted. For more information on the **dfi\_dram\_clk\_disable** signal, refer to Section 3.5, “Status Interface”.

Figure 9, “DRAM Clock Disable Behavior” shows that two timing parameters  $t_{dram\_clk\_disable}$  and  $t_{dram\_clk\_enable}$  indicate the number of Command clock cycles that the PHY requires to respond to the assertion and de-assertion of the **dfi\_dram\_clk\_disable** signal. The  $t_{dram\_clk\_disable}$  value determines the number of Command clock cycles in which a

rising edge of the **dfi\_dram\_clk\_disable** signal affects the host clock and **t<sub>dram\_clk\_enable</sub>** sets the number of cycles required for the host clock to be active again.

---

**FIGURE 9.** DRAM Clock Disable Behavior


## 4.5 3DS Stack Support

The DFI specification supports 3D stacks. The signaling is dependent on memory type.

### 4.5.1 3DS Addressing with **dfi\_cid** and **dfi\_cs** for DDR3

While addressing 3DS devices with two and four logical ranks, the MC can use dedicated **dfi\_cs** inputs to select these logical ranks. For 3DS SDRAMs with eight logical ranks, the MC requires the additional **dfi\_cid** (Chip ID) address input to select logical ranks 4 through 7.

---

**TABLE 45.** DDR3 Configuration with 8 Logical and 1 Physical Rank

| Physical Rank | Logical Rank | dfi <sub>cs</sub> [3:0] | dfi <sub>cid</sub> [0] |
|---------------|--------------|-------------------------|------------------------|
| 0             | 0            | 1110                    | 0                      |
| 0             | 1            | 1101                    | 0                      |
| 0             | 2            | 1011                    | 0                      |
| 0             | 3            | 0111                    | 0                      |
| 0             | 4            | 1110                    | 1                      |
| 0             | 5            | 1101                    | 1                      |
| 0             | 6            | 1011                    | 1                      |
| 0             | 7            | 0111                    | 1                      |

#### 4.5.2 3DS Addressing with *dfi\_cid* and *dfi\_cs* for DDR4

For DDR4, the 3DS package is organized into two, four, or eight logical ranks. For DDR4 3DS devices, the MC can select the logical ranks by using the *dfi\_cid* [2:0] signal bits. The *dfi\_cs* signal selects the physical ranks.

**TABLE 46. DDR4 Configuration with 8 Logical and 2 Physical Ranks**

| Physical Rank | Logical Rank | <i>dfi_cs</i> [1:0] | <i>dfi_cid</i> [2:0] |
|---------------|--------------|---------------------|----------------------|
| 0             | 0            | 10                  | 000                  |
| 0             | 1            | 10                  | 001                  |
| 0             | 2            | 10                  | 010                  |
| 0             | 3            | 10                  | 011                  |
| 0             | 4            | 10                  | 100                  |
| 0             | 5            | 10                  | 101                  |
| 0             | 6            | 10                  | 110                  |
| 0             | 7            | 10                  | 111                  |
| 1             | 0            | 01                  | 000                  |
| 1             | 1            | 01                  | 001                  |
| 1             | 2            | 01                  | 010                  |
| 1             | 3            | 01                  | 011                  |
| 1             | 4            | 01                  | 100                  |
| 1             | 5            | 01                  | 101                  |
| 1             | 6            | 01                  | 110                  |
| 1             | 7            | 01                  | 111                  |

## 4.6 Data Bus Inversion

DBI is an optional DFI feature used with write and read data transmissions to generate write DBI data and invert both write and read data for DBI as required. When DBI is enabled, the *phy\_dbi\_mode* parameter is applicable.

If *phy\_dbi\_mode* = 0, the MC controls the DBI functionality and the *dfi\_rddata\_dbi* signal is required. If *phy\_dbi\_mode* = 1, the PHY performs DBI generation and data inversion. If DBI is required in a system, either the MC or the PHY can generate the DBI output to DRAM and the output must be used to selectively invert data for write commands.

The PHY defines the *phy\_dbi\_mode* parameter value to determine how DBI is handled, as defined in Table 17, “Write Data Interface Programmable Parameters”.

If the MC supports DBI on DFI, the MC must support both settings of the *phy\_dbi\_mode* parameter; the MC must be able to generate DBI and invert the write data and read data as needed for DBI, and interface with a PHY that generates and handles the data inversion for DBI. The PHY can optionally support either setting of the *phy\_dbi\_mode* parameter; the PHY can optionally generate DBI and invert the write data and read data as required. If the PHY does not generate DBI and invert the corresponding write/read data, the PHY must be able to interface to an MC that has DBI support. When both CRC and DBI are enabled in a system, special care needs to be taken regarding where CRC and DBI are performed in order to operate correctly.

When **phy\_dbi\_mode** = 0, the PHY transfers the read DBI data on **dfi\_rddata\_dbi** coincident with **dfi\_rddata**. The MC transfers the write DBI data on **dfi\_wrdata\_mask** coincident with **dfi\_wrdata**.

## 4.7 Write Transactions

The write data transaction handles the transmission of write data across the DFI bus from the MC to the PHY.

The DFI write transaction includes the signals for write data (**dfi\_wrdata**), write data mask or DBI (**dfi\_wrdata\_mask**), write data link CRC (**dfi\_wrdata\_crc**), write data link ECC (**dfi\_wrdata\_ecc**), write data enable (**dfi\_wrdata\_en**), write data chip select (**dfi\_wrdata\_cs**), the associated timing parameters  $t_{phy\_cremax\_lat}$ ,  $t_{phy\_cremin\_lat}$ ,  $t_{phy\_wrcgap}$ ,  $t_{phy\_wrcslat}$ ,  $t_{phy\_wrdata}$ ,  $t_{phy\_wrlat}$  and  $t_{phy\_wrdata}$  and the programmable parameters **phy\_crc\_mode**, **phy\_linkdqcrc\_mode** and **phy\_dbi\_mode**.

The **dfi\_wrdata\_en** signal must correlate with the number of data transfers executed on the DRAM bus; one continuous assertion of the **dfi\_wrdata\_en** signal may encompass data for multiple write commands.

If the chip select is enabled, the **dfi\_wrdata\_cs** signal provides the target data path chip select value to each of the PHY data slices. In a 3DS solution, control and MRW activities are to be limited to physical ranks. For more information on these signals, refer to Section 3.2, “Write Data Interface”.

### 4.7.1 Write Transaction Sequence

The sequence for DFI write transactions is listed below; the effect of using the optional write data chip select, CRC, ECC, or DBI is shown within brackets.

1. The write command is issued.

- a.  $t_{phy\_wrlat}$  cycles elapse ( $t_{phy\_wrlat}$  can be zero). (Change: was step 2, now a)

The  $t_{phy\_wrlat}$  parameter defines the number of cycles between when the write command is driven on the DFI to assertion of the **dfi\_wrdata\_en** signal. The  $t_{phy\_wrlat}$  parameter is PHY-defined but may be specified in terms of other fixed system values.

The write timing parameters ( $t_{phy\_wrdata}$  and  $t_{phy\_wrlat}$ ) must be held constant while commands are being executed on the DFI bus; however, if necessary, the write timing parameter values may be changed when the bus is in the idle state. The  $t_{phy\_wrdata}$  and  $t_{phy\_wrlat}$  timing parameters work together to define the number of cycles from the assertion of a write command on the DFI command interface to when write data is driven on the DFI bus and must be consistent with the write latency timing that correlates to the DRAM timing.

- b.  $t_{phy\_wrcslat}$  cycles elapse.

[If chip select is enabled, the PHY defines the  $t_{phy\_wrcslat}$  timing parameter to specify the desired alignment of the command to the **dfi\_wrdata\_cs** signal; the PHY defines the  $t_{phy\_wrcgap}$  timing parameter to specify the additional delay it requires between two consecutive commands that are targeting different chip selects. The  $t_{phy\_wrcslat}$  timing parameter must be held constant while commands are being executed on the DFI bus; however, if necessary, the  $t_{phy\_wrcslat}$  parameter value may be changed when the bus is in the idle state. The PHY may require the MC to add delay beyond other system timing requirements to account for PHY-specific adjustments transitioning between data path chip selects.]

[The gap timing requirement may only be applicable to certain chip-select-to-chip-select transitions and not be applicable to other data path chip select transitions where the PHY is not required to make an internal

adjustment on the transition; this gap timing requirement is system-specific. For example, a system may not require additional delay on transitions between chip select 0 and chip select 1, but may require additional delay when transitioning from chip select 0 to chip select 2. Accordingly, the interface does not require the gap timing to be applied to every chip select transition.]

2. The MC drives **dfi\_wrdata\_cs** a minimum of the DFI data transfer width (**dfi\_rw\_length**) plus the gap timing (**t<sub>phy\_wresgap</sub>**). The minimum time the chip select is guaranteed to remain driven to the PHY relative to the write command is defined by  $t_{phy\_wreslat} + dfi\_rw\_length + t_{phy\_wresgap}$ .

The maximum delay that can be achieved between the assertion of a new chip select value on **dfi\_wrdata\_cs** and the corresponding **dfi\_wrdata\_en** is limited to the maximum time the PHY has from changing the target chip select to receiving the write data transfer (**t<sub>phy\_wrlat</sub>** - **t<sub>phy\_wreslat</sub>**).

The PHY must define the **t<sub>phy\_wreslat</sub>** and **t<sub>phy\_wresgap</sub>** timing parameters to allocate the time between transactions to different chip selects necessary for PHY-specific adjustments.

3. For non-contiguous write commands, the **dfi\_wrdata\_en** signal is asserted on the DFI after **t<sub>phy\_wrlat</sub>** is met and remains asserted for the number of cycles required to complete the write data transfer sent on the DFI command interface; **t<sub>phy\_wrlat</sub>** can be zero.

[If DRAM CRC is enabled, the MC extends the **dfi\_wrdata\_en** signal to accommodate the extended DRAM burst length and the signal is asserted for an odd number of cycles per burst.]

4. For contiguous write commands, the **dfi\_wrdata\_en** signal is asserted after **t<sub>phy\_wrlat</sub>** is met and remains asserted for the entire length of the data stream; **t<sub>phy\_wrlat</sub>** can be zero. [If DRAM CRC is enabled, the MC extends the **dfi\_wrdata\_en** signal to accommodate the extended DRAM burst length and the signal may be asserted for an odd number of cycles per burst.]
5. **t<sub>phy\_wrdata</sub>** cycles elapse.
6. The associated write data (**dfi\_wrdata**) and masking (**dfi\_wrdata\_mask**) signals are sent.

[If DRAM CRC is enabled, the MC utilizes the **dfi\_wrdata** bus to send CRC data to the PHY]

[If Link CRC is enabled, the **dfi\_wrdata\_crc** signal transfers the CRC data to the PHY.]

[If Link ECC is enabled, the **dfi\_wrdata\_ecc** signal transfers the ECC data to the PHY.]

[If DBI is enabled, **dfi\_wrdata\_mask** transfers the write data inversion information instead of the write data mask.]

The MC must always drive **dfi\_wrdata** and associated signals with the correct timing relative to the write command as defined by the timing parameters **t<sub>phy\_wrdata</sub>** and **t<sub>phy\_wrlat</sub>**.

The **t<sub>phy\_wrdata</sub>** parameter defines the timing requirements between the assertion of the **dfi\_wrdata\_en** signal assumed and when the write data is driven on the **dfi\_wrdata** signal. The exact value of the **t<sub>phy\_wrdata</sub>** parameter for a particular application is determined by how many cycles the PHY must receive the **dfi\_wrdata\_en** signal prior to receiving the **dfi\_wrdata** signal.

If the PHY requires notification of pending write data sooner than 1 cycle, the **t<sub>phy\_wrdata</sub>** parameter may be increased. However, setting **t<sub>phy\_wrdata</sub>** to a value greater than 1 may restrict the minimum write latency supported by the interface. The DFI specification does not dictate a value for the **t<sub>phy\_wrdata</sub>** parameter.

7. The **dfi\_wrdata\_en** signal de-asserts  $t_{phy\_wrdata}$  cycles before the last valid data is transferred on the **dfi\_wrdata** bus.
8.  $t_{phy\_wrdata\_delay}$  cycles elapse. The DFI bus enters the idle state.

The idle state timing parameter defines the number of DFI clocks from **dfi\_wrdata\_en** to the completion of the write data transfer on the DRAM bus. The MC drives the next value (any valid chip select or inactive).

Seven situations showing system behavior with two write transactions are presented in Figure 10, Figure 11, Figure 12, Figure 13, Figure 14, Figure 15 and Figure 16. System behavior with three write transactions using **dfi\_wrdata\_cs** is shown in Figure 17.

Figure 10, “Back-to-Back Writes (DRAM Burst of 4:  $t_{phy\_wrlat} = 0$ ,  $t_{phy\_wrdata} = 1$ )” shows back-to-back writes for a system with a  $t_{phy\_wrlat}$  of zero and a  $t_{phy\_wrdata}$  of one. The **dfi\_wrdata\_en** signal is asserted with the write command for this situation, and is asserted for two cycles per command to inform the DFI that two cycles of DFI data are sent for each write command. The timing parameters and the timing of the write commands allow the **dfi\_wrdata\_en** signal and the **dfi\_wrdata** stream to be sent contiguously.

---

**FIGURE 10.** Back-to-Back Writes (DRAM Burst of 4:  $t_{phy\_wrlat} = 0$ ,  $t_{phy\_wrdata} = 1$ )



Figure 11, “Back-to-Back Interrupted Contiguous Writes (DRAM Burst of 8:  $t_{phy\_wrlat} = 3$ ,  $t_{phy\_wrdata} = 2$ )” shows an interrupted write command. The **dfi\_wrdata\_en** signal should be asserted for 4 cycles for each of these write transactions. However, since the first write is interrupted, the **dfi\_wrdata\_en** signal is asserted for a portion of the first transaction and

---

## Functional Use

---

the complete second transaction. The **dfi\_wrdata\_en** signal will not de-assert between write commands, and the **dfi\_wrdata** stream will be sent contiguously for a portion of the first command and the complete second command.

---

**FIGURE 11. Back-to-Back Interrupted Contiguous Writes (DRAM Burst of 8:  $t_{phy\_wrlat} = 3$ ,  $t_{phy\_wrdata} = 2$ )**



Figure 12, “Back-to-Back Writes (DRAM Burst of 8:  $t_{phy\_wrlat} = 4$ ,  $t_{phy\_wrdata} = 4$ )” shows back-to-back burst-of-8 writes. The **dfi\_wrdata\_en** signal must be asserted for 4 cycles for each of these write transactions.

---

**FIGURE 12. Back-to-Back Writes (DRAM Burst of 8:  $t_{phy\_wrlat} = 4$ ,  $t_{phy\_wrdata} = 4$ )**



Figure 13, Figure 14, Figure 15 and Figure 16 also show two complete write commands, with different  $t_{phy\_wrlat}$  and  $t_{phy\_wrdata}$  timing parameters and for different DRAM types. The **dfi\_wrdata\_en** signal is asserted for two cycles for

---

## Functional Use

---

each write transaction. The  $t_{phy\_wrlat}$  timing and the timing between the write commands causes the **dfi\_wrdata\_en** signal to be de-asserted between commands. As a result, the **dfi\_wrdata** stream is non-contiguous.

**FIGURE 13.** Two Independent Writes (DRAM Burst of 4:  $t_{phy\_wrlat} = 0$ ,  $t_{phy\_wrdata} = 1$ )



**FIGURE 14.** Two Independent Writes (DRAM Burst of 4:  $t_{phy\_wrlat} = 3$ ,  $t_{phy\_wrdata} = 1$ )



**FIGURE 15.** Two Independent Writes (DRAM Burst of 8:  $t_{phy\_wrlat} = 3$ ,  $t_{phy\_wrdata} = 3$ )



**FIGURE 16.** Two Independent Writes (DRAM Burst of 4:  $t_{phy\_wrlat} = 3$ ,  $t_{phy\_wrdata} = 4$ )



Figure 17, “Write Commands Utilizing dfi\_wrdata\_cs (DRAM Burst of 4: tphy\_wrlat = 3, tphy\_wrdat = 4, tphy\_wrcslat = 2, tphy\_wrcsgap = 1)” shows three write commands, with a gap between the second and third commands. The first two commands (WR A and WR B) address CS0 while the third one (WR C) addresses CS1. The two first write commands are

back to back, that is, spaced by  $\text{dfi}_{\text{rw}}_{\text{length}}$ . The third command is also back to back, but with the required extra spacing,  $t_{\text{phy}}_{\text{wrcgap}}$ .

**FIGURE 17.** Write Commands Utilizing  $\text{dfi}_{\text{wrdata}}_{\text{cs}}$  (DRAM Burst of 4:  $t_{\text{phy}}_{\text{wrlat}} = 3$ ,  $t_{\text{phy}}_{\text{wrdat}} = 4$ ,  $t_{\text{phy}}_{\text{wrcslat}} = 2$ ,  $t_{\text{phy}}_{\text{wrcgap}} = 1$ )



DFI timing parameters for read and write commands will be referenced from the second tick of the second command in the same manner that JEDEC LPDDR4 references RL and WL.

**FIGURE 18.** LPDDR4 Write Command



#### 4.7.2 DBI - Write

DBI is an optional DFI feature used with write data transmissions. The **phy\_dbm\_mode** parameter is only needed when DBI is supported in DFI.

For more information on the **phy\_dbm\_mode** parameter, refer to Table 16, “Write Data Interface Timing Parameters”.

When the MC generates the write DBI data, the MC also inverts write data for DBI as required. The MC transmits the write DBI data across the DFI bus on **dfi\_wrdata\_mask**. In DBI mode, the PHY is only required to transfer the write DBI data through the PHY. While write data is transmitting, the DBI data transmits simultaneously on the **dfi\_wrdata\_mask** signal. The **dfi\_wrdata\_mask** signal is sent coincident with the corresponding **dfi\_wrdata** bus.

For frequency ratio systems, the **dfi\_wrdata\_mask** signal is extended, with a signal defined per phase.

When both DBI and CRC are enabled in a system, special care needs to be taken regarding where DBI and CRC are performed in order to operate correctly. DBI inversion should take effect prior to CRC encoding.

#### 4.7.3 Link ECC - Write

Link ECC is an optional DFI feature used with write data transmissions. The **phy<sub>linkecc\_mode</sub>** parameter is needed when Link ECC is supported in DFI. If the MC is handling link ECC operations, the MC will transmit the write ECC across the DFI bus on the **dfi\_wrdata\_ecc** signal. In Link ECC mode, the PHY is only required to transfer the write Link ECC through the PHY.

For more information on the **phy<sub>linkecc\_mode</sub>** parameter, refer to Section 3.13, “Link ECC”.

---

**FIGURE 19.** *Link ECC with Write Commands*



#### 4.7.4 Write Data Interleaving

DFI supports non-contiguous write data transfers and write data interleaving when supported by the target memory device. For contiguous and non-contiguous writes, the **t<sub>phy\_wrlat</sub>** timing parameter defines the timing from the command to the first rising edge of the **dfi\_wrdata\_en** signal and the **t<sub>phy\_wrdata</sub>** timing parameter defines the timing from the **dfi\_wrdata\_en** signal assertion to the data being driven on the **dfi\_wrdata** signal. The assertions and de-assertions of the **dfi\_wrdata\_en** signal must match the DRAM timing as before. Write data interleaving is permitted as defined by the DRAM and the timing also follows the DRAM timing.

**FIGURE 20.** Non-Interleaved Write Commands (LPDDR5 Example)

**FIGURE 21.** Interleaved Write Commands (LPDDR5 Example)


#### 4.7.5 Cyclic Redundancy Check - Write

##### 4.7.5.1 DRAM CRC

DRAM CRC is an optional DFI feature used with write data transmissions to send CRC data as part of the write data burst. CRC extends a burst of 8 unit intervals (UI) to 10 UIs. When DRAM CRC is used, either the MC or the PHY can generate the CRC data; however, the MC must generate the CRC data if the PHY does not generate it. The CRC data is

made of the CRC code that is expanded by the needed padding values to reach a full DFI data clock cycle data transfer (An example is padding with 1's for DDR4 x8 and x16 devices.)

While either the MC or the PHY can generate the DRAM CRC data, the PHY defines the value of the **phy<sub>crc</sub>\_mode** programmable parameter. The **phy<sub>crc</sub>\_mode** parameter is only needed when CRC is supported in DFI and uses the following definition to determine how CRC is handled:

- **phy<sub>crc</sub>\_mode == 0** → CRC generation is handled in the MC
- **phy<sub>crc</sub>\_mode == 1** → CRC generation is handled in the PHY

When DRAM CRC is supported in DFI, the system must be capable of the conditions listed in Table 47, “Systems Requiring CRC Support”.

---

**TABLE 47. Systems Requiring CRC Support**

| Description              | MC  | PHY              |
|--------------------------|-----|------------------|
| Generates CRC Data       | Yes | Optional         |
| Interfaces with CRC Data | Yes | Yes <sup>a</sup> |

a. Required if the PHY does not generate the CRC data.

Regardless of which device generates the CRC, the MC asserts ODT such that it applies to all data sent + CRC data words.

#### 4.7.5.1.1 MC CRC Support (**phy<sub>crc</sub>\_mode = 0**)

When the MC generates the CRC data, the **phy<sub>crc</sub>\_mode == 0** and the MC has the following requirements.

- The MC must assert the **dfi\_wrdata\_en** signal for the data transmitted across the DFI bus, including CRC data.
- The MC spaces commands to handle an extended burst with CRC.
- The MC generates **dfi\_odt** (**dfi\_odt\_pN** in frequency ratio systems) based on the DRAM burst length including CRC data. With CRC enabled, the MC may need to extend ODT.
- The MC needs to receive and capture error information from the PHY. These CRC write data errors are transmitted on the **dfi\_alert\_n** signal. In systems that support either command parity or CRC, the MC must support a **dfi\_alert\_n** input and the PHY must support the **dfi\_alert\_n** output.

With CRC, the **dfi\_wrdata\_en** signal could be asserted for an odd number of cycles per burst. Without exception, the PHY must support the odd CRC burst timing.

DFI dictates that when CRC is used, the CRC data word must be incorporated in the burst of write data, but DFI does not dictate placement within the burst. The specific ODT timing requirements are dependent on the chip selects accessed and system architecture. The **dfi\_odt** assertion and de-assertion are identical in the MC CRC and PHY CRC support modes. The ODT signal timing shown is only an example of one potential solution.

To further compare MC CRC support mode and PHY CRC support mode, DFI ODT signals are included in the following figures:

- Figure 18, “LPDDR4 Write Command”
- Figure 22, “DFI Write Data Bus for MC CRC Support Mode (Two Bursts starting in Phase 0)”

## Functional Use

- Figure 23, “DFI Write Data Bus for MC CRC Support Mode (Two Back-to-Back Bursts)”
- Figure 24, “DFI Write Data Bus for PHY CRC Support Mode”

Figure 22 and Figure 23 illustrate the DFI write data bus for a 1:2 frequency ratio system with CRC extending a burst of 8 by 1 additional clock DRAM cycle.

**FIGURE 22. DFI Write Data Bus for MC CRC Support Mode (Two Bursts starting in Phase 0)**



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**FIGURE 23.** DFI Write Data Bus for MC CRC Support Mode (Two Back-to-Back Bursts)



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.  
1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

#### 4.7.5.1.2 PHY CRC Support ( $phy_{crc\_mode} = 1$ )

If a PHY is capable of generating CRC data, the  $phy_{crc\_mode} == 1$  and the MC has the following requirements.

- The MC must disable its CRC generation logic so that CRC data is not transmitted across the DFI bus for write commands.
- The MC must assert the **dfi\_wrdata\_en** signal only for the data transmitted across the DFI bus, NOT for CRC.
- The MC spaces commands to handle an extended burst with CRC.
- The MC generates **dfi\_odt** (**dfi\_odt\_pN** in frequency ratio systems) based on the DRAM burst length including CRC data. With CRC enabled, the MC may need to extend ODT.
- The MC needs to receive and capture error information from the PHY. These CRC write data errors are transmitted on the **dfi\_alert\_n** signal. In systems that support command parity or CRC, the MC must support a **dfi\_alert\_n** input and the PHY must support a **dfi\_alert\_n** output.

#### 4.7.5.1.3 Burst Chop 4 with PHY CRC Support

In Burst Chop 4 (BC4) mode, the memory burst is extended for CRC, similar to a burst of 8 requiring a 10 UI transfer. When the PHY generates the CRC data, the controller does not adjust **dfi\_wrdata\_en\_pN** to account for the transfer of CRC data words. In a system supporting dynamic burst lengths and BC4, the PHY can use the width of the **dfi\_wrdata\_en\_pN** signal to determine whether a transfer is a burst of 8 or whether the transfer is a BC4 data transmission. The PHY can utilize this information to determine how to generate CRC and when to send the CRC data.

Figure 24 and Figure 25 show PHY outputs that include a single extra CRC data word, shown at the end of the burst (the location of the CRC data word is DRAM-dependent). The figures also show that **dfi\_odt** assertion and de-assertion for PHY CRC support are identical to the MC CRC Support mode in which the **dfi\_odt** signals are extended to cover both CRC and write data. The specific ODT timing requirements are dependent on the chip selects accessed and the system topology. The ODT signal timing shown is only an example of one potential solution.

Figure 24, “DFI Write Data Bus for PHY CRC Support Mode” illustrates a write BC4 case. This example shows a BC4 write followed by a burst of 8 write. With BC4, the MC only transmits 2 data words across the DFI bus. For both BC4 and burst of 8 commands, the CRC data is transmitted at the end of the burst, in UI9 and UI10.

**FIGURE 24. DFI Write Data Bus for PHY CRC Support Mode**



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**FIGURE 25.** DFI Write Data Bus for PHY CRC Support Mode with Burst Chop


This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.  
 1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

#### 4.7.5.2 Write Link CRC

Write Link CRC is an optional DFI feature used with write data transmissions. The **phylinkdqrcemode** parameter must be 1 when Link CRC is supported in DFI. If write link CRC is enabled, the MC will transmit the write CRC across the DFI bus on the **dfi\_wrdata\_crc** signal. The PHY is only required to transfer the write link CRC through the PHY.

For more information on the **phylinkdqrcemode** parameter, refer to Table 3.14, “Link DQ CRC”.

**FIGURE 26.** Link CRC with Write Commands

#### 4.7.6 CA Bus Timing

For memories with a CA bus including LPDDR2, LPDDR3, LPDDR4, LPDDR5, and DDR5, the timing parameters referencing the command are referenced to the corresponding clock on the DFI bus as defined by JEDEC as the timing reference point for the command to the memory clock on the memory bus at the output of the PHY. The following table summarizes the timing reference points for these memories and the corresponding DFI point of reference. The same rule applies to all memories including those not listed in Table 48, “CA Bus Timing Summary”.

**TABLE 48.** CA Bus Timing Summary

| DRAM Type             | CA Command Definition                                                                                                                      | Memory Command Timing Reference                                                 | DFI Command Timing Reference                          |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------|
| LPDDR2 / LPDDR3       | 1 clock DDR command <sup>a</sup>                                                                                                           | Rising edge of the memory clock of the command                                  | Rising edge of the DFI clock of the command           |
| LPDDR4                | 4 clock SDR command:<br>{CMD-1, CMD-1, CAS-2, CAS-2} where CMD is RD or WR                                                                 | Rising edge of the memory clock of the 2nd CAS-2 command when CS is de-asserted | Rising edge of the DFI clock of the 2nd CAS-2 command |
| LPDDR5                | 1 clock DDR command:<br>{CMD_r, CMD_f} where CMD is RD or WR<br><br>Note: _r, _f refer to the rising and falling edges of the memory clock | Rising edge of the memory command clock of the command                          | Rising edge of the DFI clock of the command           |
| DDR5 without RCD - 1N | 2 clock SDR command:<br>{CMD1_L, CMD2_H} where CMD is RD or WR<br><br>Note: _L, _H refer to CS_n                                           | Rising edge of the 1st memory clock of the CMD2 command                         | 2nd rising edge of the DFI clock of the command       |
| DDR5 without RCD - 2N | 4 clock SDR command:<br>{CMD1_L, CMD1_H, CMD2_H, CMD2_H} where CMD is RD or WR<br><br>Note: _L, _H refer to CS_n                           | Rising edge of the 1st memory clock of the CMD2 command                         | Rising edge of the DFI clock of the 2nd command       |

**TABLE 48. CA Bus Timing Summary**

| DRAM Type                        | CA Command Definition                                                                                                                                                                                                                                                                                                                                                                            | Memory Command Timing Reference                         | DFI Command Timing Reference                    |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------|
| DDR5 with RCD - 1N               | 2 clock DDR command:<br>$\{\text{CMD1}_r\text{ L}, \text{CMD1}_f\text{ L}, \text{CMD2}_r\text{ H}, \text{CMD2}_f\text{ H}\}$ where CMD is RD or WR<br>Note: $_L$ , $_H$ refer to CS_n<br>Note: $_r$ , $_f$ refer to the rising and falling edges of the RCD clock                                                                                                                                | Rising edge of the 1st memory clock of the CMD2 command | 2nd rising edge of the DFI clock of the command |
| DDR5 with RCD - 2N               | 4 clock SDR command:<br>$\{\text{CMD1}_l\text{ L}, \text{CMD1}_u\text{ H}, \text{CMD2}_l\text{ H}, \text{CMD2}_u\text{ H}\}$ where CMD is RD or WR<br>Note: $_L$ , $_H$ refer to CS_n<br>Note: $_l$ , $_u$ refer to the lower and upper 7 bits of the DRAM command                                                                                                                               | Rising edge of the 1st memory clock of the CMD2 command | Rising edge of the DFI clock of the 2nd command |
| DDR5 MRDIMM Mux Mode - 1N and 2N | 2 clock DDR command with a 1 cycle gap in between:<br>$\{\{\text{CMD1}_r\text{ L}, \text{CMD1}_f\text{ L}\}, \{\text{GAP}\}, \{\text{CMD2}_r\text{ H}, \text{CMD2}_f\text{ H}\}\}$ where CMD is RD or WR<br>Note: $_L$ , $_H$ refer to CS_n<br>Note: $_r$ , $_f$ refer to the rising and falling edges of the MRCD clock<br>Note: The $\{\text{GAP}\}$ may be filled by the other pseudo-channel | Rising edge of the 1st memory clock of the CMD2 command | Rising edge of the DFI clock of the 2nd command |

- a. For DDR commands, the rising and falling edge memory command is concatenated and sent in a single clock or phase on the interface.

The following diagrams illustrate the timing reference relative to the command. For all timing diagrams, the command from which the timing parameter is referenced is highlighted. In the timing diagrams, the timing parameters are referenced from the rising edge of the clock when the command is sampled.

#### 4.7.6.1 LPDDR2 / LPDDR3 Memories

For LPDDR2 and LPDDR3 memories, the command is a single clock DDR command.

**FIGURE 27.** LPDDR2 / LPDDR3 Read Timing with a 1:1 Command and 1:1 Data Frequency Ratio

#### 4.7.6.2 LPDDR4 Memories

For Figure 28, “LPDDR4 Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {CMD-1, CMD-1, CAS-2, CAS-2}.

**FIGURE 28.** LPDDR4 Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio

#### 4.7.6.3 LPDDR5 Memories

In previous versions of this DFI spec, a single frequency ratio signal which essentially defined the data frequency ratio and the command ratio was fixed at 1:1. For backwards compatibility, a DFI 5.2 supporting MC or host interface could still use this relationship. In such a case, the DFI 5.2 equivalent would be to drive **dfi\_cmd\_freq\_ratio** = 'b00 and **dfi\_data\_freq\_ratio** = **dfi\_freq\_ratio** from the older specification. This is shown in Figure 29, “LPDDR5 Read Timing With a 1:1 Command and 1:2 Data Frequency Ratio”, Figure 30, “LPDDR5 Read Timing With a 1:1 Command and 1:4 Data Frequency Ratio”, Figure 32, “LPDDR5 Write Timing With a 1:1 Command and 1:2 Data Frequency Ratio” and Figure 33, “LPDDR5 Write Timing With a 1:1 Command and 1:4 Data Frequency Ratio”.

Figure 31, “LPDDR5 Read Timing With a 1:2 Command and 1:4 Data Frequency Ratio” and Figure 34, “LPDDR5 Write Timing With a 1:2 Command and 1:4 Data Frequency Ratio” are figures that are only valid starting with DFI 5.2 which supports a command frequency ratio other than 1:1.

---

## Functional Use

---

**FIGURE 29.** LPDDR5 Read Timing With a 1:1 Command and 1:2 Data Frequency Ratio



**FIGURE 30.** LPDDR5 Read Timing With a 1:1 Command and 1:4 Data Frequency Ratio



**FIGURE 31.** LPDDR5 Read Timing With a 1:2 Command and 1:4 Data Frequency Ratio


RD includes both the rising and falling edge read command for the DDR read command.

**FIGURE 32.** LPDDR5 Write Timing With a 1:1 Command and 1:2 Data Frequency Ratio


**FIGURE 33.** LPDDR5 Write Timing With a 1:1 Command and 1:4 Data Frequency Ratio**FIGURE 34.** LPDDR5 Write Timing With a 1:2 Command and 1:4 Data Frequency Ratio

#### 4.7.6.4 DDR5 Memories Without RCD

For Figure 35, “DDR5 without RCD 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {RD1\_L, RD2\_H}. RD1 is driven on the first phase and RD2 is driven on the second phase. The CS\_n is driven LOW on the first phase.

**FIGURE 35.** DDR5 without RCD 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 36, “DDR5 without RCD 2N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {RD1\_L, RD1\_H, RD2\_H, RD2\_H}. RD1 is driven on the first two phases and RD2 is driven on the second two phases. The CS\_n is driven LOW on the first phase.

**FIGURE 36.** DDR5 without RCD 2N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 37, “DDR5 without RCD 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio”, the command sequence is {RD1\_L, RD2\_H}. RD1 is driven on the first phase and RD2 is driven on the second phase. The CS\_n is driven LOW on the first phase.

**FIGURE 37.** DDR5 without RCD 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio



For Figure 38, “DDR5 1N without RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {WR1\_L, WR2\_H}. WR1 is driven on the first phase and WR2 is driven on the second phase. The CS\_n is driven LOW on the first phase.

**FIGURE 38.** DDR5 1N without RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 39, “DDR5 without RCD 2N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {WR1\_L, WR1\_H, WR2\_H, WR2\_H}. WR1 is driven on the first two phases and WR2 is driven on the second two phases. The CS\_n is driven LOW on the first phase.

**FIGURE 39.** DDR5 without RCD 2N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 40, “DDR5 without RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {WR1\_L, WR2\_H}. WR1 is driven on the first phase and WR2 is driven on the second phase. The CS\_n is driven LOW on the first phase.

**FIGURE 40.** DDR5 without RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 41, “DDR5 without RCD 2N Write Timing with a 1:4 Command and 1:4 Data Frequency Ratio”, the command sequence is {WR1\_L, WR1\_H, WR2\_H, WR2\_H}. WR1 is driven on the first two phases and WR2 is driven on the second two phases. The CS\_n is driven LOW on the first phase.

**FIGURE 41.** DDR5 without RCD 2N Write Timing with a 1:4 Command and 1:4 Data Frequency Ratio



#### 4.7.6.5 DDR5 Memories With RCD

For Figure 42, “DDR5 with RCD 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {RD1\_r\_L / RD1\_f\_L, RD2\_r\_H / RD2\_f\_H}. Each phase includes both the rising and falling edge read command for the DDR read command. The CS\_n is driven LOW on the first phase.

**FIGURE 42.** DDR5 with RCD 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio



---

## Functional Use

---

For Figure 43, “DDR5 with RCD 2N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {RD1\_L\_L, RD1\_u\_H, RD2\_L\_H, RD2\_u\_H}. {RD1\_L, RD1\_u, RD2\_L, RD2\_u} is driven sequentially across the four phases. The CS\_n is driven LOW on the first phase. The MC must duplicate the contents of the **dfi\_address** [6:0] signal on the **dfi\_address** [13:7] signal (if present).

**FIGURE 43.** DDR5 with RCD 2N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 44, “DDR5 with RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {WR1\_r\_L/WR1\_f\_L, WR2\_r\_H/WR2\_f\_H}. Each phase includes both the rising and falling edge write command for the DDR write command. The CS\_n is driven LOW on the first phase.

**FIGURE 44.** DDR5 with RCD 1N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio



For Figure 45, “DDR5 with RCD 2N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio”, the command sequence is {WR1\_L\_L, WR1\_u\_H, WR2\_L\_H, WR2\_u\_H}. {WR1\_L, WR1\_u, WR2\_L, WR2\_u} is driven sequentially across the four phases. The CS\_n is driven LOW on the first phase. The MC must duplicate the contents of the **dfi\_address** [6:0] signal on the **dfi\_address** [13:7] signal (if present).

**FIGURE 45.** DDR5 with RCD 2N Write Timing with a 1:2 Command and 1:2 Data Frequency Ratio

#### 4.7.6.6 DDR5 MRDIMM Memories

For DDR5 MRDIMM Mux Mode, the timing parameter command reference point follows the same rules as DDR5 with RCD. However, because the command interface is interleaved on a per-cycle basis, commands that occupy 2 consecutive cycles for DDR5 with RCD (e.g. RD or WR) will have 1 command phase injected between them, which will effectively move the reference point.

Since the Command and Data interfaces use different interleaving, DFI timing parameters referenced to both Command and Data interfaces (such as  $t_{phy\_wrlat}$ ,  $t_{rddata\_en}$ ,  $t_{phy\_wreslat}$ ,  $t_{phy\_rdcslat}$ ) must be treated differently for PS0 versus PS1 and in 1N vs 2N mode. The PS1 version will be 1 Command phase less than the PS0 version. In 1N mode, the Data and Command frequency ratios are the same. However, in 2N mode, there will be 2 Data phases for 1 Command phase, so timing parameters and reference points must be scaled into Data phase units.

For Figure 46, “DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio”, the command sequence for a single pseudo-channel is {RD1\_r\_L / RD1\_f\_L, GAP, RD2\_r\_H / RD2\_f\_H}. When the DFI Data and Command ratios are equal, the effective  $t_{rddata\_en}$  timing for Pseudo-Channel 1 is the nominal  $t_{rddata\_en}$  (used for PS0) minus 1. Each phase includes both the rising and falling edge read command for the DDR read command. The CS\_n is driven LOW on the first phase.

**FIGURE 46.** DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio


|                                                             |                  |
|-------------------------------------------------------------|------------------|
| Pseudo-Channel 0                                            | Pseudo-Channel 1 |
| PS1 t <sub>rddata_en</sub> = PS0 t <sub>rddata_en</sub> - 1 |                  |
| PS0 t <sub>rddata_en</sub> is DFI t <sub>rddata_en</sub>    |                  |

For Figure 47, “DDR5 MRDIMM Mux Mode 1N Write Timing with a 1:4 Command and 1:4 Data Frequency Ratio”, the command sequence for a single pseudo-channel is {WR1\_r\_L / WR1\_f\_L, GAP, WR2\_r\_H / WR2\_f\_H}. When the DFI Data and Command ratios are equal, the effective  $t_{phy\_wrlat}$  timing for Pseudo-Channel 1 is the nominal  $t_{phy\_wrlat}$  (used for PS0) minus 1. Each phase includes both the rising and falling edge write command for the DDR write command. The CS\_n is driven LOW on the first phase.

**FIGURE 47.** DDR5 MRDIMM Mux Mode 1N Write Timing with a 1:4 Command and 1:4 Data Frequency Ratio


For Figure 48, “DDR5 MRDIMM Mux Mode 2N Read Timing with a 1:2 Command and 1:4 Data Frequency Ratio”, the command sequence for a single pseudo-channel is {RD1\_r\_L / RD1\_f\_L, GAP, RD2\_r\_H / RD2\_f\_H}. When the DFI Data ratio is twice the Command ratio, the effective  $t_{\text{rddata\_en}}$  timing for Pseudo-Channel 1 is the nominal  $t_{\text{rddata\_en}}$  (used for PS0) minus 2. Each phase includes both the rising and falling edge read command for the DDR read command. The CS\_n is driven LOW on the first phase.

**FIGURE 48.** DDR5 MRDIMM Mux Mode 2N Read Timing with a 1:2 Command and 1:4 Data Frequency Ratio


For Figure 49, “DDR5 MRDIMM Mux Mode 2N Write Timing with a 1:2 Command and 1:4 Data Frequency Ratio”, the command sequence for a single pseudo-channel is {WR1\_r\_L / WR1\_f\_L, GAP, WR2\_r\_H / WR2\_f\_H}. When the DFI Data ratio is twice the Command ratio, the effective  $t_{phy\_wrlat}$  timing for Pseudo-Channel 1 is the nominal  $t_{phy\_wrlat}$  (used for PS0) minus 2. Each phase includes both the rising and falling edge write command for the DDR write command. The CS\_n is driven LOW on the first phase.

**FIGURE 49.** DDR5 MRDIMM Mux Mode 2N Write Timing with a 1:2 Command and 1:4 Data Frequency Ratio


## 4.8 Read Transactions

The read data transaction handles the capture and return of data across the DFI bus.

The DFI read transaction includes the signals for read data enable (**dfi\_rddata\_en**), read data (**dfi\_rddata**), the read data valid (**dfi\_rddata\_valid**), read data not valid (**dfi\_rddata\_dnv**), read data inversion or link ECC (**dfi\_rddata\_dbi**), read data link CRC (**dfi\_rddata\_crc**), an optional target data chip select (**dfi\_rddata\_cs**) and the timing parameters  $t_{\text{rddata\_en}}$  and  $t_{\text{phy\_rdlat}}$ .

The number of clocks of **dfi\_rddata\_en** assertion must correlate with the number of data transfers executed on the DRAM bus.

If used, the **dfi\_rddata\_cs** signal provides the target data path chip select value to each of the PHY data slices. For more information on these signals, refer to Section 3.3, “Read Data Interface”.

DFI read data must be returned from the PHY within a maximum delay defined by the sum of the  $t_{\text{rddata\_en}}$  and  $t_{\text{phy\_rdlat}}$  timing parameters. The  $t_{\text{rddata\_en}}$  is a fixed delay, but the  $t_{\text{phy\_rdlat}}$  is defined as a maximum value. The delay can be adjusted as long as both the MC and the PHY coordinate the change such that the DFI specification is maintained. Both parameters may be expressed as equations based on other fixed system parameters.

#### 4.8.1 Read Transaction Sequence

The sequence for DFI read transactions is listed below; the effect of using the optional read data chip select, ECC, CRC, or DBI is shown within brackets.

1. The read command is issued.
2.  $t_{rddata\_en}$  cycles elapse.

[If using read data chip select,  $t_{phy\_rdeslat}$  cycles elapse.]

[The PHY defines the  $t_{phy\_rdeslat}$  timing parameter to specify the desired alignment of the command to the **dfi\_rddata\_cs** signal; the PHY defines the  $t_{phy\_rdesgap}$  timing parameter to specify the additional delay it requires between two consecutive commands that are targeting different chip selects. The PHY may require the MC to add additional delay beyond other system timing requirements to account for PHY-specific adjustments transitioning between chip selects.]

[The gap timing requirement is system-specific and may only be applicable to certain chip-select-to-chip-select. It may not be applicable to other chip select transitions where the PHY is not required to make an internal adjustment on the chip select change. For example, a system may not require additional delay on transitions between chip select 0 and chip select 1, but may require additional delay when transitioning from chip select 0 to chip select 2. Accordingly, the interface does not require the gap timing to be applied on every chip select transition.]

3. The  $t_{rddata\_en}$  parameter defines the timing requirements between the read command on the DFI interface and the assertion of the **dfi\_rddata\_en** signal to maintain synchronization between the MC and the PHY for the start of contiguous read data expected on the DFI interface. The exact value of this parameter for a particular application is determined by memory system components. For non-contiguous read commands,  $t_{rddata\_en}$  cycles elapse, and the **dfi\_rddata\_en** signal is asserted on the DFI and remains valid for the number of cycles that read data is expected.
4. For contiguous read commands,  $t_{rddata\_en}$  cycles after the first read command of the stream, the **dfi\_rddata\_en** signal is asserted and remains asserted for the entire length of the data stream.

[If DRAM CRC is enabled, the MC extends the **dfi\_rddata\_en** signal to accommodate the extended DRAM burst length and the signal may be asserted for an odd number of cycles per burst.]

5. One continuous assertion of the **dfi\_rddata\_en** signal may encompass data for multiple read commands. The **dfi\_rddata\_en** signal de-asserts to signify there is no more contiguous data expected from the DFI read command(s).

The minimum time that the MC will continue to drive the **dfi\_rddata\_cs** signal to the PHY relative to the read command is defined by  $t_{phy\_rdeslat} + dfi_{rw\_length} + t_{phy\_rdesgap}$ . The additional time needed by the PHY between read commands to different chip selects to make internal adjustments due to changing the target chip select is defined by the  $t_{phy\_rdesgap}$  timing parameter. The PHY must define the  $t_{phy\_rdeslat}$  and  $t_{phy\_rdesgap}$  timing parameters to allocate the time between transactions to different chip selects necessary for internal adjustments.

6. The data is returned with the **dfi\_rddata\_valid** signal asserted.
7. The associated read data signal (**dfi\_rddata**) is sent.

[If DRAM CRC is enabled, the PHY utilizes the **dfi\_rddata** bus to send CRC data to the MC.]

[If DBI is enabled, the read data DBI signal (**dfi\_rddata\_dbi**) is sent coincident with the read data signal.]

[If Link ECC is enabled, the **dfi\_rddata\_dbi** signal transfers the ECC data instead of the DFI.]

---

## Functional Use

---

[If Link CRC is enabled, the **dfi\_rddata\_crc** signal transfers the CRC data coincident with the read data signal.]

Ten situations are presented in Figure 50, Figure 51, Figure 52, Figure 53, Figure 54, Figure 55, Figure 56, Figure 57, Figure 58, Figure 59 and Figure 60.

Figure 50, “Single Read Transaction of 2 Data Words” shows a single read transaction. In this case, the **dfi\_rddata\_en** signal is asserted for two cycles to inform the DFI that two cycles of DFI data are expected and data is returned  $t_{phy\_rdlat}$  cycles after the **dfi\_rddata\_en** signal assertion.

---

**FIGURE 50.** Single Read Transaction of 2 Data Words



Figure 51, “Single Read Transaction of 4 Data Words” shows a single read transaction where the data is returned in less than the maximum delay. The data returns one cycle less than the maximum PHY read latency.

---

**FIGURE 51.** Single Read Transaction of 4 Data Words



Figure 52, “Back-to-Back Read Transactions with First Read Burst Interrupted (DDR1 Example BL = 8)” shows an interrupted read command. The **dfi\_rddata\_en** signal must be asserted for 4 cycles for each of these read transactions.

However, since the first read is interrupted, the **dfi\_rddata\_en** signal is asserted for a portion of the first transaction and the complete second transaction. In this case, the **dfi\_rddata\_en** signal will not de-assert between read commands.

---

**FIGURE 52. Back-to-Back Read Transactions with First Read Burst Interrupted (DDR1 Example BL = 8)**



Note: The **tphy\_rdlat** value shown is the actual value, not the maximum value.

Figure 53, “Two Independent Read Transactions (DDR1 Example)” and Figure 54, “Two Independent Read Transactions (DDR2 Example)” also show two complete read transactions. The **dfi\_rddata\_en** signal is asserted for two cycles for each read transaction. In Figure 53, “Two Independent Read Transactions (DDR1 Example)”, the values for the timing parameters are such that the read data is returned in a contiguous data stream for both transactions. Therefore, the **dfi\_rddata\_en** signal and the **dfi\_rddata\_valid** signal are each asserted for the complete read data stream.

---

**FIGURE 53. Two Independent Read Transactions (DDR1 Example)**



Note: The **tphy\_rdlat** value shown is the actual value, not the maximum value.

---

## Functional Use

---

In Figure 54, “Two Independent Read Transactions (DDR2 Example)”, the **t<sub>rddata\_en</sub>** timing and the timing between the read commands causes the **dfi\_rddata\_en** signal to be de-asserted between commands. As a result, the **dfi\_rddata\_valid** signal is de-asserted between commands and the **dfi\_rddata** stream is non-contiguous.

---

**FIGURE 54. Two Independent Read Transactions (DDR2 Example)**



**Note:** The **t<sub>phy\_rdlat</sub>** value shown is the actual value, not the maximum value.

In Figure 55, “Two Independent Read Transactions (DDR2 Example)”, the effective **t<sub>phy\_rdlat</sub>** for the two transactions is different. This results in a situation in which the **dfi\_rddata\_valid** signal remains asserted across commands and the **dfi\_rddata** stream is contiguous.

---

**FIGURE 55. Two Independent Read Transactions (DDR2 Example)**



**Note:** The **t<sub>phy\_rdlat</sub>** value shown is the actual value, not the maximum value.

---

## Functional Use

---

The data may return to the DFI in fewer cycles than maximum delay. In Figure 56, “Two Independent Read Transactions (DDR3 Example)”, the first read data transfer is returned in three cycles, even though the  $t_{phy\_rddata}$  timing parameter is set to four cycles. The second read data transfer is returned in the maximum of four cycles.

---

**FIGURE 56.** Two Independent Read Transactions (DDR3 Example)



**Note:** The  $t_{phy\_rddata}$  value shown is the actual value, not the maximum value.

Some DRAMs define a transaction type of mode register read (MRR). From the DFI perspective, a mode register read is handled like any other read command and utilizes the same signals. Figure 57, “Example MRR Transactions with LPDDR2” shows an MRR transaction for a LPDDR2 memory device.

---

**FIGURE 57.** Example MRR Transactions with LPDDR2



**Note:** The  $t_{phy\_rddata}$  value shown is the actual value, not the maximum value.

## Functional Use

In Figure 58, “DFI Read Data Transfer Illustrating `dfi_rddata_valid` Definition”, the `dfi_rddata_valid` signals are transferred independently. This figure shows a one-to-one correspondence between the data words for `dfi_rddata_en` and `dfi_rddata_valid`; the `dfi_rddata_valid` words do not need to be contiguous.

**FIGURE 58.** DFI Read Data Transfer Illustrating `dfi_rddata_valid` Definition



**Note:** The `tphy_rdlat` value shown is the actual value, not the maximum value.

Figure 59, “Read Commands Utilizing `dfi_rddata_cs`” shows three read commands, with a gap between the second and third commands.

**FIGURE 59.** Read Commands Utilizing `dfi_rddata_cs`



DFI timing parameters for read and write commands will be referenced from the second tick of the second command in the same manner that JEDEC LPDDR4 references RL and WL.

---

**FIGURE 60. LPDDR4 Read Command**



Note: The **t<sub>phy\_rdlat</sub>** value shown is the actual value, not the maximum value.

#### 4.8.2 DBI - Read

DBI is an optional DFI feature used with read data transmissions. The **phy<sub>dbi\_mode</sub>** parameter is only needed when DBI is supported in DFI. If DBI is required in a system, DRAM DBI input must be received and used to selectively invert data for read commands.

For more information on the **phy<sub>dbi\_mode</sub>** parameter, refer to Table 17, “Write Data Interface Programmable Parameters”.

##### 4.8.2.1 MC DBI Support (**phy<sub>dbi\_mode</sub> = 0**)

The PHY captures the DRAM read DBI data and transmits the data over the DFI to the MC using the **dfi\_rddata\_dbi** signals. For more information on the DBI signals, refer to Table 15, “Write Data Interface Signals” and Table 18, “Read Data Interface Signals”. The timing of the **dfi\_rddata\_dbi** signal is identical to the timing of the **dfi\_rddata** signal, and the DBI data is sent coincident with the corresponding **dfi\_rddata** bus.

For frequency ratio systems, the **dfi\_rddata\_dbi** signal is extended, similar to **dfi\_rddata**, with a signal defined per phase. For example, with a 1:4 frequency system, the DBI information is transmitted across the **dfi\_rddata\_dbi\_w0**, **dfi\_rddata\_dbi\_w1**, **dfi\_rddata\_dbi\_w2** and **dfi\_rddata\_dbi\_w3** signals.

The timing of the phase outputs for DBI is identical to the **dfi\_rddata\_wN** outputs, with the data returned in a rolling order.

##### 4.8.2.2 PHY DBI Support (**phy<sub>dbi\_mode</sub> = 1**)

When the PHY generates the write DBI data, the **dfi\_rddata\_dbi** signal is not needed.

#### 4.8.3 Link ECC - Read

Link ECC is an optional DFI feature used with read data transmissions. The **phy<sub>linkecc\_mode</sub>** parameter is needed when Link ECC is supported in DFI. If the MC is handling link ECC operations, the DRAM will transmit the write ECC across

the DFI bus on the **dfi\_rddata\_dbi** signal. In Link ECC mode, the PHY is only required to transfer the read Link ECC through the PHY.

For more information on the **phy<sub>linkecc</sub>\_mode** parameter, refer to Section 3.13, “Link ECC”.

---

**FIGURE 61.** *Link ECC with Read Commands*



**Note:** The **t<sub>phy\_rdlat</sub>** value shown is the actual value, not the maximum value.

### 4.8.4 Read Data Interleaving

DFI supports non-contiguous read data transfers and read data interleaving when supported by the target memory device. For contiguous and non-contiguous reads, the **t<sub>phy\_rddata\_en</sub>** timing parameter defines the timing from the command to the first rising edge of the **dfi\_rddata\_en** signal and the **t<sub>phy\_rdlat</sub>** timing parameter defines the maximum delay from the **dfi\_rddata\_en** signal assertion to the data being driven on the **dfi\_rddata** signal. The assertions and de-assertions of the **dfi\_rddata\_en** signal must match the DRAM timing as before. Read data interleaving is permitted as defined by the DRAM and the timing also follows the DRAM timing. Read data order and timing across the read phases also follows the same rules. Figure 62 shows a normal non-interleaved read command. Figure 63 and Figure 64 show two examples of interleaved read commands. Figure 64 illustrates an additional delay on the read data due to transmission delay in the PHY.

**FIGURE 62.** Non-Interleaved Read Commands (LPDDR5 Example)

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

**FIGURE 63.** Interleaved Read Commands (LPDDR5 Example)


**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

**FIGURE 64.** Interleaved Read Commands with Transmission Delay (LPDDR5 Example)

Note: The **tphy\_rdlat** value shown is the actual value, not the maximum value.

#### 4.8.5 Cyclic Redundancy Check - Read

##### 4.8.5.1 DRAM CRC

DRAM CRC is an optional DFI feature used with read data transmissions to send CRC data as part of the read data burst. CRC extends a burst of 8 unit intervals (UI) to 10 UIs. When DRAM CRC is used, either the MC or the PHY can check the CRC data; however, the MC must check the CRC data if the PHY does not check it. The CRC data is made of the CRC code that is expanded by the needed padding values to reach a full DFI data clock cycle data transfer.

While either the MC or the PHY can validate the CRC data, the PHY defines the value of the **phy<sub>crc</sub>\_mode** programmable parameter. The **phy<sub>crc</sub>\_mode** parameter is only needed when CRC is supported in DFI and uses the following definition to determine how CRC is handled:

- **phy<sub>crc</sub>\_mode** = 0: CRC validation is handled in the MC
- **phy<sub>crc</sub>\_mode** = 1: CRC validation is handled in the PHY

##### 4.8.5.2 Read Link CRC

Read Link CRC is an optional DFI feature used with read data transmissions. The **phy<sub>linkdqrc</sub>\_mode** parameter must be 1 when Link CRC is supported in DFI. If read link CRC is enabled, the PHY will transmit the read CRC across the DFI bus on the **dfi\_rddata\_crc** signal. The PHY is only required to transfer the read link CRC through the PHY.

For more information on the **phylinkdqrc\_mode** parameter, refer to Section 3.13, “Link ECC”.

---

**FIGURE 65.** Link CRC with Read Commands



**Note:** The **t<sub>phy\_rdlat</sub>** value shown is the actual value, not the maximum value.

## 4.9 Update

The DFI contains signals to support MC-initiated and PHY-initiated update processes. The signals used in the update interface are: **dfi\_ctrlupd\_req**, **dfi\_ctrlupd\_ack**, **dfi\_phyupd\_req**, **dfi\_phyupd\_type** and **dfi\_phyupd\_ack**. The idle state timing parameters used in the update interface are: **t<sub>ctrl\_delay</sub>** and **t<sub>wrdata\_delay</sub>**.

For more information on the signals, refer to Section 3.4, “Update Interface”. For more information on the idle state timing parameters, refer to Table 14, “Command Interface Timing Parameters” and Table 16, “Write Data Interface Timing Parameters”.

### 4.9.1 MC-Initiated Update

During normal operation, the MC may encounter idle time during which no commands are issued to the DRAMs and all outstanding read and write data have been transferred on the DFI bus and the write data transfer has completed on the memory bus. Assertion of the **dfi\_ctrlupd\_req** signal indicates the control, read and write interfaces on the DFI are idle. While the **dfi\_ctrlupd\_req** signal is asserted, the DFI bus may only be used for commands related to the update process.

The MC guarantees that **dfi\_ctrlupd\_req** signal is asserted for at least **t<sub>ctrlupd\_min</sub>** cycles, allowing the PHY time to respond. The PHY may respond to or ignore the update request. To acknowledge the request, the **dfi\_ctrlupd\_ack** signal must be asserted before **t<sub>ctrlupd\_max</sub>** expires and while the **dfi\_ctrlupd\_req** signal is asserted. The **dfi\_ctrlupd\_ack** signal must de-assert at least one cycle before **t<sub>ctrlupd\_max</sub>** expires.

The MC should hold the **dfi\_ctrlupd\_req** signal as long as the **dfi\_ctrlupd\_ack** signal is asserted, although the MC could de-assert the **dfi\_ctrlupd\_req** signal to disconnect the handshake through the disconnect protocol. The PHY must de-assert the **dfi\_ctrlupd\_ack** signal before **t<sub>ctrlupd\_max</sub>** expires.

Figure 66, “MC-Initiated Update Timing Diagram” shows that the DFI does not specify the number of cycles after the **dfi\_ctrlupd\_ack** signal de-asserts before the **dfi\_ctrlupd\_req** signal de-asserts.

**FIGURE 66.** MC-Initiated Update Timing Diagram

Figure 67, “MC-Initiated Update with No Response” shows the important point that the **dfi\_ctrlupd\_ack** signal is not required to assert when the **dfi\_ctrlupd\_req** signal is asserted. The MC must assert the **dfi\_ctrlupd\_req** signal for at least  $t_{ctrlupd\_min}$  within every  $t_{ctrlupd\_interval}$  cycle, but the total number of cycles that the **dfi\_ctrlupd\_req** signal is asserted must not exceed  $t_{ctrlupd\_max}$ .

**FIGURE 67.** MC-Initiated Update with No Response

#### 4.9.2 PHY-Initiated Update

The PHY may also trigger the DFI to enter an idle state. This update process utilizes three signals: **dfi\_phyupd\_req**, **dfi\_phyupd\_type** and **dfi\_phyupd\_ack**. The **dfi\_phyupd\_req** signal indicates the need for idle time on the DFI, the **dfi\_phyupd\_type** signal defines the type of update required, and the **dfi\_phyupd\_ack** signal is the MC’s response signal. Four update types are specified by the DFI.

To request an update, the **dfi\_phyupd\_type** signal must be valid when the **dfi\_phyupd\_req** signal is asserted. The  $t_{phyupd\_typeX}$  parameters indicate the maximum number of cycles of idle time on the DFI command, read data and write data interfaces being requested. The **dfi\_phyupd\_ack** signal must assert within  $t_{phyupd\_resp}$  cycles after the assertion of the **dfi\_phyupd\_req** signal in most cases. Exceptions are granted if **dfi\_init\_start**, **dfi\_phymngd\_req** or **dfi\_ctrlupd\_req** are active along with **dfi\_phyupd\_req**. Refer to Section 4.21, “DFI Interactions”

When the **dfi\_phyupd\_ack** signal is asserted, it should remain asserted until the **dfi\_phyupd\_req** signal de-asserts unless the Controller wishes to disconnect the handshake. The **dfi\_phyupd\_req** signal must de-assert before  $t_{phyupd\_typeX}$  cycles have expired. The **dfi\_phyupd\_ack** signal must de-assert following the detection of the **dfi\_phyupd\_req** signal de-assertion. The **dfi\_phyupd\_ack** signal for the previous transaction must be de-asserted before the **dfi\_phyupd\_req** signal can re-assert. While the **dfi\_phyupd\_ack** signal is asserted, the DFI bus may only be used for commands related to the update process.

Figure 68, “PHY-Initiated Update Timing Diagram” shows that the MC must respond to a PHY update request, unlike MC-initiated updates shown in Figure 66, “MC-Initiated Update Timing Diagram” and Figure 67, “MC-Initiated Update with No Response”.

**FIGURE 68. PHY-Initiated Update Timing Diagram**



### 4.9.3 DFI Bus Idle

To prevent the condition where a PHY may disrupt the write data transfer on the memory bus, the write data transfer on the memory bus must complete before the DFI bus idle state is reached.

The  $t_{wrdata\_delay}$  idle state timing parameter defines the number of Data clocks from **dfi\_wrdata\_en** to the completion of the write data transfer on the host interface. Since the requirement for an idle bus state following a write is generally an infrequent event relative to the overall traffic pattern, the accuracy of the setting should not be a performance issue, so it may be set to a larger value.

If a PHY has no dependency between completing a write data transfer on the DFI bus and the idle state, the  $t_{wrdata\_delay}$  parameter can be set to zero.

When a PHY does have a dependency between completing a write data transfer on the DFI bus and the idle state, the  $t_{wrdata\_delay}$  parameter should be set to a sufficiently large value to accommodate the write data width, flight time through the PHY and worst-case timing on the host interface.

**FIGURE 69.** DFI Bus Idle State Timing Parameter -  $t_{wrdata\_delay}$ 

Note: The **tphy\_rdlat** value shown is the actual value, not the maximum value.

## 4.10 Frequency Ratios Across the DFI

In a DDR memory subsystem, it may be advantageous to operate the PHY's interface to memory, also referred to as the host interface, at a higher frequency than the MC. The DFI clock is generally assumed to be the same clock as the MC clock. If the host's data interface operates at a multiple of the MC frequency, the PHY transfers data at a higher data rate relative to the DFI clock. If the host's command interface operates at a multiple of the MC frequency, the PHY can transfer multiple commands in a single DFI clock cycle.

DFI recognizes four clock domains - the DFI clock domain, the Control clock domain, the Command clock domain, and the Data clock domain. The DFI clock is the MC-PHY interface clock. The Control clock domain is always the same frequency as the DFI clock domain. Refer to Section 2.1, "Clocking" for more information on these clocks.

Depending on the DRAM or DIMM protocol, the host interface may utilize a single memory clock or separate command and data clocks. For protocols utilizing a single host clock, the terms "Command clock" and "Data clock" refer to the common clock. The Command clock domain is always the same frequency as the host command clock (eg CK, DCK). The Data clock domain is always the same frequency as the host data clock or strobe (eg DQS, RDQS, WCK).

If all 4 clock domains operate at the same frequency, it is a matched ratio system, otherwise it is frequency ratio system.

For a frequency ratio system, DFI defines two clock ratios - the command ratio is the ratio between the slower Control clock domain and the faster Command clock domain, and the data ratio is the ratio between the slower Control clock domain and the faster Data clock domain. A frequency ratio system with a 1:1 command frequency ratio may be referred to as a matched command ratio system for brevity. Supported ratios for frequency ratio systems are 1:1, 1:2, 1:4, and 1:8.

All DFI interface signals operate on the DFI clock. The MC communicates command frequency ratio settings to the PHY on the **dfi\_cmd\_freq\_ratio** signal and data frequency ratio settings to the PHY on the **dfi\_data\_freq\_ratio** signal. These signals are only required for devices that support frequency ratio systems.

The frequency ratio protocol affects the command, write data, and read data interfaces, including read data rotation and resynchronization. Frequency ratio also affects CA parity and CRC errors.

For information on how frequency ratio affects CA parity and CRC errors, refer to Section 4.12.3, “CA Parity and CRC Errors in Frequency Ratio Systems”.

#### **4.10.1 Frequency Ratio Clock Definition**

The DFI clock and the Command or Data clock must be phase-aligned and at a 1:2, 1:4, or 1:8 frequency ratio relative to one another. Some DFI signals from the MC to the PHY must communicate information about the signal in reference to the Command or Data clock to maintain the correct timing information. Therefore, the Command or Data clock is described in terms of phases of the DFI clock, where the number of clock phases for an interface is the ratio of the Command or Data clock to the DFI clock.

Figure 70, “Frequency Ratio 1:2 Phase Definition” and Figure 71, “Frequency Ratio 1:4 Phase Definition” show the clock phase definitions for 1:2 and 1:4 frequency ratio systems. Figure 72, “Mixed Frequency Ratio Phase Definition” shows the clock phase definition for a system with 1:2 command frequency and 1:4 data frequency ratio.

---

**FIGURE 70. Frequency Ratio 1:2 Phase Definition**



---

**FIGURE 71. Frequency Ratio 1:4 Phase Definition**



---

**FIGURE 72. Mixed Frequency Ratio Phase Definition**



In a system with different command and data frequency ratios, when referencing a Command domain signal from a Data domain timing parameter, use the Data phase that begins at the same time as the Command phase. Using the example in Figure 72, “Mixed Frequency Ratio Phase Definition”, a Command phase 0 signal would align with Data phase 0 and a Command phase 1 signal would align with Data phase 2.

#### **4.10.2 Interface Signals with Frequency Ratio Systems**

DFI signals operating at a frequency ratio are defined on a per-phase basis and all signal timing is in reference to the DFI clock. The PHY must account for any assertions based on the DFI clock. Any DFI signals driven by the PHY must be launched from the rising edge of the DFI clock.

The DFI specification supports the ability to send a unique command on each phase of the Command clock. To communicate this information to the PHY, the DFI specification defines commands for a frequency ratio system in a vectored format. The PHY must maintain this information to preserve the timing relationships between commands and data. Therefore, for frequency ratio systems, the command interface signals are suffixed with a “\_pN” where N is the command phase number, and the write data interface and the read data enable signal are all suffixed with a “\_pN” where N is the data phase number. As an example, for a 1:2 command frequency ratio system, instead of a single **dfl\_address** signal, there are 2 signals: **dfl\_address\_p0** and **dfl\_address\_p1**. The read data valid, read data, and related signals are suffixed with a “\_wN” where N is the DFI data word. More information on the read data interface for frequency ratio systems is provided in Section 4.10.4, “Read Data Interface in Frequency Ratio Systems”. The phase 0 or DFI data word 0 suffixes are not required.

There is flexibility in system setup for frequency ratio systems. The MC may be implemented to support command output on a single phase or on multiple phases. Even if multiple phases are supported, the MC is not required to implement or drive every phase of a signal. Only phases where a command is sent must be implemented and driven. The exceptions to the rule are the **dfl\_cke\_pN** and **dfl\_odt\_pN** signals. These two signals are not necessarily driven in the same phase as the rest of the command. Therefore, these signals must be implemented for all phases of the clock to allow flexibility in timing.

The PHY must be able to accept a command on all phases to be DFI compliant. If the MC is only using certain phases, the PHY must be appropriately connected to properly interpret the command stream.

There is no requirement that signals must be implemented in the same way across the interfaces. For example, in a 2T implementation, the **dfl\_ras\_n\_pN**, **dfl\_cas\_n\_pN** and **dfl\_we\_n\_pN** signals may be driven by the MC on all clock phases, but the **dfl\_cs\_pN** signal may only be driven by the MC on half of the phases.

Figure 73, “Example 1:2 Command Frequency Ratio Command Stream” illustrates an example command stream for a 1:2 frequency ratio system and how the PHY in this system would interpret the DFI signals. In this example, a command is only sent on phase 0; the values of phase 0 and phase 1 commands will be different. ODT information is provided on both phases. The command bus signals are not always the same value and are not always equal to one.

**FIGURE 73.** Example 1:2 Command Frequency Ratio Command Stream



Figure 74, “Example 1:4 Command Frequency Ratio Command Stream” represents the same example, in a 1:4 frequency ratio system. The command is only sent on phase 0 and ODT information is provided on all phases.

**FIGURE 74.** Example 1:4 Command Frequency Ratio Command Stream



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

### 4.10.3 Write Data Interface in Frequency Ratio Systems

The write data enable signal (**dfi\_wrdata\_en\_pN**) indicates to the PHY that valid **dfi\_wrdata** will be transmitted in  $t_{phy\_wrdata}$  Data clock cycles. In order to communicate this information to the PHY, the phase information must be encoded within the signal. Therefore, this signal is also vectored into multiple signals based on the data frequency ratio. Similar to the DFI command, each signal is associated with a data phase of the DFI clock.

Figure 75, “1:2 Command and 1:2 Data Frequency Ratio Write Data Example” demonstrates how a vectored **dfi\_wrdata\_en\_pN** signal is interpreted by the PHY in a 1:2 frequency ratio system.

**FIGURE 75. 1:2 Command and 1:2 Data Frequency Ratio Write Data Example**



For matched frequency systems, the DFI write data bus width is generally twice the width of the DRAM data bus. For frequency ratio systems, this DFI write data bus width is proportional to the frequency ratio to allow all of the write data that the memory requires to be sent in a single DFI clock cycle. The write data must be delivered with the DFI data words aligned in ascending order.

The timing parameters  $t_{phy\_wrlat}$  and  $t_{phy\_wrdata}$  apply in frequency ratio systems in the same way as in matched frequency systems. The  $t_{phy\_wrlat}$  parameter defines the delay from the write command to the **dfi\_wrdata\_en\_pN** signal. The  $t_{phy\_wrdata}$  parameter defines the delay from the **dfi\_wrdata\_en\_pN** signal to when data is driven on the **dfi\_wrdata\_pN** signal. These timing parameters are defined in terms of Data clocks and are measured relative to how the PHY interprets the data.

## Functional Use

Figure 76, “1:2 Command and 1:2 Data Frequency Ratio Aligned Write Data Example” shows how data is received by the PHY in a situation where the data is sent aligned, but the enable signals are not aligned.

**FIGURE 76. 1:2 Command and 1:2 Data Frequency Ratio Aligned Write Data Example**



■ DFI clock phase p0

□ DFI clock phase p1

This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

## Functional Use

In Figure 77, “1:2 Command and 1:2 Data Frequency Ratio Aligned Write Enable Example”, the enable signals are sent aligned, but the data is not aligned. The MC sends the first beat of data on the phase 1 data signal. The write data must be sent un-aligned to achieve the proper relationship between the command and data.

**FIGURE 77. 1:2 Command and 1:2 Data Frequency Ratio Aligned Write Enable Example**



DFI timing parameters for read and write commands will be referenced from the second tick of the second command in the same manner that JEDEC LPDDR4 references RL and WL.

**FIGURE 78.** LPDDR4 Write Command, 1:2 Command and 1:2 Data Frequency Ratio ( $t_{phy\_wrdata} = 0$ )

#### 4.10.4 Read Data Interface in Frequency Ratio Systems

Similar to the write data enable signal, the read data enable signal (**dfi\_rddata\_en\_pN**) defines the number of Data clocks between the read command and the read data. The PHY sends read data to the MC on the **dfi\_rddata\_wN** buses whenever read data is available, asserting the associated **dfi\_rddata\_valid\_wN** signals to inform the MC which buses contain valid data. Unlike the read data enable signal which correlates to the Data phase of the DFI clock, the read data valid, read data, and related signals are all vectored with the DFI data word suffix.

For matched frequency systems, the DFI read data bus width is generally twice the width of the DRAM data bus. For frequency ratio systems, this DFI read data bus width is proportional to the frequency ratio to allow all of the read data that the memory returns to be sent in a single DFI clock cycle. The read data must be delivered with the DFI data words aligned in ascending order.

For a 1:2 frequency ratio system, the read data bus is divided into 2 DFI read data words. For a 1:4 frequency ratio system, the read data bus is divided into 4 DFI read data words. Each DFI data word transfers a memory data word, the data associated with one rising and falling DQS. For example, in a 1:4 system with a memory data width of 32 bits, the DFI read data bus would consist of 4 64-bit DFI data words.

On a DFI clock, the PHY is permitted to assert any number of consecutive **dfi\_rddata\_valid\_wN** signals that correspond to valid read data. However, the read data must be returned in a rolling order of DFI data words. For a 1:4 frequency ratio system, if read data is returned on the **dfi\_rddata\_w0** and **dfi\_rddata\_w1** buses on one DFI clock cycle, the next transaction must return data starting on the **dfi\_rddata\_w2** bus, regardless of the number of DFI data words being returned. If that next transaction returned 2 DFI data words, data must be returned on the **dfi\_rddata\_w2** and **dfi\_rddata\_w3** buses. If that next transaction returned 4 DFI data words, data must be returned on the **dfi\_rddata\_w2**, **dfi\_rddata\_w3**, **dfi\_rddata\_w0** and **dfi\_rddata\_w1** buses - in that order.

For a 1:2 frequency ratio system, read data must be returned in the same manner, in a rolling order of DFI data words. In this case, there are only 2 DFI data words in the DFI read data bus - **dfi\_rddata\_w0** and **dfi\_rddata\_w1**.

The rolling order rule must be followed regardless of whether the subsequent data transfer occurs on the next DFI clock or several clocks later. The rolling order rule applies to both reads and mode register reads. The order is critical for the PHY and MC to correctly communicate read data. Each DFI data word must be used prior to sending data on the subsequent DFI data word, requiring data to be sent contiguously. The subsequent read data must be returned on the next DFI data word relative to the previous transaction. If the last transaction ended on **dfi\_rddata\_w2**, for example, the next transfer

must begin on **dfi\_rddata\_w3**. Similarly, it is not legal to return read data on only the **dfi\_rddata\_w0** and **dfi\_rddata\_w2** buses.

Both the MC and the PHY must track which signals were used in the last transfer in order to interpret the data accurately. At initialization, the DFI data word pointer is set to 0, and the first read data returned is expected on the **dfi\_rddata\_w0** bus. During normal operation, certain procedures may affect the read data rotation, such as frequency changing. Therefore, any assertion of the **dfi\_init\_start** signal must trigger a re-initialization of the DFI data word pointer to 0.

The rotational use of the **dfi\_rddata\_valid\_wN** signals is only required in situations where the system may return less data than the DFI read data bus. If the minimum transfer size is a multiple of the DFI read data bus width, data can always be returned on all DFI data words and the **dfi\_rddata\_valid\_wN** signals are all driven identically. Otherwise, only certain DFI data words of the DFI read data bus are used. In either case, the MC must be able to receive data in a rotating order based on the last transfer to be DFI compliant for frequency ratio. A PHY may optionally be implemented such that it always returns read data on the entire DFI read data bus per transaction.

Regardless of how the signals are vectored, the PHY may only change read data valid, read data, and related signals during phase 0 of the DFI clock to allow the MC the entire DFI clock period to capture the signal and read data.

The timing parameters **t<sub>rddata\_en</sub>** and **t<sub>phy\_rdlat</sub>** apply in frequency ratio systems in the same way as in matched frequency systems. These timing parameters define the delay from the read command to the **dfi\_rddata\_en\_pN** signal, and from the **dfi\_rddata\_en\_pN** signal to when data is returned on the **dfi\_rddata\_wN** bus, respectively. These timing parameters are defined in terms of Data clocks and are measured relative to how the PHY interprets the data.

Figure 79, “1:2 Command and 1:2 Data Frequency Ratio Single Read Data Example with Even Read Data to Enable Timing” demonstrates how a vectored **dfi\_rddata\_en\_pN** signal is interpreted by the PHY in a 1:2 frequency ratio system with an even value for the **t<sub>rddata\_en</sub>** timing parameter, and where all DFI data words are returned on a DFI clock cycle.

**FIGURE 79.** 1:2 Command and 1:2 Data Frequency Ratio Single Read Data Example with Even Read Data to Enable Timing



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

Figure 80, “1:2 Command and 1:2 Data Frequency Ratio Single Read Data Example with Odd Read Data to Enable Timing” demonstrates how a vectored `dfi_rddata_en_pN` signal is interpreted by the PHY in a 1:2 frequency ratio system with an odd value for the  $t_{rddata\_en}$  timing parameter, and where all DFI data words are returned on a DFI clock cycle.

**FIGURE 80.** 1:2 Command and 1:2 Data Frequency Ratio Single Read Data Example with Odd Read Data to Enable Timing



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The `tphy_rdlat` value shown is the actual value, not the maximum value.

## Functional Use

Figure 81, “1:4 Command and 1:4 Data Frequency Ratio Single Read Data Example” demonstrates how a vectored **dfi\_rddata\_en\_pN** signal is interpreted by the PHY in a 1:4 frequency ratio system where all DFI data words are being returned on a DFI clock cycle.

**FIGURE 81. 1:4 Command and 1:4 Data Frequency Ratio Single Read Data Example**



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

## Functional Use

Figure 82, “1:2 Command and 1:2 Data Frequency Ratio Multiple Read Data Example” returns a single DFI data word with each command. The data for the second read command is returned on the **dfi\_rddata\_w1** bus following the rotational order rule.

**FIGURE 82. 1:2 Command and 1:2 Data Frequency Ratio Multiple Read Data Example**



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

Similar to Figure 82, “1:2 Command and 1:2 Data Frequency Ratio Multiple Read Data Example”, Figure 83, “1:4 Command and 1:4 Data Frequency Ratio Multiple Read Data Example” shows a burst length 4 followed by a burst length

## Functional Use

8 read. The data for the burst length 8 read command is returned starting on the **dfi\_rddata\_w2** bus following the rotational order rule.

**FIGURE 83.** 1:4 Command and 1:4 Data Frequency Ratio Multiple Read Data Example



| DFI clock phase 0                                                                                                                     | DFI clock phase 1 | DFI clock phase 2 | DFI clock phase 3 |
|---------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|
| This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.  |                   |                   |                   |
| 1. In the MC diagram, the timing shows the DFI bus signaling.                                                                         |                   |                   |                   |
| 2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only. |                   |                   |                   |

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

DFI timing parameters for read and write commands will be referenced from the second tick of the second command in the same manner that JEDEC LPDDR4 references RL and WL.

**FIGURE 84.** LPDDR4 Read Command, 1:2 Command and 1:2 Data Frequency Ratio

Note: The  $t_{phy\_rdlat}$  value shown is the actual value, not the maximum value.

#### 4.10.4.1 DFI Read Data Rotation

For simplicity, the following four diagrams illustrate different potential timing scenarios with a 1:2 frequency ratio system, transmitting 2 bursts of data, with each burst extended by one DRAM clock cycle.

Many DFI systems do not require support for burst transfers that are not a multiple of the frequency ratio. However, if a system does support these burst transfers, the PHY must transfer the read data in a rotating order as follows:

1. Figure 85, “DFI Read Data Bus for Two 10UI Bursts, each starting in Phase 0”
2. Figure 86, “DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 0 ( $trddata\_en = 2$ ,  $tphy\_rdlat = 8$ )”
3. Figure 87, “DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 1”
4. Figure 88, “DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 0 ( $trddata\_en = 2$ ,  $tphy\_rdlat = 10$ )”

Additionally, the MC must be able to capture this data correctly and correlate it to the proper read command.

**FIGURE 85.** DFI Read Data Bus for Two 10UI Bursts, each starting in Phase 0



DFI clock phase 0

DFI clock phase 1

This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

**FIGURE 86.** DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 0 ( $t_{rddata\_en} = 2$ ,  $t_{phy\_rdlat} = 8$ )



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

**FIGURE 87.** DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 1



This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

**FIGURE 88.** DFI Read Data Bus for 10UI Back-to-Back Bursts Starting in Phase 0 ( $t_{rddata\_en} = 2$ ,  $t_{phy\_rdlat} = 10$ )



DFI clock phase 0

DFI clock phase 1

This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.

1. In the MC diagram, the timing shows the DFI bus signaling.

2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

#### 4.10.4.2 Read Data Resynchronization

When the read data rotation order is applicable, the MC and the PHY must maintain read data synchronization to properly interpret the read data order. At initialization, the DFI data word pointer is set to 0, and the first read data returned is expected on the **dfi\_rddata\_w0** bus. During normal operation, certain procedures may affect the read data rotation, such as frequency changing. Therefore, any assertion of the **dfi\_init\_start** signal must trigger a re-initialization of the DFI data word pointer to 0. If a condition occurs where the read data synchronization may be lost (such as if an error must be reported), a mechanism is necessary to resynchronize the devices. In order to be able to resynchronize when either the **dfi\_ctrlupd\_req** or **dfi\_phyupd\_ack** signals are asserted, reset the read data in a Frequency Ratio implementation in both the MC and PHY. Following the assertion of either the **dfi\_ctrlupd\_req** or **dfi\_phyupd\_ack** signal, the next read data word is always sent on **dfi\_rddata\_w0** regardless of the location of the previous data word.

#### 4.10.4.3 DFI Read Data Rotation in Large Frequency Ratio Systems

In section Figure 4.10.4.1, “DFI Read Data Rotation”, rotation was illustrated for a 1:2 ratio system. When considering larger ratio systems, such as 1:4 or 1:8, additional scenarios are possible. Before evaluating how data will be returned on

the DFI, some basic rules of data rotation must be reviewed. Note that the enable beats and their order are shown in blue text, and the and valid beats (and their order) are shown in magenta text on the following figures. Also note that these examples all show a 1:4 frequency ratio system but the same extrapolation applies to 1:8 frequency ratio systems.

- **Rule 1:** A PHY may send as much or as little data as is ready on any DFI cycle. There is no requirement to smooth out gaps. This means that on any DFI cycle, for a 1:4 system, there can be 0, 1, 2, 3 or 4 valid bursts (or for 1:8 system, there can be 0, 1, 2, 3, 4, 5, 6, 7 or 8 valid bursts). However, the bursts must be contiguous within a cycle, starting at the correct `dfi_rddata_valid_wX` signal. In Figure 89, “Read Rotation Rule 1 Example”, on the first cycle, there are 2 valid beats, then 4 on the 2nd cycle, 2 on the 3rd cycle, 4 on the 4th cycle, and 4 on the 5th cycle.

---

**FIGURE 89.** Read Rotation Rule 1 Example



- **Rule 2:** In the first cycle that contains data after the read data resynchronization, regardless of the phase (`dfi_rddata_en_pX`) on which the enable of beat 0 was sent, the data will always be returned on the `dfi_rddata_valid_w0` / `dfi_rddata_w0` signal. Figure 90, “Read Rotation Rule 2 Example” uses the same example shown above. Even though the first enable beat was sent on the `dfi_rddata_en_p1` signal, the first beat of data is returned on the `dfi_rddata_valid_w0` signal and the second beat is returned on the `dfi_rddata_valid_w1` signal.

---

**FIGURE 90.** Read Rotation Rule 2 Example



- **Rule 3:** For all other DFI cycles, the PHY will drive the next beat of data on the “next” phase of the `dfi_rddata_valid_wX` signal that was not used in the last cycle. Using the same example, in the first cycle, the `dfi_rddata_valid_w0` and `dfi_rddata_valid_w1` signals returned data beats. Therefore, on the second cycle, the first beat (beat 2) will be driven on the `dfi_rddata_valid_w2` signal, beat 3 will be driven on the `dfi_rddata_valid_w3` signal, beat 4 will be driven on the `dfi_rddata_valid_w0` signal, then beat 5 will be driven on the `dfi_rddata_valid_w1` signal. The beat pattern is shown in Figure 91, “Read Rotation Rule 3 Example”.

**FIGURE 91.** Read Rotation Rule 3 Example



- **Rule 4:** Each valid data beat corresponds to a particular enable beat, in the same order, regardless of the overall pattern formed on the valid and enable signals. In this example, the valid signals return the first two beats (the magenta 0 and 1) on one DFI cycle, even though the first 3 beats (the blue 0, 1 and 2) of the enable signals shared a DFI cycle. Similarly, the valid signals for the 7th and 8th beats (the magenta 7 and 8) are returned on different DFI cycles even though the matching enable beats (the blue 7 and 8) were sent on the same cycle. The beat pattern is shown in Figure 92, “Read Rotation Rule 4 Example”.

**FIGURE 92.** Read Rotation Rule 4 Example



To demonstrate how these rules apply, three examples are provided with a **dfi\_rddata\_valid\_wX** pattern that is simple, moderate, or extreme. The examples are not necessarily realistic, but are artificially exaggerated for illustrative purposes. For these examples, the **dfi\_rddata\_en\_pX** signals are shown in Figure 93, “Enable Signals for the Read Data Rotation Examples in a 1:4 Frequency Ratio System” send data in contiguous sets of 16 phases. The number of valid phases and the first and last word pointers for the **dfi\_rddata\_valid** signal are indicated.

**FIGURE 93.** Enable Signals for the Read Data Rotation Examples in a 1:4 Frequency Ratio System


Figure 94, “Simple DFI Read Data Rotation Example in a 1:4 Frequency Ratio System” shows a simple **dfi\_rddata\_valid\_wX** pattern in which only 2 phases of read data are valid in the first DFI clock cycle (following rule 1), and are sent on the **dfi\_rddata\_valid\_w0** signal (following rule 2) and the **dfi\_rddata\_valid\_w1** signal. Following rule 3, on the next cycle, data will be returned first on the **dfi\_rddata\_valid\_w2** signal, then on the **dfi\_rddata\_valid\_w3** signal, then the **dfi\_rddata\_valid\_w0** signal, then on the **dfi\_rddata\_valid\_w1** signal. The Controller must understand this data pattern to re-assemble the read data correctly.

**FIGURE 94.** Simple DFI Read Data Rotation Example in a 1:4 Frequency Ratio System


Figure 95, “Moderate DFI Read Data Rotation Example in a 1:4 Frequency Ratio System” shows a moderate **dfi\_rddata\_valid\_wX** pattern in which each DFI cycle alternates between providing 3 or 4 phases of data, until data runs out. This example includes a 1-phase gap in each **dfi\_rddata\_valid\_wX** signal. Note how each 1-phase gap moves the start position in the next cycle. Only 3 phases of read data are valid in the first DFI clock cycle (following rule 1), and are sent on the **dfi\_rddata\_valid\_w0** signal (following rule 2), the **dfi\_rddata\_valid\_w1** signal, and the **dfi\_rddata\_valid\_w2** signal. Following rule 3, on the next cycle, data will be returned first on the **dfi\_rddata\_valid\_w3** signal, then on the **dfi\_rddata\_valid\_w0** signal, then on the **dfi\_rddata\_valid\_w1** signal, then on the **dfi\_rddata\_valid\_w2** signal.

**FIGURE 95.** Moderate DFI Read Data Rotation Example in a 1:4 Frequency Ratio System



Figure 96, “Extreme DFI Read Data Rotation Example in a 1:4 Frequency Ratio System” shows an extreme **dfi\_rddata\_valid\_wX** pattern, the DFI cycles contain 0, 1, 2, 3 or 4 phases of valid data. Gaps of various lengths begin at various positions. Only 1 phase of read data is valid in the first DFI clock cycle (following rule 1), and is sent on the **dfi\_rddata\_valid\_w0** signal (following rule 2). Following rule 3, on the next cycle, data will be returned first on the **dfi\_rddata\_valid\_w1** signal. On the subsequent cycle, data is returned on the **dfi\_rddata\_valid\_w2** signal, the **dfi\_rddata\_valid\_w3** signal, then on the **dfi\_rddata\_valid\_w0** signal.

**FIGURE 96.** Extreme DFI Read Data Rotation Example in a 1:4 Frequency Ratio System



In all these examples, the read data burst begins on the **dfi\_rddata\_valid\_w0** signal and ends on the **dfi\_rddata\_valid\_w3** signal. This is because the number of data phases per burst is an integer multiple of the DFI ratio. When the number of data phases per burst is not a multiple of the ratio, the start and end points of the bursts will move.

Figure 97, “Non-Integral Transfer-Length-to-Ratio Example” shows a simple **dfi\_rddata\_valid\_wX** pattern when the burst length is not a multiple of the DFI ratio. The **dfi\_rddata\_en** signals represent a single command (first burst), then a gap, followed by 2 contiguous commands on a second and third burst.

Only 2 phases of read data are valid in the first DFI clock cycle, and are sent on the **dfi\_rddata\_valid\_w0** signal and the **dfi\_rddata\_valid\_w1** signal. The remainder of data for the first command continues, concluding on the **dfi\_rddata\_valid\_w1** signal (magenta 0-9). Then, following rule 3, data for the second command (magenta 10-19) will be returned first on the **dfi\_rddata\_valid\_w2** signal on the next cycle that returns data, and it will end on the **dfi\_rddata\_valid\_w3** signal. On the subsequent cycle, data is returned for the third command (magenta 20-29) on the **dfi\_rddata\_valid\_w0** signal (again following rule 3), the **dfi\_rddata\_valid\_w1** signal, the **dfi\_rddata\_valid\_w2** signal, and the **dfi\_rddata\_valid\_w3** signal and continues until all data has been returned, ending on the **dfi\_rddata\_valid\_w1** signal. Even though this is a simple example, this pattern of first and last pointers will continue for all commands, regardless of any gaps in the valid signals, provided that all commands are the same burst length.

---

**FIGURE 97. Non-Integral Transfer-Length-to-Ratio Example**



## 4.11 Frequency Change

The DFI specification defines a frequency change protocol between the MC and the PHY to allow the devices to change in response to a clock frequency change. How the system orchestrates the changing of the DFI clock frequency is outside the scope of the DFI spec. The memory specifications define various memory states in which the clock frequency can be changed safely. The general procedure is to put the memory in one of these states, modify the clock frequency and re-synchronize the system. When the new clock frequency has been established, the PHY may need to re-initialize various circuits to the new clock frequency prior to resuming normal memory operation. Once complete, the memory system is ready to resume normal operation.

The DFI frequency change protocol is an optional feature. The system may use a non-DFI frequency change method, or may choose to not support a frequency change option. However, if both the MC and the PHY intend to use the DFI frequency change protocol, the MC and PHY must comply with the handshake defined by the DFI specification. The handshaking protocol defines the signals through which the MC and the PHY allow a frequency change operation to occur and also provides a means to abort the process if the PHY does not respond to a frequency change request. When a frequency change operation occurs, some of the DFI timing parameters may need to be changed.

NOTE: During the frequency change protocol, the DFI clock must remain valid - either operating at a valid frequency or gated high or low.

The signals used in the frequency change protocol are **dfi\_init\_start**, **dfi\_init\_complete**, **dfi\_frequency**, **dfi\_cmd\_freq\_ratio**, **dfi\_data\_freq\_ratio** and **dfi\_freq\_fsp**. If supported, the **dfi\_cmd\_freq\_ratio** signal indicates the clock ratio between the DFI clock and the host command clock and the **dfi\_data\_freq\_ratio** signal indicates the clock ratio between the DFI clock and the host data clock. If the memory supports multiple FSPs, the **dfi\_freq\_fsp** signal indicates the target FSP for the frequency change. For more information on these signals, refer to Section 3.5, “Status Interface”.

### 4.11.1 Frequency Change Protocol - Acknowledged

During normal operation, once the **dfi\_init\_start** and **dfi\_init\_complete** signals have been asserted, the system may change the DFI clock frequency. The MC asserts the **dfi\_init\_start** signal to indicate that a clock frequency change request has been made and drives the encoded value of the new frequency on the **dfi\_frequency** signal. The **dfi\_cmd\_freq\_ratio**, **dfi\_data\_freq\_ratio** and **dfi\_freq\_fsp** signals are also driven if applicable. The memory must be given to the PHY as defined in the **dfifreq\_change\_state** timing parameter during a frequency change operation before asserting the **dfi\_init\_start** signal. The PHY should not interpret the initial **dfi\_init\_start** assertion (during initialization) as a frequency change request. When the **dfi\_init\_start** signal is asserted, the MC and the PHY must reset their DFI read data word pointers to 0.

The MC guarantees that the **dfi\_init\_start** signal remains asserted for at least  $t_{init\_start}$  cycles, allowing the PHY time to respond. The PHY may respond or ignore the frequency change request. To acknowledge the request, the **dfi\_init\_complete** signal must be de-asserted within  $t_{init\_start}$  cycles of the assertion of the **dfi\_init\_start** signal, or the opportunity for a DFI frequency change operation is withdrawn until the MC re-asserts this signal. The **dfi\_init\_complete** signal must de-assert at least one cycle before  $t_{init\_start}$  expires. If necessary, when the PHY acknowledges the frequency change request, the PHY will complete memory setup before de-asserting the **dfi\_init\_complete** signal. In this case,  $t_{init\_start}$  should be programmed to larger values, so that the PHY can complete memory setup with the new frequency settings.

If the frequency change request is acknowledged, the MC must hold the **dfi\_init\_start** signal asserted as long as the frequency change operation continues. As long as the **dfi\_init\_start** signal is asserted, the MC can not change the **dfi\_frequency**, **dfi\_cmd\_freq\_ratio**, **dfi\_data\_freq\_ratio** and **dfi\_freq\_fsp** signals. Once the frequency change operation has completed for the MC, the MC de-asserts the **dfi\_init\_start** signal. The PHY must then complete any re-initialization (PHY and memory setup) and re-training required for the new clock frequency and re-assert **dfi\_init\_complete** within  $t_{init\_complete}$  cycles.

The PHY must also perform the following actions before asserting the **dfi\_init\_complete** signal during a frequency change operation:

- Ensure that all the DRAM timings associated with re-initialization (PHY and memory setup) and re-training are met.
- Ensure that memory is in the state defined by the **dfifreq\_change\_state**.
- Ensure that WCK is turned off for the DRAMs which support WCK.

During a frequency change operation, the PHY must ensure that the memory interface is maintained at valid and stable levels to ensure that memory protocol is being observed. The MC must also ensure that it maintains valid and stable levels on the DFI while **dfi\_init\_start** is asserted or **dfi\_init\_complete** is de-asserted. During a frequency change operation, the MC and the PHY must meet all the memory and DFI timing requirements prior to transitioning the corresponding **dfi\_init\_start** and **dfi\_init\_complete** signals. WCK needs to be disabled during a frequency change operation when the

MC initiates with assertion of the **dfi\_init\_start** signal and while the PHY asserts the **dfi\_init\_complete** signal for the DRAMs which support WCK. For more information, refer to Section 3.11, “WCK Control Interface”.

Note that no maximum number of cycles for the entire cycle to complete is specified by the DFI.

Figure 98, “Frequency Change Request Acknowledge Timing Diagram” shows the MC holding the **dfi\_init\_start** signal asserted as long as the frequency change operation continues and the PHY re-asserting **dfi\_init\_complete** within  $t_{init\_complete}$  cycles.

---

**FIGURE 98. Frequency Change Request Acknowledge Timing Diagram**



Note: “New frequency value” is the encoded value of the new frequency after the MC completes its MC-initiated frequency change operation.

---

**FIGURE 99. Frequency Change Request Acknowledge Timing Diagram, with Optional *dfi\_cmd\_freq\_ratio*, *dfi\_data\_freq\_ratio* and *dfi\_freq\_fsp* Signals**



Note: “New frequency value” is the encoded value of the new frequency after the MC completes its MC-initiated frequency change operation, “new FSP value” is the value of the new frequency set point and “new frequency ratio value” is the encoded value of the new frequency ratio.

#### 4.11.2 Frequency Change Request Protocol - Not Acknowledged

When asserted, the MC must assert the **dfi\_init\_start** signal for at least  $t_{init\_start}$  cycles. It is important to note that the PHY is not required to respond to a frequency change request. Figure 100, “Frequency Change Request Ignored Timing Diagram” shows the MC asserting the **dfi\_init\_start** signal for  $t_{init\_start}$  cycles.

**FIGURE 100.** Frequency Change Request Ignored Timing Diagram


## 4.12 CA Parity Signaling and CA Parity, CRC Errors

Parity bits are used in command transmission for verifying that the command has been transmitted correctly on the host interface. A single parity bit is sent with each command and identifies if the number of bits set high in the **dfi\_address**, **dfi\_act\_n**, **dfi\_bg**, **dfi\_bank**, **dfi\_cas\_n**, **dfi\_ras\_n** and **dfi\_we\_n** signals is an even or an odd number. If the DRAM receives a command that the number of bits of these signals that is set to 'b1 does not match the even/odd setting of the **dfi\_parity\_in** signal, an error occurred during transmission.

The MC sends the **dfi\_parity\_in** signal, which is valid for one cycle per command. The PHY must delay the **dfi\_parity\_in** signal identically to the command bus. Consequently, the PHY sends the **dfi\_parity\_in** signal, along with the command and other DFI signals, to the DRAM interface  $t_{ctrl\_delay}$  cycles after it receives the MC **dfi\_parity\_in** signal.

The **dfi\_parity\_in** signal is sent  $t_{parin\_lat}$  cycles after the DFI command; if  $t_{parin\_lat} = 0$ , **dfi\_parity\_in** and the DFI command are sent in the same cycle. The memory systems compute parity on the incoming command and compare the computed value with the value driven on the DFI parity signal. If these values do not match, the memory systems assert a parity error output, which is sent back to the PHY. The **dfi\_alert\_n** signal is asserted within  $t_{phy\_paritylat}$  cycles of the associated **dfi\_parity\_in** signal. Since  $t_{phy\_paritylat}$  is a maximum value, the **dfi\_alert\_n** signal can not be correlated to one specific command, but to any command sent within the last  $t_{phy\_paritylat}$  cycles.

Figure 101, “Odd Command Parity Error Example Timing Diagram” shows the timing between the command and error with an odd command parity example.

**FIGURE 101.** Odd Command Parity Error Example Timing Diagram


#### **4.12.1 CA Parity Timing**

The DFI protocol supports CA parity utilizing the **dfi\_parity\_in** signal to transmit the parity data across the DFI. The MC generates the **dfi\_parity\_in** signal and sends it across the DFI. The PHY transmits the signal to the memory subsystem, incorporating the same **t\_ctrl\_delay** as the command bus.

In frequency ratio systems, the **dfi\_parity\_in** signal is defined per phase, similar to the CA bus. For example, in a 1:2 frequency ratio system, the parity data is sent on **dfi\_parity\_in\_p0** and **dfi\_parity\_in\_p1**.

To generalize the parity support for current and future parity implementations, the **t\_parin\_lat** parameter, defined in Table 23, “Status Interface Signals”, specifies the timing of the **dfi\_parity\_in\_pN** signal relative to the DFI command. The **t\_parin\_lat** parameter, allows the parity data to be sent coincident with the command or on a subsequent cycle.

#### **4.12.2 CA Parity and CRC Errors**

The DRAM generates both CA parity and CRC errors. The error signals are transferred across the DFI bus to the MC. In systems that require CA parity or CRC support, the MC and PHY must both support the **dfi\_alert\_n** error signal.

The active low **dfi\_alert\_n** signal transmits both CA parity and write CRC errors. The PHY is not required to distinguish between a CA parity and a CRC error, instead, the PHY transmits the error to the MC for evaluation. The PHY holds the current state of the **dfi\_alert\_n** signal until the PHY error input transitions to a new value. Consequently, the pulse width of **dfi\_alert\_n** matches the pulse width of the DRAM subsystem error signal, plus or minus any synchronization cycles.

#### **4.12.3 CA Parity and CRC Errors in Frequency Ratio Systems**

With frequency ratio systems, multiple **dfi\_alert\_n** outputs from the PHY are required to accurately transfer the error pulse width.

Table 49, “**dfi\_alert\_n** Signal With Matched and Frequency Ratio Systems” defines the outputs for matched frequency, 1:2 frequency ratio, 1:4 frequency ratio and 1:8 frequency ratio systems. In all cases, the PHY must synchronize the **dfi\_alert\_n** outputs to the DFI clock domain. During synchronization, the width of the DRAM error signal may change by a few cycles, and these small changes in the error pulse width are acceptable.

---

**TABLE 49. *dfi\_alert\_n* Signal With Matched and Frequency Ratio Systems**

| System            | Alert Outputs                                  | Description                                                                                                                                                                                                                                                                                                  |
|-------------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Matched Frequency | <b>dfi_alert_n</b>                             | Single Output<br>Width of output indicates width of error pulse +/- synchronization errors.                                                                                                                                                                                                                  |
| 1:2 Frequency     | <b>dfi_alert_n_a0</b><br><b>dfi_alert_n_a1</b> | 2 outputs, one for each phase of the DFI clock.<br>Combination of signals is used for determining error pulse width.<br>For example, <b>dfi_alert_n_a0</b> and <b>dfi_alert_n_a1</b> are both asserted for one DFI clock period. The error signal width is 2 host command clocks +/- synchronization errors. |

**TABLE 49.** *dfi\_alert\_n* Signal With Matched and Frequency Ratio Systems

| System        | Alert Outputs                                                                                                                                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:4 Frequency | <b>dfi_alert_n_a0</b><br><b>dfi_alert_n_a1</b><br><b>dfi_alert_n_a2</b><br><b>dfi_alert_n_a3</b>                                                                                                     | 4 outputs, one for each phase of the DFI clock.<br>Combination of signals is used for determining error pulse width.<br>For example, <b>dfi_alert_n_a0</b> , <b>dfi_alert_n_a1</b> , <b>dfi_alert_n_a2</b> and <b>dfi_alert_n_a3</b> are all asserted for one DFI clock period. The error signal width is 4 host command clocks +/- synchronization errors.<br>As another example, only <b>dfi_alert_n_a1</b> and <b>dfi_alert_n_a2</b> are asserted for one DFI clock period. The error signal width is 2 host command clocks +/- synchronization errors.                                                                                                 |
| 1:8 Frequency | <b>dfi_alert_n_a0</b><br><b>dfi_alert_n_a1</b><br><b>dfi_alert_n_a2</b><br><b>dfi_alert_n_a3</b><br><b>dfi_alert_n_a4</b><br><b>dfi_alert_n_a5</b><br><b>dfi_alert_n_a6</b><br><b>dfi_alert_n_a7</b> | 8 outputs, one for each phase of the DFI clock.<br>Combination of signals is used for determining error pulse width.<br>For example, <b>dfi_alert_n_a0</b> , <b>dfi_alert_n_a1</b> , <b>dfi_alert_n_a2</b> , <b>dfi_alert_n_a3</b> , <b>dfi_alert_n_a4</b> , <b>dfi_alert_n_a5</b> , <b>dfi_alert_n_a6</b> and <b>dfi_alert_n_a7</b> are all asserted for one DFI clock period. The error signal width is 8 host command clocks +/- synchronization errors.<br>As another example, only <b>dfi_alert_n_a1</b> and <b>dfi_alert_n_a2</b> are asserted for one DFI clock period. The error signal width is 2 host command clocks +/- synchronization errors. |

In Figure 102, “dfi\_alert\_n\_aN with 1:2 Command Frequency Ratio”, the 1st assertion of the DRAM or DIMM error signal (host **alert\_n**) is held for 2 host command clocks, but due to synchronization, only **dfi\_alert\_n\_a0** is asserted on the DFI bus, indicating a single host command clock period pulse. The 2nd assertion of the DRAM or DIMM error signal is held for multiple cycles and the DFI output indicates this functionality by asserting both **dfi\_alert\_n\_a0** and **dfi\_alert\_n\_a1** as required. The **dfi\_alert\_n\_a0** and **dfi\_alert\_n\_a1** signals correlate to the phase of the DFI clock. However, the assertion of **dfi\_alert\_n\_a0** does not directly relate to the phase of assertion on the host interface and therefore the assertion of **dfi\_alert\_n\_a0** is not directly related to the phase of the write data.

**FIGURE 102.** *dfi\_alert\_n\_aN* with 1:2 Command Frequency Ratio

This timing diagram includes both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain.  
1. In the MC diagram, the timing shows the DFI bus signaling.  
2. In the PHY diagram, the timing illustrates how the PHY interprets the DFI bus. PHY timing is shown for illustrative purposes only.

## 4.13 Low Power Control Handshaking

If the PHY has knowledge that the DFI will be idle for a period of time, the PHY may be able to enter an MC-initiated low power state. During low power handshaking, the DFI clock must maintain a valid and constant clock operating frequency until **dfi\_lp\_ctrl\_req**, **dfi\_lp\_ctrl\_ack** and **dfi\_lp\_ctrl\_wakeup** OR **dfi\_lp\_data\_req**, **dfi\_lp\_data\_ack** and **dfi\_lp\_data\_wakeup** have reached a constant state.

When the MC detects an idle time, the MC asserts low power requests (control and/or data) to the PHY and wakeup signals (control and/or data) with the wakeup time required. The PHY can acknowledge the request and go into low power mode based on the wakeup time required and remain in low power mode as long as the request and acknowledge are both asserted, or the PHY can disregard the request and not change power states even if a low power opportunity request was acknowledged.

If the request is acknowledged through the assertion of the **dfi\_lp\_ctrl\_ack** or **dfi\_lp\_data\_ack** signal, the PHY may enter a low power mode as long as the **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** signal remains asserted. Once the **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** signal is de-asserted, the PHY must return to normal operating mode within the number of cycles indicated by the corresponding **dfi\_lp\_ctrl\_wakeup** or **dfi\_lp\_data\_wakeup** signal.

When **dfi\_lp\_ctrl\_req** and **dfi\_lp\_ctrl\_ack** have asserted, the MC will not de-assert **dfi\_lp\_ctrl\_req** to increase the wakeup time. In order for the PHY to recognize that the MC has increased the wakeup time, the PHY must monitor the **dfi\_lp\_ctrl\_wakeup** signal. Similarly, when the **dfi\_lp\_data\_req** and **dfi\_lp\_data\_ack** signals have asserted, the MC will not de-assert the **dfi\_lp\_data\_req** signal to increase the wakeup time and the PHY will need to monitor the **dfi\_lp\_data\_wakeup** signal.

Wakeup time is a specific number of cycles ( $t_{lp\_ctrl\_wakeup}$  or  $t_{lp\_data\_wakeup}$  cycles) in which the PHY is expected to respond to a signal change (the de-assertion of either the **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** signal) on the DFI. The DFI specification defines up to 28 different wakeup times; neither the MC nor the PHY are required to support all of the defined wakeup times. Generally, the PHY should enter the lowest supported power state that allows low power exit within the required wakeup time.

When the **dfi\_lp\_max\_wakeup** parameter is 1B, the PHY guarantees to wakeup within  $t_{lp\_ctrl\_wakeup}$  cycles and can accept commands as early as  $t_{lp\_ctrl\_wakeup}$  cycles after the de-assertion of the **dfi\_lp\_ctrl\_req** signal, as observed on its interface. If the controller waits  $t_{lp\_ctrl\_wakeup}$  cycles and accounts for propagation delays between the controller and PHY, then it does not need to internally observe the de-assertion of the **dfi\_lp\_ctrl\_ack** signal before resuming normal operation.

When the **dfi\_lp\_max\_wakeup** parameter is 1B, the PHY also guarantees to wakeup within  $t_{lp\_data\_wakeup}$  cycles and can accept data as early as  $t_{lp\_data\_wakeup}$  cycles after the de-assertion of the **dfi\_lp\_data\_req** signal, as observed on its interface. If the controller waits  $t_{lp\_data\_wakeup}$  cycles and accounts for propagation delays between the controller and PHY, then it does not need to internally observe the de-assertion of **dfi\_lp\_data\_ack** signal before resuming normal operation.

When the **dfi\_lp\_max\_wakeup** parameter is 0B, the PHY treats the wakeup time as an average or estimated delay. In this case the controller must observe **dfi\_lp\_ctrl\_ack** signal or **dfi\_lp\_data\_ack** signal de-assertion prior to resuming normal operation; exceeding the wakeup time should not be treated as an error condition.

The MC guarantees that **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** will be asserted and the **dfi\_lp\_ctrl\_wakeup** or **dfi\_lp\_data\_wakeup** signal will be constant for at least  $t_{lp\_resp}$  cycles, allowing the PHY time to respond. The PHY may respond or ignore the low power mode request. To acknowledge the request, the PHY must assert the **dfi\_lp\_ctrl\_ack** or **dfi\_lp\_data\_ack** signal within  $t_{lp\_resp}$  clock cycles of the request (control and/or data) signal assertion, during which

time the MC must hold the **dfi\_lp\_ctrl\_wakeup** or **dfi\_lp\_data\_wakeup** signal constant. Once the request has been acknowledged by the PHY, the MC may de-assert the **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** signal. The PHY is expected to de-assert the **dfi\_lp\_ctrl\_ack** or **dfi\_lp\_data\_ack** signal within the appropriate **t<sub>lp\_ctrl\_wakeup</sub>** or **t<sub>lp\_data\_wakeup</sub>** clock cycles after the **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** signal is de-asserted and be ready for normal operation.

Figure 103, “Low Power Control Handshaking Timing Diagram” shows a sequence in which the request is acknowledged. The same diagram applies to the data low power interface.

---

**FIGURE 103. Low Power Control Handshaking Timing Diagram**



Figure 104, “Low Power Control Request with No Response” shows that the **dfi\_lp\_ctrl\_ack** signal is not required to assert when the **dfi\_lp\_ctrl\_req** signal is asserted. The MC must assert the **dfi\_lp\_ctrl\_req** signal for at least **t<sub>lp\_resp</sub>** cycles. If the **dfi\_lp\_ctrl\_ack** signal is not asserted within **t<sub>lp\_resp</sub>** cycles, the PHY must not assert the acknowledge for the current request. The **dfi\_lp\_ctrl\_req** signal should be de-asserted after **t<sub>lp\_resp</sub>** cycles have elapsed without an acknowledge. The same timing diagram would apply for the data low power interface.

---

**FIGURE 104. Low Power Control Request with No Response**



After the request has been acknowledged, the MC may increase the time that the PHY has to respond beyond the time that was initially defined. The MC is allowed to change the **dfi\_lp\_ctrl\_wakeup** (or **dfi\_lp\_data\_wakeup**) signal to a larger value as long as both the **dfi\_lp\_ctrl\_ack** and **dfi\_lp\_ctrl\_req** (or **dfi\_lp\_data\_ack**/**dfi\_lp\_data\_req**) signals are asserted. This results in a longer **t<sub>lp\_ctrl\_wakeup</sub>** (or **t<sub>lp\_data\_wakeup</sub>**) time for the PHY. The value of the

---

## Functional Use

---

**dfi\_lp\_ctrl\_wakeup / dfi\_lp\_data\_wakeup** signal when the **dfi\_lp\_ctrl\_req / dfi\_lp\_data\_req** signal is de-asserted will be used to define the  $t_{lp\_ctrl\_wakeup}$  /  $t_{lp\_data\_wakeup}$  time.

Figure 105, “Low Power Control Handshaking Timing Diagram with Multiple Wakeup Times” shows a scenario with the assumption that the wakeup time is increased with each change.

**FIGURE 105. Low Power Control Handshaking Timing Diagram with Multiple Wakeup Times**



Figure 106, “Low Power State Progressing From an Active Command Interface to Inactive” illustrates **dfi\_lp\_ctrl\_req** and **dfi\_lp\_data\_req** when progressing from a low power state that requires use of the command interface into a low power state that can operate when the command interface is inactive.

**FIGURE 106. Low Power State Progressing From an Active Command Interface to Inactive**



PDE = Power-Down Enter

SRE = Self-Refresh Enter

SRX = Self-Refresh Exit

Figure 107, “Low Power State Requiring Ongoing Use of the Command Interface” illustrates **dfi\_lp\_data\_req** when entering a low power state that must continue to execute memory commands.

**FIGURE 107. Low Power State Requiring Ongoing Use of the Command Interface**



Figure 108, “Data Low Power Request Acknowledged Only”, Figure 109, “Both Data and Control Low Power Requests Acknowledged Simultaneously” and Figure 110, “Both Data and Control Low Power Requests Acknowledged, At Different Times” show four illustrations of both the control and data low power requests asserting. The requests are independent and may assert in either order or simultaneously, and the PHY may acknowledge one, both or neither - and at any point in time. There is no requirement that the PHY has to respond in either order.

**FIGURE 108. Data Low Power Request Acknowledged Only**



**FIGURE 109.** Both Data and Control Low Power Requests Acknowledged Simultaneously**FIGURE 110.** Both Data and Control Low Power Requests Acknowledged, At Different Times

## 4.14 Error Signaling

The optional DFI error interface enables the PHY to communicate error information from the PHY to the MC.

For data errors, the timing parameter is defined as the max delay from **dfi\_wrdata\_en** or **dfi\_rddata\_en** to the assertion of the **dfi\_error** signal.

For command errors, the timing parameter is defined as the max delay from command to the assertion of the **dfi\_error** signal. Since the timing parameter is a maximum delay, it is not always possible to correlate the error with a specific command.

Figure 111, “Example of Error Condition” shows the error interface. The error condition does not affect RD A and RD B, and may affect RD C and/or RD D.

---

**FIGURE 111. Example of Error Condition**



Table 50, “Error Codes” defines specific error codes, error codes reserved for future use, and error codes available for design-specific definition. Not all defined error codes apply to all systems and all error types are optional unless required as part of another interface.

If multiple errors occur in a single clock cycle, the PHY is responsible for resolving communication through error prioritization, using multiple clocks, or through another means.

---

**TABLE 50. Error Codes**

| Error Response Code | Name            | Description                                          |
|---------------------|-----------------|------------------------------------------------------|
| 0000                | General purpose | The PHY indicates a general purpose error.           |
| 0001                | Internal PHY    | The PHY indicates some internal error condition.     |
| 0010 - 0111         | Reserved        | Reserved for a future definition.                    |
| 1000 - 1111         | User-defined    | These error codes are available for user definition. |

## 4.15 PHY Control of the DFI Bus

The PHY managed interface enables the PHY to request control of the DFI bus. The procedure to use this interface is as follows:

1. The PHY asserts the **dfi\_phymngd\_req** signal along with the **dfi\_phymngd\_cs\_state** and **dfi\_phymngd\_state\_sel** signals to indicate to the MC the state of the memory required before handing off the bus. The PHY drives **dfi\_phymngd\_type** to indicate to the MC the length of time that it is requesting control.
2. If the **dfi\_phymngd\_cs\_state** signal is cleared, the MC places the DRAM in the state specified in the **dfi\_phymngd\_state\_sel** signal.
3. The MC asserts **dfi\_phymngd\_ack** within  $t_{phymngd\_resp}$  cycles of the assertion of **dfi\_phymngd\_req** in most cases. Exceptions are granted if **dfi\_phyupd\_ack**, **dfi\_lp\_ctrl\_req** or **dfi\_lp\_data\_req** are active along with **dfi\_phyupd\_req**. Refer to Section 4.21, “DFI Interactions” for details.
4. The MC de-asserts the **dfi\_phymngd\_ack** signal upon sampling the **dfi\_phymngd\_req** signal low.

If the PHY does not de-assert the **dfi\_phymngd\_req** signal within  $t_{phymngd\_typeX}$  cycles (where X was the value of the **dfi\_phymngd\_type** signal) following the assertion of the **dfi\_phymngd\_ack** signal, a DFI protocol violation occurs.

5. The PHY must return control of the DFI bus to the MC with DRAM in the identical state that it received it, including the state of memory. Also, all memory pages must be closed, and the refresh count must correspond with the MC refresh count.

Figure 112, “PHY Managed Interface Timing” illustrates the new interface timing.

---

**FIGURE 112. PHY Managed Interface Timing**



If refreshes are required, the MC is responsible for maintaining all refresh timing requirements and sending out refresh commands. This is the only commands that may be sent on the DFI bus while the **dfi\_phymngd\_req** and **dfi\_phymngd\_ack** signals are asserted. If the MC passes the memory to the PHY in the self refresh state, no refreshes are issued during the PHY managed mode.

To meet DRAM refresh timing requirements the MC and the PHY perform the following steps:

1. The MC performs following actions:
  - a. The MC sends refresh commands as required on the DFI bus.
  - b. The MC must maintain all refresh timing requirements relative to a refresh command that is issued during PHY managed mode.
  - c. The MC takes into account the PHY delay ( $t_{phymngd\_rfsh}$  parameter) for meeting all DRAM refresh timing.
2. The PHY performs following actions:
  - a. The PHY generates a refresh command to the DRAM within  $t_{phymngd\_rfsh}$  cycles.
  - b. The PHY ensures that all DRAM refresh timings are met.
  - c. The PHY ensures that all DRAM refresh timings have expired before it returns control to the MC.

Figure 113, “Refresh Timing” illustrates the new refresh timing.

**FIGURE 113.** Refresh Timing

## 4.16 DFI Disconnect Protocol

The DFI disconnect protocol can be used to break up a handshake between two DFI signals. There are eight affected interfaces. When the disconnect is issued, the user will specify if the disconnect will leave the system in a fully operational state (QOS), or if the system is no longer guaranteed to be operational (error condition). This information is conveyed through the **d<sub>i</sub>\_disconnect\_error** signal. The **d<sub>i</sub>\_disconnect\_error** signal must be valid on the same clock as the disconnect and remain unchanged until the disconnecting device completes the disconnection. The signal is not meaningful at any other time.

### 4.16.1 Update Interface

There are two handshakes in the update interface: controller-initiated updates and PHY-initiated updates. For both, when the request and acknowledge signals are asserted, only the PHY can disconnect the handshake. Although there are timing parameters to define the maximum handshake time ( $t_{phyupd\_typeX}$ ,  $t_{ctrlupd\_min}$ ), the delay might be unacceptably long in some cases.

To break either handshake, the MC will violate the protocol and de-assert the **d<sub>i</sub>\_ctrlupd\_req** or the **d<sub>i</sub>\_phyupd\_ack** signal. The de-assertion of either signal indicates to the PHY that the MC intends to disconnect the handshake. For a controller-initiated update disconnect, the MC must assume that the PHY did not complete the requested operation, and that a subsequent request should be scheduled. This requires meeting  $t_{ctrlupd\_interval}$  timing.

The **d<sub>i</sub>\_disconnect\_error** signal defines if the disconnect is an error condition or a QOS event. The value of this signal when the disconnect occurs (the de-assertion of the **d<sub>i</sub>\_ctrlupd\_req** or **d<sub>i</sub>\_phyupd\_ack** signal) determines the expected system behavior:

- If the **d<sub>i</sub>\_disconnect\_error** signal is de-asserted (QOS), the PHY must de-assert the corresponding signal (**d<sub>i</sub>\_ctrlupd\_ack** or **d<sub>i</sub>\_phyupd\_req**) within  $t_{ctrlupd\_disconnect}$  or  $t_{phyupd\_disconnect}$  clocks. At that point, the PHY must be fully operational.
- If the **d<sub>i</sub>\_disconnect\_error** signal is asserted (error), the PHY must de-assert the corresponding signal (**d<sub>i</sub>\_ctrlupd\_ack** or **d<sub>i</sub>\_phyupd\_req**) within  $t_{ctrlupd\_disconnect\_error}$  or  $t_{phyupd\_disconnect\_error}$  clocks. The state of the PHY that follows the disconnect error condition is defined by the PHY and should be stated in the PHY specification. Ideally, the PHY disconnects on a boundary that preserves the most memory service possible.

NOTE: In previous versions of the DFI interface, the signaling that is defined for disconnect is an illegal operation.

Figure 114, “PHY Update Request, QOS Disconnect Protocol” and Figure 115, “PHY Update Request, Error Disconnect Protocol” illustrate the new disconnect signaling protocol.

**FIGURE 114.** PHY Update Request, QOS Disconnect Protocol**FIGURE 115.** PHY Update Request, Error Disconnect Protocol

#### 4.16.2 PHY Managed Interface

The PHY managed interface includes a request and acknowledge signal, with the PHY driving the request signal to the MC and the MC responding with the acknowledgement. Although there are timing parameters to define the maximum handshake time ( $t_{phymngd\_typeX}$ ), the delay might be unacceptably long in some cases.

To break the handshake, the MC will de-assert the **dfi\_phymngd\_ack** signal. The de-assertion of this signal indicates to the PHY that the MC intends to disconnect the handshake.

The **dfi\_disconnect\_error** signal defines if the disconnect is an error condition or a QOS event. The value of this signal when the disconnect occurs (the de-assertion of the **dfi\_phymngd\_ack** signal) determines the expected system behavior:

- If the **dfi\_disconnect\_error** signal is de-asserted (QOS), the PHY must de-assert the **dfi\_phymngd\_req** signal within  $t_{phymngd\_disconnect}$  clocks. At that point, the PHY must be fully operational.
- If the **dfi\_disconnect\_error** signal is asserted (error), the PHY must de-assert the **dfi\_phymngd\_req** signal within  $t_{phymngd\_disconnect\_error}$  clocks. The state of the PHY that follows the disconnect error condition is defined by the PHY and should be stated in the PHY specification. Ideally, the PHY disconnects on a boundary that preserves the most memory service possible.

NOTE: In previous versions of the DFI interface, the signaling that is defined for disconnect is an illegal operation.

Figure 116, “PHY Managed Interface, QOS Disconnect Protocol” illustrates the new disconnect signaling protocol.

**FIGURE 116.** PHY Managed Interface, QOS Disconnect Protocol

## 4.17 2N Mode

Some memories support a 2N mode (also referred to as geardown mode in DDR4 memories) in which the command's alignment with the memory clock is altered and the command should be aligned to the command's first clock rising edge to center on the command's second clock rising edge. The DFI specification includes a **dfi\_2n\_mode** signal to support this behavior.

### 4.17.1 Use of 2N Mode

To enter 2N mode on DFI, the MC enters the DRAM 2N mode. If synchronization is required, when the **t\_ctrl\_delay** time elapses from the defined sync pulse, the MC will assert the **dfi\_2n\_mode** signal. If synchronization is not required, the MC will assert **dfi\_2n\_mode** following the command to place the DRAM in 2N mode. The CA bus signals must be maintained in an idle or de-select state or both for the time defined in the **t<sub>2n\_mode</sub>\_delay** parameter. During this time, the PHY makes adjustments in CA and/or CS timing. To exit 2N mode, the same timing applies, no synchronization is required.

For DDR4, when **dfi\_2n\_mode** = 'b1, the MC must drive command CA and CS signals for two Command clocks - for two DFI clocks in a matched frequency configuration, or for two phases in a Command Frequency Ratio configuration.

For DDR5 without RCD, when **dfi\_2n\_mode** = 'b1, the MC must drive CA signals for two Command clocks - for two DFI clocks in a matched frequency configuration, or for two phases in a Command Frequency Ratio Configuration.

For DDR5 with RCD, when **dfi\_2n\_mode** = 'b0, the MC must drive CA signals following double data rate rules, and when **dfi\_2n\_mode** = 'b1, the MC must drive CA signals following single data rate rules. (Refer to Section 4.7.6, "CA Bus Timing" for more information.) The PHY does not make additional adjustments to the DCA to DCK timing.

For DDR5 MRDIMM, the **dfi\_2n\_mode** signal is used to indicate whether the CA bus uses double data rate (**dfi\_2n\_mode** = 'b0) or single data rate (**dfi\_2n\_mode** = 'b1) operation. In Rank Mode, this operates the same as DDR5 with RCD. In Mux mode, **dfi\_2n\_mode** = 'b0 in both 1N and 2N mode, however in 1N mode, the **dfi\_cmd\_freq\_ratio** signal equals the **dfi\_data\_freq\_ratio** signal, and in 2N mode the **dfi\_cmd\_freq\_ratio** signal is half of the **dfi\_data\_freq\_ratio** signal. (Refer to Section 4.7.6, "CA Bus Timing" for more information.) The PHY does not make additional adjustments to the DCA to DCK timing.

Several timing diagrams follow. These timing diagrams include both the MC timing and an illustration of how the PHY interprets the timing in the Memory Clock domain. In these figures, the signals are shown changing on the positive clock edge. In the MC clock portion, the timing shows the DFI bus signaling. In the Memory portion, the timing illustrates how the PHY interprets the DFI bus. Memory timing is shown for illustrative purposes only.

---

## Functional Use

---

Figure 117, “Illustration of DDR4 read in 1N Mode” and Figure 118, “Illustration of DDR4 read in 2N Mode” illustrate the differences between 1N and 2N mode commands for DDR4 on DFI.

---

**FIGURE 117. Illustration of DDR4 read in 1N Mode**



---

**FIGURE 118. Illustration of DDR4 read in 2N Mode**



Figure 119, “Illustration of DDR5 without RCD read in 1N Mode” and Figure 120, “Illustration of DDR5 without RCD read in 2N Mode with DDR5 CS Geardown Disabled” illustrate the differences between the modes for DDR5 without RCD on DFI.

**FIGURE 119.** Illustration of DDR5 without RCD read in 1N Mode

**FIGURE 120.** Illustration of DDR5 without RCD read in 2N Mode with DDR5 CS Geardown Disabled


Figure 121, “Entering 2N Mode with a Sync Command; DDR4 with Matched Command Frequency Ratio” and Figure 122, “Entering 2N Mode with a MPC command; DDR5 without RCD, 1:2 Command Frequency Ratio, with CS Geardown Disabled” illustrate the difference in entering 2N mode with and without issuing a sync command.

**FIGURE 121.** Entering 2N Mode with a Sync Command; DDR4 with Matched Command Frequency Ratio

**FIGURE 122.** Entering 2N Mode with a MPC command; DDR5 without RCD, 1:2 Command Frequency Ratio, with CS Geardown Disabled


#### 4.17.2 Use of DDR5 CS Geardown Mode with 2N Mode

Some DDR5 memories support a CS geardown mode in which the CS alignment with the memory clock is altered and the command should be aligned to the command's first clock rising edge to center on the command's second clock rising edge. DDR5 memories that support CS geardown are required to utilize 2N command timing when CS geardown is enabled. However, since 2N command timing does not require CS geardown, the DFI specification includes a **dfi\_cs\_geardown** signal to support this independent behavior.

To enter CS geardown mode on the DFI, the MC enters the DRAM CS geardown mode. If synchronization is required, then when the  $t_{ctrl\_delay}$  time elapses from the defined sync pulse, the MC will assert the **dfi\_cs\_geardown** signal. The

---

## Functional Use

---

CA bus signals must be maintained in an idle or de-select state or both for the time defined in the **t<sub>cs\_gardown\_delay</sub>** parameter. During this time, the PHY makes adjustments in CS timing. To exit CS gardown mode, the same timing applies, no synchronization is required.

For DDR5, when the **d<sub>fi</sub>\_cs\_gardown** signal = 'b1, the MC must drive CS signals for two Command clocks - for two DFI clocks in a matched frequency configuration, or for two command phases in a Frequency Ratio Configuration.

Figure 123, “Illustration of DDR5 without RCD read in 2N Mode with DDR5 CS Gardown Enabled” illustrates how a command should be sent from the DFI interface to be correctly sampled by the DRAM when the gardown mode is enabled. This figure shows an alignment with DFI phase 0.

---

**FIGURE 123. Illustration of DDR5 without RCD read in 2N Mode with DDR5 CS Gardown Enabled**



Figure 124, “DDR5 Self-Refresh Exit Sequence in 2N Mode with DDR5 CS Gardown Enabled” includes both the MC timing and an illustration of how the PHY interprets the timing in the Memory Clock domain. In this figure, the signals are shown changing on the positive clock edge. In the MC clock portion, the timing shows the DFI bus signaling. In the Memory portion, the timing illustrates how the PHY interprets the DFI bus. Memory timing is shown for illustrative purposes only. The DRAM state at the start of this timing diagram is Self-refresh. The DFI Command “SR” state is for illustration purposes only. If the NOP starts on an even DFI phase, any subsequent command must start on an even DFI phase. If the NOP starts on an odd DFI phase, any subsequent command must start on an odd DFI phase.

**FIGURE 124.** DDR5 Self-Refresh Exit Sequence in 2N Mode with DDR5 CS Geardown Enabled


#### 4.18 Use of the MC to PHY Message Interface

The MC to PHY message interface handles the transmission of encoded messages from the MC to the PHY. Messages may be pre-defined or device-specific messages. Both the controller and PHY should support encodings for all messages that are supported by the device.

When the **dfi\_ctrlmsg\_req** signal is asserted, the PHY can ignore the request, or if it chooses to respond, it must assert the **dfi\_ctrlmsg\_ack** within **t<sub>ctrlmsg\_resp</sub>** DFI clocks. Once asserted, the **dfi\_ctrlmsg\_ack** may de-assert at any time. If the PHY wants to prevent additional messages, it may continue to drive the **dfi\_ctrlmsg\_ack** signal for up to **t<sub>ctrlmsg\_max</sub>** DFI clocks. As long as **dfi\_ctrlmsg\_ack** is asserted, the **dfi\_ctrlmsg\_req** signal must remain asserted and should de-assert immediately if the **dfi\_ctrlmsg\_ack** signal is de-asserted; sufficient delay is allowed to account for pipelining and clock domains and no specific timing requirement is defined.

If the PHY does not acknowledge the request within **t<sub>ctrlmsg\_resp</sub>** cycles, the PHY must not acknowledge the request at all. In this case, the controller should de-assert the **dfi\_ctrlmsg\_req** signal. The **dfi\_ctrlmsg\_req** signal must remain de-asserted for at least one DFI clock before issuing another request.

While the **dfi\_ctrlmsg\_req** signal is asserted, the **dfi\_ctrlmsg** and **dfi\_ctrlmsg\_data** signals must remain static. When the **dfi\_ctrlmsg\_req** signal is de-asserted, the **dfi\_ctrlmsg** and **dfi\_ctrlmsg\_data** signals are in a “don’t\_care” state. If the PHY asserts the **dfi\_ctrlmsg\_ack** signal, the PHY has received the message. If the PHY does not assert the **dfi\_ctrlmsg\_ack** signal, the PHY may or may not have received the message.

There is not a defined response from the MC or PHY regarding messages sent and no implied timing for a response or any action in response to the message. The message bus is informational and the corresponding activity is implementation-specific.

The assertion of the **dfi\_ctrlmsg\_req** and/or **dfi\_ctrlmsg\_ack** signals cannot block the operation of the other interfaces on the DFI bus; messages should be sent in parallel to other DFI operations. The specific behavior of the MC to PHY message interface relative to other interfaces is detailed as follows:

- **PHY Managed and Update Interface:** DFI messages are permitted during update or PHY managed interface activity.
- **Low Power Interface:** The MC may send messages in a low power state if the wakeup time is below the **dfi\_ip\_wakeup\_threshold** value. If the PHY is in the defined low power state corresponding to the wakeup time or a larger wakeup time, the MC should not issue a message request.
- **Frequency Change Protocol:** When a frequency change is acknowledged, any pending messages can be canceled. The PHY should not acknowledge a message once a frequency change has been acknowledged until the frequency change handshake has completed.

#### **4.18.1 Timing Diagram**

Figure 125, “MC to PHY Message Handshaking Timing Diagram” shows the timing relationship between the MC to PHY message interface signals.

---

**FIGURE 125. MC to PHY Message Handshaking Timing Diagram**



#### **4.18.2 PHY Messages**

For compatibility between a DFI controller and a DFI PHY, a standard set of messages is defined. Additional message encodings will be defined by the device, or those settings will be reserved. Table 51, “Controller Message Codes” defines the command encodings.

---

**TABLE 51. Controller Message Codes**

| Message Code | Name                   | Description                                       |
|--------------|------------------------|---------------------------------------------------|
| 0x00         | Command Bus Training   | Training the CA bus relative to the memory clock. |
| 0x01         | Read Data Eye Training | Training the DQ bus to the DQS                    |
| 0x02         | Read Gate Training     | Training the read DQS to the DQS gate             |
| 0x03         | CS Training            | Training the chip select timing                   |
| 0x04         | Write Leveling         | Training the write DQ to the DQS                  |

**TABLE 51.** Controller Message Codes

| Message Code | Name                              | Description                                                            |
|--------------|-----------------------------------|------------------------------------------------------------------------|
| 0x05         | Write Data Eye Training           | Training the write DQ to the DQS                                       |
| 0x06         | DB Bus Training                   | Training the Data Buffer                                               |
| 0x07         | ZQ Calibration                    | Output driver and termination calibration                              |
| 0x08         | DQS Interval Oscillator           | Evaluation of the DQS timing                                           |
| 0x09         | WCK2CK Internal Oscillator Input  | Evaluation of WCK input timing                                         |
| 0x0a         | WCK2CK Internal Oscillator Output | Evaluation of WCK output timing                                        |
| 0x0b - 0x1f  | Reserved                          | Future expansion                                                       |
| 0x20-0x3f    | Device-specific                   | Defined by the MC and the PHY. These should be programmatically mapped |
| 0x40 - 0xff  | Reserved                          | Future expansion                                                       |

#### 4.18.3 Information Data Signal

Additional information may be required for each message. The **dfi\_ctrlmsg\_data** signal provides additional information, if required, for the message. The data field may be uniquely defined per message. The message data signal width is 16 bits. The lower bits define whether the message is to a single rank or all ranks. Other encodings, such as 2 ranks, are not supported. The physical and logic ranks are encoded; these encodings are ignored if the corresponding all rank bit is set.

For device-specific message encodings, the data coding can be customized to the message. Additional fields are available for device-specific usage and reserved for future expansion. Table 52, “Data Signal Codes” defines the data signal for each command.

**TABLE 52.** Data Signal Codes

| Field        | Data Coding | Description                                                                                                                                                                                                      |
|--------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit [0]      | 0, 1        | <ul style="list-style-type: none"><li>• 'b0 = Signal physical rank as defined by bits [7:4]</li><li>• 'b1 = All physical ranks</li></ul> <p>In a single-rank system, this bit should be set to 'b1.</p>          |
| Bit [1]      | 0, 1        | <ul style="list-style-type: none"><li>• 'b0 = Signal logical rank as defined by bits [11:8]</li><li>• 'b1 = All logical ranks</li></ul> <p>If a 3DS device is not being used, this bit should be set to 'b1.</p> |
| Bits [3:2]   | Reserved    |                                                                                                                                                                                                                  |
| Bits [7:4]   | 0x0 - 0xf   | Target physical rank; this field is ignored if Bit [0] = 1                                                                                                                                                       |
| Bits [11:8]  | 0x0 - 0xf   | Target logical rank; this field is ignored if Bit [1] = 1                                                                                                                                                        |
| Bits [15:12] | 0x0 - 0x7   | Defined by device                                                                                                                                                                                                |
|              | 0x8-0xf     | Reserved                                                                                                                                                                                                         |

#### 4.19 Use of the WCK Control Interface

For WCK free running operation, the **dfi\_wck\_en** signal and timing parameters are the same. The WCK must be synchronized initially and following commands that cause the WCK to stop. When the DFI interface changes ownership

---

## Functional Use

---

between the MC and PHY, the WCK clock must be in the DISABLED state. This applies to both the normal and free running mode and to the following interfaces: initialization, frequency change, PHY managed, PHY update, and Controller update.

The timing diagrams that follow include both the MC timing and an illustration of how the PHY interprets the MC timing in the PHY clock domain. In these figures, the signals are shown changing on the positive clock edge. In the MC clock diagrams, the timing shows the DFI bus signaling. In the DRAM clock diagrams, the timing illustrates how the DRAM interprets the DFI bus. DRAM timing is shown for illustrative purposes only.

Figure 126, “WCK Timing, Read 1:1 Command and 1:4 Data Ratio Timing Diagram” shows the read timing relationship in a 1:1 command and 1:4 data ratio system.

---

**FIGURE 126. WCK Timing, Read 1:1 Command and 1:4 Data Ratio Timing Diagram**



Figure 127, “WCK Timing for a Write, 1:1 Command and 1:2 Data Frequency Ratio, 2 Rank Timing Diagram” shows the write timing relationship in a 1:1 command and 1:2 data ratio system.

**FIGURE 127. WCK Timing for a Write, 1:1 Command and 1:2 Data Frequency Ratio, 2 Rank Timing Diagram**



For WCK free-running operation, the WCK is initially synchronized in the same manner as normal operation. In this mode, certain commands will stop the WCK in the DRAM. In these cases, the same signal and timing applies to WCK disable as defined for normal operations;  $t_{wck\_dis}$  timing applies from the issuance of the command that stops the WCK.

When the DFI interface changes ownership between the MC and PHY, the WCK clock must be in the DISABLED state. This applies to both the normal and free running mode and to the following interfaces: initialization, frequency change, PHY Managed, PHY update, and Controller update.

The write X function is an optional feature in LPDDR5 devices used for reducing power in write operations of repeated data patterns of all 0s or 1s. With a Write X command, the MC must drive the **dfi\_wrdata\_en** signal low and the

**dfi\_wrdata, dfi\_wrdata\_mask / dfi\_wrdata\_cs** signals are all in a don't care state. The MC will need to generate the **dfi\_wck\_en** signal with CAS-WRX as shown in Figure 128, "LPDDR5 WriteX Function".

**FIGURE 128. LPDDR5 WriteX Function**



## 4.20 Channel Operation for Multi-Channel Memories

Certain memories can operate with independent or combine channels. If used in combined mode, the setting of the **phy\_channel\_en** programmable parameter indicates whether the PHY connects to a single channel or both channels when it operates in combined mode.

### 4.20.1 Fully Independent Operation

Figure 129, "LPDDR4 Independent Channels" illustrates how an LPDDR4 device could be connected for fully independent channels. The MC can represent one or two memory controllers. The memory reset is shared, so the MC

must ensure that all DFI channels change their **dfi\_reset\_n** signals to the PHY simultaneously. The system can use any reset signal.

---

**FIGURE 129. LPDDR4 Independent Channels**



#### 4.20.2 Fully Combined Operation

For fully combined operation, a common command is driven across multiple channels and data is combined into a multi-channel wide bus. On the DFI bus, the PHY will be connected to multiple channels of read and write data sub-interfaces. All signals for all channels must be present and operational as defined for these sub-interfaces. For all other DFI sub-interfaces (control, update, status, low power) the MC or PHY can connect to one channel's sub-interfaces or to all channels' sub-interfaces, operating in lock-step. The connectivity is defined by a programmable parameter, **phy\_channel\_en**. If the MC or PHY optionally only implements a single shared copy of a sub-interface, this programmable parameter does not apply.

If the MC or PHY is connected to a single interface, the multi channel lock-step operation is easily maintained. Alternatively, if the MC or PHY connects to all channels, but always generates the same responses to all channels (for example, if the same signal is fanned out to all channels), the lock-step operation is maintained. For combined operation with the PHY connected to a single host command channel, Figure 130 applies. The MC can represent one or two memory controllers.

**FIGURE 130.** LPDDR4 Combined Channels

For combined operation with the PHY connected to all command channels, Figure 129 can still apply if the command signals from the MC to the PHY are identical for both channels. However, if the MC or PHY connects to all channels, and the MC or PHY driven signals on the DFI channels operate independently (and might be different) for any sub-interface, the system's operational mode is semi-independent.

#### 4.20.3 Semi-Independent Operation

Figure 131, “Semi-Independent Channel Interfaces” illustrates how a device could be connected for semi-independent operation, using a mixture of combined/shared and independent interfaces.

**FIGURE 131.** Semi-Independent Channel Interfaces

Using multiple channels for some sub-interfaces, and only a single channel for other sub-interfaces, is permitted. Refer to the Figure 42, “DFI Sub-interface Channel Mode Parameters”. Unused interfaces should be tied inactive.

If the MC and PHY do not use the same mode on a sub-interface, special handling is required. This is outside the scope of DFI. It is the system integrator’s responsibility to resolve.

NOTE: A channel can be disabled, but a single interface within a channel cannot be disabled.

#### 4.20.4 Multi-Configuration Support

It might be desirable for MCs and PHYs to be able to operate in both an independent and combined mode of operation. For interoperability, it would be preferable to define the device, MC or PHY, that is responsible for multiplexing the bus when supporting both independent and combined operations. The recommendation is placing the burden for multiplexing within the MC rather than the PHY.

NOTE: It is also possible to achieve the same system by using external multiplexing on the DFI interface.

Figure 132, “Example of LPDDR4 Multi-Configuration” illustrates the MC multiplexing the DFI bus for operating in both modes. Combined operation means a single MC (MC0), and independent operation means two MCs (MC0 and

MC1). The MC block internally multiplexes the command and data for MC0 and MC1, and no multiplexing of the command and data is required within the PHY.

---

**FIGURE 132.** Example of LPDDR4 Multi-Configuration



When operating in combined mode, the DFI channels operate in lock-step. In this mode, the PHY can either connect to the interfaces for all channels (as Figure 129 and Figure 130 show), or connect to a single interface. When connecting to a single interface, the other channels can be disabled. When using only a single channel, channel 0 should be used and other channels disabled.

## 4.21 DFI Interactions

This section describes how interactions between the Update, Status, PHY Managed and Low Power Interfaces should be handled.

**TABLE 53.** *DFI Interactions*

| Rules                                                                                                                                                                                        | During Interactions Between |                        | Exceptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{phyupd\_resp}$ ,<br>$t_{phymngd\_resp}$                                                                                                                                                  | <b>dfi_phyupd_req</b>       | <b>dfi_phymngd_req</b> | The PHY is permitted to have both <b>dfi_phyupd_req</b> and <b>dfi_phymngd_req</b> asserted. If the MC asserts <b>dfi_phymngd_ack</b> first, it must assert <b>dfi_phyupd_ack</b> within $t_{phyupd\_resp}$ of de-asserting <b>dfi_phymngd_ack</b> . If the MC asserts the <b>dfi_phyupd_ack</b> first, it must assert <b>dfi_phymngd_ack</b> within $t_{phymngd\_resp}$ cycles of de-asserting the <b>dfi_phyupd_ack</b> signal.<br><br>The MC must never have both <b>dfi_phyupd_ack</b> and <b>dfi_phymngd_ack</b> asserted.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| MC requirement to assert<br><b>dfi_phyupd_ack</b> in response to<br><b>dfi_phyupd_req</b><br><br>PHY requirement to maintain<br><b>dfi_phyupd_req</b> until<br><b>dfi_phyupd_ack</b> asserts | <b>dfi_phyupd_req</b>       | <b>dfi_init_start</b>  | If <b>dfi_init_start</b> and <b>dfi_phyupd_req</b> are both asserted, the MC is permitted to not assert <b>dfi_phyupd_ack</b> . In this case, the PHY should de-assert <b>dfi_init_complete</b> to initiate the frequency change protocol. In this case it must also de-assert the <b>dfi_phyupd_req</b> signal before asserting the <b>dfi_init_complete</b> signal again.<br><br>Alternately, if the <b>dfi_init_start</b> and the <b>dfi_phyupd_req</b> signals are both asserted, the PHY may not de-assert the <b>dfi_init_complete</b> signal. In this case, after $t_{init\_start}$ , the frequency change request is not accepted and the MC must assert the <b>dfi_phyupd_ack</b> signal before $t_{phyupd\_resp}$ . The timing value $t_{phyupd\_resp}$ must be defined large enough to accommodate this behavior.<br><br>The MC must never have both the <b>dfi_init_start</b> and the <b>dfi_phyupd_ack</b> signals asserted together. |
| MC requirement to assert<br><b>dfi_phyupd_ack</b> in response to<br><b>dfi_phyupd_req</b>                                                                                                    | <b>dfi_phyupd_req</b>       | <b>dfi_ctrlupd_req</b> | If <b>dfi_phyupd_req</b> and <b>dfi_ctrlupd_req</b> are both asserted, the PHY may assert <b>dfi_ctrlupd_ack</b> ; the PHY then has the option to keep <b>dfi_phyupd_req</b> asserted or to de-assert <b>dfi_phyupd_req</b> . If the PHY keeps <b>dfi_phyupd_req</b> asserted, the MC should assert <b>dfi_phyupd_ack</b> after <b>dfi_ctrlupd_req</b> and <b>dfi_ctrlupd_ack</b> have both de-asserted. If the PHY de-asserts <b>dfi_phyupd_req</b> , it should do so while <b>dfi_ctrlupd_ack</b> is asserted. The MC should never have <b>dfi_ctrlupd_req</b> and <b>dfi_phyupd_ack</b> asserted together.                                                                                                                                                                                                                                                                                                                                      |

**TABLE 53.** DFI Interactions

| Rules                                                                                       | During Interactions Between |                                                    | Exceptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------------|-----------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MC requirement to assert<br><b>dfi_phyupd_ack</b> in response to<br><b>dfi_phyupd_req</b>   | <b>dfi_phyupd_req</b>       | <b>dfi_lp_ctrl_req</b><br><b>dfi_lp_data_req</b>   | If <b>dfi_phyupd_req</b> asserts while <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> are asserted, the MC must first de-assert <b>dfi_lp_ctrl_req</b> and <b>dfi_lp_data_req</b> and wait (if necessary) for <b>dfi_lp_ctrl_ack</b> and <b>dfi_lp_data_ack</b> to de-assert. After that, and before sending any data commands, the MC must assert <b>dfi_phyupd_ack</b> . Even in these cases, <b>dfi_lp_ctrl_req</b> and <b>dfi_lp_data_req</b> must meet <b>t<sub>lp_resp</sub></b> requirements.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>t<sub>phyupd_resp</sub></b>                                                              | <b>dfi_phyupd_req</b>       | <b>dfi_ctrlupd_req</b>                             | The PHY is permitted to assert <b>dfi_ctrlupd_ack</b> while <b>dfi_phyupd_req</b> is asserted and keep <b>dfi_phyupd_req</b> asserted. The MC must assert <b>dfi_phyupd_ack</b> within <b>t<sub>phyupd_resp</sub></b> cycles of a <b>dfi_phyupd_req</b> signal assertion even if a DFI controller update handshake occurs during that time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>t<sub>phyupd_resp</sub></b>                                                              | <b>dfi_phyupd_req</b>       | <b>dfi_lp_ctrl_req</b><br><b>dfi_lp_data_req</b>   | If <b>dfi_phyupd_req</b> is asserted or asserts while <b>dfi_lp_ctrl_req</b> and/or <b>dfi_lp_data_req</b> are asserted, <b>t<sub>phyupd_resp</sub></b> is counted from the first cycle in which <b>dfi_lp_ctrl_req</b> , <b>dfi_lp_ctrl_ack</b> , <b>dfi_lp_data_req</b> , and <b>dfi_lp_data_ack</b> are all de-asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| MC requirement to assert<br><b>dfi_phymngd_ack</b> in response to<br><b>dfi_phymngd_req</b> | <b>dfi_phymngd_req</b>      | <b>dfi_init_start</b>                              | If the <b>dfi_init_start</b> and <b>dfi_phymngd_req</b> signals are both asserted, the MC cannot assert the <b>dfi_phymngd_ack</b> signal. In this case, the PHY may de-assert the <b>dfi_init_complete</b> signal to initiate the frequency change protocol and it must also de-assert the <b>dfi_phymngd_req</b> signal before asserting the <b>dfi_init_complete</b> signal again.<br><br>Alternately, if the <b>dfi_init_start</b> and <b>dfi_phymngd_req</b> signals are both asserted, the PHY may not de-assert the <b>dfi_init_complete</b> signal. In this case, after <b>t<sub>init_start</sub></b> , the frequency change request is not accepted and the MC must assert the <b>dfi_phymngd_ack</b> signal before <b>t<sub>phymngd_resp</sub></b> . The timing value <b>t<sub>phymngd_resp</sub></b> must be defined large enough to accommodate this behavior.<br><br>The MC must never have both the <b>dfi_init_start</b> and the <b>dfi_phymngd_ack</b> signals asserted together. |
| MC requirement to assert<br><b>dfi_phymngd_ack</b> in response to<br><b>dfi_phymngd_req</b> | <b>dfi_phymngd_req</b>      | <b>dfi_lp_ctrl_req</b> ,<br><b>dfi_lp_data_req</b> | If <b>dfi_phymngd_req</b> asserts while <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> are asserted, the MC must first de-assert <b>dfi_lp_ctrl_req</b> and <b>dfi_lp_data_req</b> and wait (if necessary) for <b>dfi_lp_ctrl_ack</b> and <b>dfi_lp_data_ack</b> to de-assert. After that, and before sending any data commands, the MC must assert <b>dfi_phymngd_ack</b> . Even in these cases, <b>dfi_lp_ctrl_req</b> and <b>dfi_lp_data_req</b> must meet <b>t<sub>lp_resp</sub></b> requirements.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

**TABLE 53.** *DFI Interactions*

| Rules               | During Interactions Between                      |                                                    | Exceptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|--------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $t_{phymngd\_resp}$ | <b>dfi_phymngd_req</b>                           | <b>dfi_lp_ctrl_req</b> ,<br><b>dfi_lp_data_req</b> | If <b>dfi_phymngd_req</b> is asserted or asserts while <b>dfi_lp_ctrl_req</b> and/or <b>dfi_lp_data_req</b> are asserted, $t_{phymngd\_resp}$ is counted from the first cycle in which <b>dfi_lp_ctrl_req</b> , <b>dfi_lp_ctrl_ack</b> , <b>dfi_lp_data_req</b> , and <b>dfi_lp_data_ack</b> are all de-asserted.                                                                                                                                                                                                                                                   |
| Illegal operation   | <b>dfi_ctrlupd_req</b>                           | <b>dfi_init_start</b>                              | MC must never have both <b>dfi_ctrlupd_req</b> and <b>dfi_init_start</b> asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Illegal operation   | <b>dfi_lp_ctrl_req</b><br><b>dfi_lp_data_req</b> | <b>dfi_init_start</b>                              | MC must never have both <b>dfi_lp_ctrl_req</b> and <b>dfi_init_start</b> asserted. MC must never have both <b>dfi_lp_data_req</b> and <b>dfi_init_start</b> asserted.                                                                                                                                                                                                                                                                                                                                                                                               |
| Illegal operation   | <b>dfi_ctrlupd_ack</b><br><b>dfi_ctrlupd_req</b> | All other DFI Interfaces                           | If <b>dfi_ctrlupd_req</b> is asserted, all DFI signals must not change while <b>dfi_ctrlupd_req</b> remains asserted with the following exceptions: <b>dfi_phymngd_req</b> , <b>dfi_phymngd_cs_state</b> , <b>dfi_phymngd_state_sel</b> , <b>dfi_phymngd_type</b> , <b>dfi_ctrlmsg_req</b> , <b>dfi_ctrlmsg</b> , <b>dfi_ctrlmsg_data</b> , <b>dfi_ctrlmsg_ack</b> , <b>dfi_phyupd_req</b> , <b>dfi_phyupd_type</b> , <b>dfi_ctrlmsg_req</b> , <b>dfi_ctrlmsg</b> , <b>dfi_ctrlmsg_data</b> , <b>dfi_ctrlmsg_ack</b> , <b>dfi_error</b> , and <b>dfi_error_info</b> |
| Illegal operation   | <b>dfi_phymngd_ack</b>                           | <b>dfi_lp_ctrl_req</b><br><b>dfi_lp_data_req</b>   | If <b>dfi_phymngd_ack</b> is asserted and <b>dfi_lp_ctrl_req</b> and <b>dfi_lp_data_req</b> are not asserted, the MC must not assert <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> while <b>dfi_phymngd_ack</b> remains asserted.                                                                                                                                                                                                                                                                                                                                |
| Illegal operation   | <b>dfi_phymngd_ack</b>                           | <b>dfi_ctrlupd_req</b>                             | If <b>dfi_phymngd_ack</b> is asserted and <b>dfi_ctrlupd_req</b> is not asserted, the MC must not assert <b>dfi_ctrlupd_req</b> while <b>dfi_phymngd_ack</b> remains asserted.                                                                                                                                                                                                                                                                                                                                                                                      |
| Illegal operation   | <b>dfi_phymngd_ack</b>                           | DFI command, data and WCK interfaces               | If <b>dfi_phymngd_ack</b> is asserted, the DFI bus must be idle, no commands may be issued on the command bus, no data may be transferred on the data buses, and read and write data must have reached their destinations. The <b>dfi_dram_clk_disable</b> signal is defined as part of the command and cannot change. The WCK interface can not change. The exception is that the controller can send refresh commands.                                                                                                                                            |
| Illegal operation   | <b>dfi_phyupd_ack</b>                            | <b>dfi_lp_ctrl_req</b><br><b>dfi_lp_data_req</b>   | If <b>dfi_phyupd_ack</b> is asserted and <b>dfi_lp_ctrl_req</b> and <b>dfi_lp_data_req</b> are not asserted, the MC must not assert <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> while <b>dfi_phyupd_ack</b> remains asserted.                                                                                                                                                                                                                                                                                                                                  |
| Illegal operation   | <b>dfi_phyupd_ack</b>                            | DFI command, data and WCK interfaces               | If <b>dfi_phyupd_ack</b> is asserted, the DFI bus must be idle, no commands may be issued on the command bus, no data may be transferred on the data buses, and read and write data must have reached their destinations. The <b>dfi_dram_clk_disable</b> signal is defined as part of the command and cannot change. The WCK interface cannot change.                                                                                                                                                                                                              |

**TABLE 53.** DFI Interactions

| Rules             | During Interactions Between                                                                                                                                    |                             | Exceptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Illegal operation | <b>dfi_init_complete</b><br><b>dfi_init_start</b>                                                                                                              | <b>dfi_ctrlmsg_req</b>      | If <b>dfi_init_start</b> is asserted or <b>dfi_init_complete</b> is de-asserted and <b>dfi_ctrlmsg_req</b> is not asserted, the MC must not assert <b>dfi_ctrlmsg_req</b> while <b>dfi_init_start</b> remains asserted or <b>dfi_init_complete</b> remains de-asserted.                                                                                                                                                                                                                                                                                                                                                                                                     |
| Illegal operation | <b>dfi_init_complete</b><br><b>dfi_init_start</b>                                                                                                              | <b>dfi_dram_clk_disable</b> | If <b>dfi_init_start</b> is asserted or <b>dfi_init_complete</b> is de-asserted during a frequency change, <b>dfi_dram_clk_disable</b> must not change while <b>dfi_init_start</b> remains asserted or <b>dfi_init_complete</b> remains de-asserted.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Illegal operation | <b>dfi_lp_ctrl_ack</b><br><b>dfi_lp_ctrl_req</b><br><b>dfi_lp_ctrl_wakeup</b><br><b>dfi_lp_data_ack</b><br><b>dfi_lp_data_req</b><br><b>dfi_lp_data_wakeup</b> | <b>dfi_ctrlmsg_req</b>      | If <b>dfi_lp_ctrl_req</b> , <b>dfi_lp_ctrl_ack</b> , <b>dfi_lp_data_req</b> or <b>dfi_lp_data_ack</b> are asserted and the wakeup time for either interface is greater than or equal to <b>dfi_lp_wakeup_threshold</b> and <b>dfi_ctrlmsg_req</b> is not asserted, the MC must not assert <b>dfi_ctrlmsg_req</b> while these signals remain asserted.<br>If <b>dfi_ctrlmsg_req</b> is asserted and <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> are not asserted, <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_data_req</b> cannot be asserted with a wakeup time that is greater than or equal to <b>dfi_lp_wakeup_threshold</b> while <b>dfi_ctrlmsg_req</b> remains asserted. |
| Illegal operation | <b>dfi_lp_ctrl_ack</b><br><b>dfi_lp_ctrl_req</b>                                                                                                               | <b>dfi_dram_clk_disable</b> | If <b>dfi_lp_ctrl_req</b> and/or <b>dfi_lp_ctrl_ack</b> is asserted, <b>dfi_dram_clk_disable</b> must not change while <b>dfi_lp_ctrl_req</b> or <b>dfi_lp_ctrl_ack</b> remains asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## 4.22 MRDIMM Memories with Pseudo-Channels

In DDR5 MRDIMM Mux Mode, two pseudo-channels (PS0 and PS1) are interleaved on the same host interface.

The host command interface is interleaved per-clock cycle. Each phase of the **dfi\_address** bus represents a single cycle on the host interface. Even phases are used for pseudo-channel 0 and odd phases are used for pseudo-channel 1. Matched command frequency ratio is not supported for DDR5 MRDIMM Mux Mode.

The timing parameter command reference point follows the same rules as DDR5 with RCD. However, because the command interface is interleaved on a per-cycle basis, commands that occupy 2 consecutive cycles for DDR5 with RCD (e.g. RD or WR) will have 1 command phase injected between them, which will effectively move the reference point.

The host data interface is interleaved per-strobe-edge, with both PS0 and PS1 data in every host Data cycle (PS0 on the rising edge and PS1 on the falling edge) and a shared burst preamble/postamble.

Since the Command and Data interfaces use different interleaving, DFI timing parameters referenced to both Command and Data interfaces (e.g. **tphy\_wrlat**, **trddata\_en**, **tphy\_wrcslat**, **tphy\_rdcslat**) must be treated differently for PS0 vs PS1 and in 1N vs 2N mode. The PS1 version will be 1 Command phase less than the PS0 version. In 1N mode, the Data and Command frequency ratios are the same. However, in 2N mode, there will be 2 Data phases per 1 Command phase, so timing parameters and reference points must be scaled into Data phase units.

The PHY is only responsible for transferring the data bursts between the DFI and host interface, in the same manner as any other protocol. The MC is responsible for resolving the shared burst into PS0 and PS1 data.

#### **4.22.1 Write Transaction Timing**

On the Write Data interface, the combination of both pseudo-channels together forms a single, extra-long burst, delimited by a common **dfi\_wrdata\_en** signal. Each phase of the **dfi\_wrdata** bus represents a single double-data-rate cycle on the host interface. Rising edge data is used for pseudo-channel 0 and falling edge data is used for pseudo-channel 1.

Since the interleaving difference creates a different delay between command and data for PS0 vs PS1, the **t<sub>phy\_wrdata</sub>** parameter is nominally defined only for PS0, and PS1's effective delay is derived relative to the paired PS0 cycle. In 1N mode, this is a 1 Data cycle difference and in 2N mode, this is a 2 Data cycle difference.

Figure 133, “MRDIMM Mux 1N Mode Write 1:4 Command and 1:4 Data Frequency Ratio” demonstrates a write transaction with matched command and data frequency ratios. Note that this diagram uses a smaller than legal “BL8” burst for illustration purposes only.

## Functional Use

**FIGURE 133. MRDIMM Mux 1N Mode Write 1:4 Command and 1:4 Data Frequency Ratio**



Figure 134, “MRDIMM Mux 2N Mode Write 1:2 Command and 1:4 Data Frequency Ratio” demonstrates a write transaction with different command and data frequency ratios. Note that this diagram uses a smaller than legal “BL8” burst for illustration purposes only.

**FIGURE 134.** MRDIMM Mux 2N Mode Write 1:2 Command and 1:4 Data Frequency Ratio


#### 4.22.2 Read Transaction Timing

On the Read Data interface, the combination of both pseudo-channels together forms a single, extra-long burst, delimited by a common **dfi\_rddata\_en** signal. Each phase of the **dfi\_rddata** bus represents a single double-data-rate cycle on the host interface. Rising edge data is used for pseudo-channel 0 and falling edge data is used for pseudo-channel 1.

Since the interleaving difference creates a different delay between command and data for PS0 vs PS1, the **t\_rddata\_en** parameter is nominally defined only for PS0, and PS1's effective delay is derived relative to the paired PS0 cycle. In 1N mode, this is a 1 Data cycle difference and in 2N mode, this is a 2 Data cycle difference.

---

## Functional Use

---

Figure 135, “MRDIMM Mux 1N Mode Read 1:4 Command and 1:4 Data Frequency Ratio” demonstrates the read data rotation rule with only one word available on the first cycle. Note that this diagram uses a smaller than legal “BL8” burst for illustration purposes only.

## Functional Use

**FIGURE 135. MRDIMM Mux 1N Mode Read 1:4 Command and 1:4 Data Frequency Ratio**



**Note:** The **tphy\_rdlat** value shown is the actual value, not the maximum value.

## Functional Use

Figure 136, “MRDIMM Mux 2N Mode Read 1:2 Command and 1:4 Data Frequency Ratio” demonstrates the read data rotation rule with only three words available on the first cycle. Note that this diagram uses a smaller than legal “BL8” burst for illustration purposes only.

**FIGURE 136. MRDIMM Mux 2N Mode Read 1:2 Command and 1:4 Data Frequency Ratio**



**Note:** The tphy\_rdlat value shown is the actual value, not the maximum value.

#### **4.22.3 Read Transaction Considerations for Pseudo-Channels**

The MC is responsible for resolving shared data bursts into the appropriate pseudo-channel. As with any protocol, each phase of the **dfi\_rddata\_valid** signals corresponds to a specific phase of the **dfi\_rddata\_en** signal, in the same order. In DDR5 MRDIMMs, this means that the pseudo-channel composition of each **dfi\_rddata\_en** signal and **dfi\_rddata\_valid** signal remains consistent. If an enable phase represents only PS0 content, then the corresponding valid phase also represents only PS0 data. (Note that PS1 “data” will be all “1”s, from the MDBs). Similarly, if an enable phase represents both PS0 and PS1 content, then the corresponding valid phase also represents both PS0 and PS1 data. Note that the read rotation rules apply to the **dfi\_rddata** and the **dfi\_rddata\_valid** signals on the shared interface, not per pseudo-channel. For a reminder of the read rotation rules, refer to Section 4.10.4.1, “DFI Read Data Rotation”.

Figure 137, “DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio with Offset Between Pseudo-Channel Commands” is a conceptual representation of the meaning of each enable and valid phase when the PS0 and PS1 commands are not strictly aligned. Note that burst lengths and latencies are artificially shortened for illustrative purposes.

To show the correlation between each phase of the **dfi\_rddata\_en** and **dfi\_rddata\_valid** signals, each asserted phase has been labeled with a phase count. Since the first PS0 command is sent without a PS1 command in the matching slot, the first 2 phases of the **dfi\_rddata\_en** signal only represent PS0. A PS1 command is sent on the next opportunity (2 phases after the missed slot), so the next few **dfi\_rddata\_en** signal phases represent both PS0 and PS1, but the last 2 phases of the burst represent only PS1. This means that the first 2 phases of the **dfi\_rddata\_valid** will only contain PS0 data, the middle phases contain both, and the last 2 phases only contain PS1 data. In the second burst, the first command is for PS1, without a PS0 command is the matching slot. The PS0 command is sent 4 phases after the missed slot. So, now, the first 4 phases of the **dfi\_rddata\_en** signal are PS1-only, the last 4 phases are PS0-only, and the middle 4 phases are for both pseudo-channels. Therefore, of the 12 phases of the **dfi\_rddata\_valid** signal, the first 4 phases are PS1-only, the middle 4 phases are both, and the last 4 phases are PS0-only. The read data must be returned on the **dfi\_rddata** signal with the same phase information as the **dfi\_rddata\_en** signal for each pseudo-channel.

**FIGURE 137.** DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio with Offset Between Pseudo-Channel Commands



Figure 138, “DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio with Offset Between Pseudo-Channel Commands” is a more complex example. An extreme example of a legal (but unlikely) **dfi\_rddata\_valid** signal waveform is shown for illustrative purposes. (Please review Figure 137, “DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:2 Command and 1:2 Data Frequency Ratio with Offset Between Pseudo-Channel Commands”, the read data rotation rules, and the diagrams in Figure 4.10.4.3, “DFI Read Data Rotation in Large Frequency Ratio Systems” before continuing.) The 1:4 frequency ratio adds complexity to the read data rotation rules as they apply at the combined PHY to MC interface, not per-pseudo-channel. Note that the first phase of the **dfi\_rddata\_valid** signal that represents PS0 data occurs on \_w0, but the first phase of the **dfi\_rddata\_valid** signal that represents PS1 data occurs on \_w2. Similarly, “a7” ends on \_w3, but “d0” starts on \_w2, and “z7” ends on \_w1, but “w0” starts on \_w0. In all of these cases, there is a 2 phase gap where the **dfi\_rddata\_valid** signal represents only the other pseudo-channel. Though the combined interface is following the read data rotation rules, the pointers for each pseudo-channel are impacted by the valid signals for the other pseudo-channel. Each **dfi\_rddata\_valid** signal phase corresponds to a specific **dfi\_rddata\_en** signal phase, and has the same order and composition.

**FIGURE 138.** DDR5 MRDIMM Mux Mode 1N Read Timing with a 1:4 Command and 1:4 Data Frequency Ratio with Offset Between Pseudo-Channel Commands



#### 4.23 Use of the `dfi_rddata_cs` / `dfi_wrdata_cs` Signal with DDR5 DIMMs

This section describes the usage of the `dfi_rddata_cs` or `dfi_wrdata_cs` signals to control interface timing with DDR5 UDIMMs, RDIMMs, and MRDIMMs. Examples show the correspondence between the `dfi_cs` and the appropriate `dfi_rddata_cs` / `dfi_wrdata_cs` signal for a 2 DIMM-per-channel system of 2-rank DIMMs in two different mapping scenarios.

For DDR5 RDIMM and UDIMMs, each physical rank is independent, so the mapping between the **dfi\_cs** signal and the **dfi\_rddata\_cs / dfi\_wrdata\_cs** signal must match. This means that if a command is sent with a **dfi\_cs** [X] bit set, it will be reflected on the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [X] signal bit, and if a command is sent with a **dfi\_cs** [Y] bit set, it will be reflected on the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [Y] signal bit, regardless of the relationship between X and Y.

For DDR5 MRDIMM, each DIMM is independent, so only a single bit of the **dfi\_rddata\_cs / dfi\_wrdata\_cs** signal is used per DIMM - the bit corresponding to the CS0 of that DIMM. In other words, if a command is sent with **dfi\_cs** [X] bit or **dfi\_cs** [Y] bit set, and X is CS0 and Y is CS1 of the same DIMM, both cases will be reflected on the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [X] signal bit, but if a command is sent with a **dfi\_cs** [Z] bit set where Z is CS0 on a different DIMM, it will be reflected on the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [Z] signal bit.

### 4.23.1 Example 1

For this example, the **dfi\_cs** signals are mapped with adjacent bits for the same DIMM as shown:

- **dfi\_cs** [0] for DIMM-0 CS0
- **dfi\_cs** [1] for DIMM-0 CS1
- **dfi\_cs** [2] for DIMM-1 CS0
- **dfi\_cs** [3] for DIMM-1 CS1

For DDR5 RDIMM or UDIMM, this will be reflected as:

- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [0] for DIMM-0 CS0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [1] for DIMM-0 CS1
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [2] for DIMM-1 CS0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [3] for DIMM-1 CS1

For DDR5 MRDIMM Mux Mode, regardless of actual backside PS or rank selected inside DIMM, this will be reflected as:

- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [0] for DIMM-0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [2] for DIMM-1

For DDR5 MRDIMM Rank Mode, regardless of actual backside ranks selected inside DIMM, this will be reflected as:

- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [0] for DIMM-0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [2] for DIMM-1

### 4.23.2 Example 2

For this example, the **dfi\_cs** signal mapping with adjacent bits for the same CS as shown:

- **dfi\_cs** [0] for DIMM-0 CS0
- **dfi\_cs** [1] for DIMM-1 CS0
- **dfi\_cs** [2] for DIMM-0 CS1
- **dfi\_cs** [3] for DIMM-1 CS1

For DDR5 RDIMM or UDIMM, this will be reflected as:

- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [0] for DIMM-0 CS0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [1] for DIMM-1 CS0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [2] for DIMM-0 CS1
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [3] for DIMM-1 CS1

For DDR5 MRDIMM Mux Mode, regardless of actual backside PS or rank selected inside DIMM, this will be reflected as:

- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [0] for DIMM-0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [1] for DIMM-1

For DDR5 MRDIMM Rank Mode, regardless of actual backside ranks selected inside DIMM, this will be reflected as:

- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [0] for DIMM-0
- the corresponding **dfi\_rddata\_cs / dfi\_wrdata\_cs** [1] for DIMM-1

## 5.0 Signal Timing

---

The DFI specification does not specify timing values for signaling between the MC and the PHY. The only requirement is that a DFI clock must exist, and all DFI-related signals must be driven by registers referenced to the rising edge of the DFI clock. There are no restrictions on how these signals are received, nor any rules on the source of the DFI clock.

Compatibility between the MC and the PHY at given frequencies is dependent on the specification of both the output timing for signals driven, and the setup and hold requirements for reception of these signals on the DFI.

However, the DFI signals are categorized into three signal groups that place restrictions on how signals may be driven and captured by DFI devices. All DFI signals may be driven from the DFI clock and captured on the following rising edge of the DFI clock. However, some signals may allow less restrictive timing which may alleviate timing restrictions within the design.

For frequency ratio systems, the PHY must send and receive DFI signals with respect to the rising edge of the DFI clock, even if the signals are driven and captured by registers clocked by the higher frequency Command or Data clock.

There are three signal groups:

### 1. Standard Signals

Standard signals contain timing critical information on a cycle-by-cycle basis, and therefore, must be sent and received on every DFI clock. The Command Interface signals fall into the standard signal category because the Command Interface signals must be cycle-accurate to properly communicate memory commands.

Standard signals must be sent on the DFI clock and must be received on every DFI clock period for proper operation. All standard signals are required to meet setup and hold time to the DFI clock at the destination. Neither device should have a dependency on the source clock of the other device. The source and destination clock should always be assumed to be the DFI clock.

### 2. State-Retaining Signals

State-retaining signals contain information that is not single cycle-critical because state-retaining signals retain a state change until either a signal acknowledge is received or a timing parameter has been satisfied. The update interface signals fall into the standard signal category because all signal state changes are defined in terms of signal responses and timing parameters.

State-retaining signals may be sent and received in the same way on every DFI clock period. They may also be sent and/or received by a divided frequency clock, provided that the lower frequency clock is an even multiple ( $\frac{1}{2}$ ,  $\frac{1}{4}$ , etc.) and is phase aligned to the DFI clock.

All state-retaining signals are required to meet setup and hold time to the DFI clock at the destination regardless of whether the signal is generated from the DFI clock or from a lower frequency, phase-aligned clock source. Neither device should have a dependency on the source clock of the other device; the source and destination clock should always be assumed to be the DFI clock. If a lower frequency clock is used, the associated timing parameters must be set to appropriately account for the timing effects of using a lower frequency clock at either the source or destination.

---

## Signal Timing

---

The timing parameters are always defined in terms of the DFI clock regardless of the source and destination clock frequency.

### 3. Timer-Based Signals

Timer-based signals do not have a clock-edge dependency because timer-based signals are either not required to be valid until a timing parameter has been met, another signal has been asserted, or they are expected to be static during normal operation (static signals may be changed during idle times).

Timer-based signals do not have to meet setup and hold time to the DFI clock except on the cycle after meeting the associated timing parameter. Timer-based signals may also be changed during idle times in which case the setup and hold times are irrelevant. For timing analysis, timer-based signals may be treated as multi-cycle paths.

Table 54, “Signal Group Divisions” shows that each DFI signal is categorized into a signal group.

---

**TABLE 54. Signal Group Divisions**

| Signal                                                                       | Signal Group    |
|------------------------------------------------------------------------------|-----------------|
| <code>dfi_2n_mode</code> (or <code>dfi_2n_mode_pN</code> )                   | Standard        |
| <code>dfi_act_n</code> (or <code>dfi_act_n_pN</code> )                       | Standard        |
| <code>dfi_address</code> (or <code>dfi_address_pN</code> )                   | Standard        |
| <code>dfi_alert_n</code> (or <code>dfi_alert_n_aN</code> )                   | Standard        |
| <code>dfi_bank</code> (or <code>dfi_bank_pN</code> )                         | Standard        |
| <code>dfi_bg</code> (or <code>dfi_bg_pN</code> )                             | Standard        |
| <code>dfi_cas_n</code> (or <code>dfi_cs_pN</code> )                          | Standard        |
| <code>dfi_cid</code> (or <code>dfi_cid_pN</code> )                           | Standard        |
| <code>dfi_cke</code> (or <code>dfi_cke_pN</code> )                           | Standard        |
| <code>dfi_cmd_freq_ratio</code>                                              | Timer-Based     |
| <code>dfi_cs</code> (or <code>dfi_cs_pN</code> )                             | Standard        |
| <code>dfi_cs_geardown</code> (or <code>dfi_cs_geardown_pN</code> )           | Standard        |
| <code>dfi_ctrlmsg</code>                                                     | State-Retaining |
| <code>dfi_ctrlmsg_ack</code>                                                 | State-Retaining |
| <code>dfi_ctrlmsg_data</code>                                                | State-Retaining |
| <code>dfi_ctrlmsg_req</code>                                                 | State-Retaining |
| <code>dfi_ctrlupd_ack</code>                                                 | State-Retaining |
| <code>dfi_ctrlupd_req</code>                                                 | State-Retaining |
| <code>dfi_data_freq_ratio</code>                                             | Timer-Based     |
| <code>dfi_disconnect_error</code>                                            | Standard        |
| <code>dfi_dram_clk_disable</code> (or <code>dfi_dram_clk_disable_pN</code> ) | Standard        |
| <code>dfi_error</code>                                                       | Standard        |
| <code>dfi_error_info</code>                                                  | Standard        |
| <code>dfi_freq_fsp</code>                                                    | Timer-Based     |
| <code>dfi_frequency</code>                                                   | Timer-Based     |
| <code>dfi_init_complete</code>                                               | State-Retaining |
| <code>dfi_init_start</code>                                                  | State-Retaining |
| <code>dfi_lp_ctrl_ack</code>                                                 | State-Retaining |

---

---

## Signal Timing

---

**TABLE 54.** *Signal Group Divisions*

| Signal                                                               | Signal Group    |
|----------------------------------------------------------------------|-----------------|
| <code>dfi_lp_ctrl_req</code>                                         | State-Retaining |
| <code>dfi_lp_ctrl_wakeup</code>                                      | State-Retaining |
| <code>dfi_lp_data_ack</code>                                         | State-Retaining |
| <code>dfi_lp_data_req</code>                                         | State-Retaining |
| <code>dfi_lp_data_wakeup</code>                                      | State-Retaining |
| <code>dfi_odt</code> (or <code>dfi_odt_pN</code> )                   | Standard        |
| <code>dfi_parity_in</code> (or <code>dfi_parity_in_pN</code> )       | Standard        |
| <code>dfi_phymngd_ack</code>                                         | State-Retaining |
| <code>dfi_phymngd_cs_state</code>                                    | State-Retaining |
| <code>dfi_phymngd_req</code>                                         | State-Retaining |
| <code>dfi_phymngd_state_sel</code>                                   | State-Retaining |
| <code>dfi_phymngd_type</code>                                        | State-Retaining |
| <code>dfi_phyupd_ack</code>                                          | State-Retaining |
| <code>dfi_phyupd_req</code>                                          | State-Retaining |
| <code>dfi_phyupd_type</code>                                         | State-Retaining |
| <code>dfi_ras_n</code> (or <code>dfi_ras_n_pN</code> )               | Standard        |
| <code>dfi_rddata</code> (or <code>dfi_rddata_wN</code> )             | Standard        |
| <code>dfi_rddata_crc</code> (or <code>dfi_rddata_crc_wN</code> )     | Standard        |
| <code>dfi_rddata_cs</code> (or <code>dfi_rddata_cs_pN</code> )       | State-Retaining |
| <code>dfi_rddata_dbi</code> (or <code>dfi_rddata_dbi_wN</code> )     | Standard        |
| <code>dfi_rddata_dnv</code> (or <code>dfi_rddata_dnv_wN</code> )     | Standard        |
| <code>dfi_rddata_en</code> (or <code>dfi_rddata_en_pN</code> )       | Standard        |
| <code>dfi_rddata_valid</code> (or <code>dfi_rddata_valid_wN</code> ) | Standard        |
| <code>dfi_reset_n</code> (or <code>dfi_reset_n_pN</code> )           | Standard        |
| <code>dfi_wck_cs</code> (or <code>dfi_wck_cs_pN</code> )             | Standard        |
| <code>dfi_wck_en</code> (or <code>dfi_wck_en_pN</code> )             | Standard        |
| <code>dfi_wck_toggle</code> (or <code>dfi_wck_toggle_pN</code> )     | Standard        |
| <code>dfi_we_n</code> (or <code>dfi_we_n_pN</code> )                 | Standard        |
| <code>dfi_wrdata</code> (or <code>dfi_wrdata_pN</code> )             | Standard        |
| <code>dfi_wrdata_crc</code> (or <code>dfi_wrdata_crc_pN</code> )     | Standard        |
| <code>dfi_wrdata_cs</code> (or <code>dfi_wrdata_cs_pN</code> )       | Standard        |
| <code>dfi_wrdata_ecc</code> (or <code>dfi_wrdata_ecc_pN</code> )     | Standard        |
| <code>dfi_wrdata_en</code> (or <code>dfi_wrdata_en_pN</code> )       | Standard        |
| <code>dfi_wrdata_mask</code> (or <code>dfi_wrdata_mask_pN</code> )   | Standard        |

## 6.0 Glossary

---

**TABLE 55.** *Glossary of Terms*

| Term                         | Definition                                                                                                                                                                                                                                                                                     |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CA Bus                       | JEDEC defines the CA bus as a bus containing command, address and bank/row buffer information. The CA bus operates at double data rate for LPDDR2, LPDDR3, DDR5 with RCD, and DDR5 MRDIMM systems, and single data rate for LPDDR4, DDR5 and LPDDR5 systems.                                   |
| Column Selection (CAS)       | Column address strobe.                                                                                                                                                                                                                                                                         |
| Command Address (CA) Signals | Includes the following command interface signals: <b>dfi_act_n</b> , <b>dfi_address</b> , <b>dfi_bank</b> , <b>dfi_bg</b> , <b>dfi_ras_n</b> , <b>dfi_cas_n</b> , and <b>dfi_we_n</b> . The DRAM class determines the signals applicable to a specific system.                                 |
| Command Bus                  | Includes the following command interface signals: <b>dfi_act_n</b> , <b>dfi_cas_n</b> , <b>dfi_ras_n</b> and <b>dfi_we_n</b> . The DRAM class determines the signals applicable to a specific system.                                                                                          |
| Command Clock Frequency      | Defines the command clock frequency of the host interface. For matched systems, this is the same as the DFI clock frequency. For command frequency ratio systems, the period of the Command clock must be 1/2, 1/4, or 1/8 the period of the DFI clock. These clocks must be aligned in phase. |
| Control Clock Frequency      | Defines the clock frequency of the DFI Interface Groups that do not correspond to signals on the host interface. The period of the Control clock is the same as the period of the DFI clock. These clocks must be aligned in phase.                                                            |
| Data Bus Inversion (DBI)     | A feature of the DRAM that allows read and write data to be inverted selectively before the data is transferred across the DDR data bus.                                                                                                                                                       |
| Data Clock Frequency         | Defines the data clock or strobe frequency of the host interface. For matched systems, this is the same as the DFI clock frequency. For data frequency ratio systems, the period of the Data clock must be 1/2, 1/4 or 1/8 the period of the DFI clock. These clocks must be aligned in phase. |
| DFI Address Width            | The number of address bits on the DFI interface. This is generally the same number of bits as the number of address bits on the host interface when operating at single data rate or twice the number of bits when operating at double data rate.                                              |
| DFI Alert Width              | The width of the alert signal on the DFI interface. Typically the PHY would drive an alert signal per slice and the alert is typically 1 bit.                                                                                                                                                  |
| DFI Bank Group Width         | The number of bank group bits on the DFI interface. This is generally the same number of bits as the number of BG bits on the DRAM device.                                                                                                                                                     |
| DFI Bank Width               | The number of bank bits on the DFI interface. This is generally the same number of bits as the number of bank pins on the DRAM device.                                                                                                                                                         |
| DFI Bus Idle                 | The DFI bus is considered idle when the command interface is not sending any commands and all read and write data has transferred on the DFI bus, reached its destination (DRAM or DIMM or MC), and the write data transfer has completed on the host interface.                               |
| DFI Chip ID Width            | The CID signals are used with 3D stacks. For DDR4, the MAX width is 3 bits (stack of 8). There are also stacks with 1 bit for CID (stack of 2).                                                                                                                                                |
| DFI Chip Select Width        | The number of chip select bits on the DFI interface. This is generally the same number of bits as the number of chip select pins on the host interface. Rank width and chip select width are equivalent. For 3DS, this is referred to as the “Physical Rank.”                                  |

## Glossary

**TABLE 55.** *Glossary of Terms*

| <b>Term</b>                    | <b>Definition</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DFI CKE Width                  | Defines the width of the <b>dfi_cke</b> signal. The MC and the PHY should support the same number of bits on this signal. The MC must detect CKE signals that are valid. It could send more signals than the PHY can use, transmit, or both. However, whatever is dropped should not be asserted by the MC.                                                                                                                                                                                                 |
| DFI clock cycle                | The DFI clock has the same phase and frequency as the MC clock.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DFI clock frequency            | Defines the clock frequency of the MC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DFI Data Enable Width          | The width of the datapath enable signals on the DFI interface. For PHYs with an 8-bit slice, this is generally 1/16th of the DFI Data Width to provide a single enable bit per memory data slice, but may be 1/4, 1/8, 1/32, or any other ratio. Bit zero corresponds to the lowest segment.                                                                                                                                                                                                                |
| DFI Data Slice Count           | The number of data slices in the PHY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DFI Data Width                 | The width of the datapath on the DFI interface. Since data generally operates at double data rate, this is generally twice the host data width.                                                                                                                                                                                                                                                                                                                                                             |
| DFI Data Word                  | One phase of read or write data passed between the MC and the PHY. A DFI data word is twice the width of the bus between the memory and the PHY and corresponds to a single memory word transfer across the DFI bus.                                                                                                                                                                                                                                                                                        |
| DFI DBI Width                  | The DBI width on the DFI interface. Typically DFI Data Width/8. See the description of <b>dfi_wrdata_mask</b> for more details.                                                                                                                                                                                                                                                                                                                                                                             |
| DFI DRAM Clk Disable Width     | Defines the width of the <b>dfi_dram_clk_disable</b> signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DFI Error Width                | Typically, 1 bit per data slice plus 1 bit for control. The PHY may implement <b>dfi_error</b> as a single bit or any other width not exceeding the sum of the data slices + 1 bit for control. The MC should accept 1 bit per instance as defined by the sum of data slices plus 1 bit for control.                                                                                                                                                                                                        |
| DFI FSP Width                  | For LPDDR4, this is 1 bit. For LPDDR5, this is 2 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DFI ODT Width                  | Defines the width of the <b>dfi_odt</b> signal. The MC must detect ODT signals that are valid. It could send more signals than the PHY can use, transmit, or both. However, whatever is dropped should not be asserted by the MC.                                                                                                                                                                                                                                                                           |
| DFI Physical Rank Width        | Defines the number of chip selects. For 3DS, this is referred to as the “Physical Rank.”                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DFI Read Data Valid Width      | The width of the datapath valid signals on the DFI interface. Equivalent to the number of PHY data slices, the same width definition as the <b>dfi_rddata_en</b> signal. Bit zero corresponds to the lowest segment.                                                                                                                                                                                                                                                                                        |
| DFI Reset Width                | Defines the width of the <b>dfi_reset_n</b> signal. The MC and the PHY should support the same number of bits on this signal.                                                                                                                                                                                                                                                                                                                                                                               |
| DFI WCK Width                  | The number of individual WCK control signal interfaces driven on the DFI bus. This is generally the number of WCKs supported on the memory interface.                                                                                                                                                                                                                                                                                                                                                       |
| <b>dfi<sub>rw</sub>_length</b> | The value of the total number of Data clocks required to transfer one DFI read or write command worth of data. <ul style="list-style-type: none"> <li>• For a matched frequency system: <b>dfi<sub>rw</sub>_length</b> would typically equal (burst length/2).</li> <li>• For a frequency ratio system: <b>dfi<sub>rw</sub>_length</b> is defined in terms of Data clocks and would typically equal (burst length/2). Additional Data clock cycles must be added for the DRAM CRC data transfer.</li> </ul> |
| DQ                             | The bi-directional bus that transfers read and write data to the memory.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DQS                            | The bi-directional data strobe bus transmitted to and from the memory.                                                                                                                                                                                                                                                                                                                                                                                                                                      |

---

## Glossary

---

**TABLE 55.** *Glossary of Terms*

| <b>Term</b>                           | <b>Definition</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Frequency Ratio                       | <p>If the MC operates at a lower frequency, either 1:2, or 1:4, or 1:8 ratio to the host interface, the system is defined as a frequency ratio system.</p> <p>For a frequency ratio system, DFI defines two clock ratios - the command ratio is the ratio between the slower MC clock and the faster host command clock, and the data ratio is the ratio between the slower MC clock and the faster data clock. Refer to Section 2.1, “Clocking” for more details.</p> <p>Phase-specific signals with a suffix of “_pN” with the phase number N (e.g., <b>dfi_wrdata_pN</b>) replace the matched frequency command, write data, read data and WCK interface signals. Phase-specific signals allow the MC to drive multiple commands in a single clock cycle.</p> <p>Data word-specific signals with a suffix of “_wN” with the DFI data word number N (e.g., <b>dfi_rddata_wN</b>) replace the matched frequency read data interface signals to distinguish how memory words are transferred across the DFI bus.</p> <p>Variable pulse width-specific signals with a suffix of “aN”, with the command clock cycle N (e.g., <b>dfi_alert_n_aN</b>), replace the matched frequency status interface signals to maintain the pulse width during transmission of error signals from the memory system to the PHY.</p> <p>For all signal types, the suffix for phase 0/data word 0/clock cycle 0 is optional. For more information on frequency ratios, refer to Section 4.10, “Frequency Ratios Across the DFI”.</p> |
| Host Interface                        | The interface between the PHY and the memory devices. Example memory devices include DRAMs and DIMMs (or DIMM components). Generally the host interface is composed of command and data interfaces.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Matched Frequency                     | <p>In a matched frequency system, the MC and the host interface operate at a common frequency ratio of 1:1.</p> <p>In a matched command frequency system, the MC and the host command interface operate at the same frequency, but the host data interface operates at a different frequency.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| MC                                    | DDR Memory Controller logic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PHY                                   | DDR Physical Interface logic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PHY Data Word                         | One phase of read or write data passed between the PHY and the memory. A PHY data word is the width of the bus between the PHY and the memory and corresponds to a single memory word transfer across the DFI bus. In double data rate operation, a PHY data word is half the width of a DFI data word.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Row Selection (RAS)                   | Row address strobe.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Unit interval (UI)                    | <p>Half of a data word; the number of DRAM data words in one DRAM burst.</p> <p>NOTE: With DDR DRAM devices, the number of DRAM data words is 2x the number of DFI data words.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Variable pulse width-specific signals | Differentiated with a suffix of “aN”, with the command clock cycle N (e.g., <b>dfi_alert_n_aN</b> ), variable pulse width-specific signals replace status interface matched frequency signals to maintain the pulse width during transmission of error signals from the memory system to the PHY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |