



**T-HEAD**

# **TH1520 Memory Interface**

## **User Manual**

|                 |            |
|-----------------|------------|
| <b>Revision</b> | 1.0.0      |
| <b>Security</b> | Secret     |
| <b>Date</b>     | 2023-08-26 |

**Copyright © 2022 T-HEAD (Shanghai) Semiconductor Co., Ltd. All rights reserved.**

This document is the property of T-HEAD (Shanghai) Semiconductor Co., Ltd. This document may only be distributed to: (i) a T-HEAD party having a legitimate business need for the information contained herein, or (ii) a non-T-HEAD party having a legitimate business need for the information contained herein. No license, expressed or implied, under any patent, copyright or trade secret right is granted or implied by the conveyance of this document. No part of this document may be reproduced, transmitted, transcribed, stored in a retrieval system, translated into any language or computer language, in any form or by any means, electronic, mechanical, magnetic, optical, chemical, manual, or otherwise without the prior written permission of T-HEAD (Shanghai) Semiconductor Co., Ltd.

**Trademarks and Permissions**

The T-HEAD Logo and all other trademarks indicated as such herein are trademarks of T-HEAD (Shanghai) Semiconductor Co., Ltd. All other products or service names are the property of their respective owners.

**Notice**

The purchased products, services and features are stipulated by the contract made between T-HEAD and the customer. All or part of the products, services and features described in this document may not be within the purchase scope or the usage scope. Unless otherwise specified in the contract, all statements, information, and recommendations in this document are provided "AS IS" without warranties, guarantees or representations of any kind, either express or implied.

The information in this document is subject to change without notice. Every effort has been made in the preparation of this document to ensure accuracy of the contents, but all statements, information, and recommendations in this document do not constitute a warranty of any kind, express or implied.

**平头哥（上海）半导体技术有限公司 T-HEAD (Shanghai) Semiconductor Co., LTD**

Address: 5th Floor Number 2 Chuan He Road 55, Number 366 Shang Ke Road, Shanghai free trade area, China  
Website: [www.t-head.cn](http://www.t-head.cn)

**Copyright © 2022 平头哥（上海）半导体技术有限公司，保留所有权利.**

本文档的所有权及知识产权归属于平头哥（上海）半导体技术有限公司及其关联公司(下称“平头哥” )。本文档仅能分派给: (i)拥有合法雇佣关系，并需要本文档的信息的平头哥员工，或(ii)非平头哥组织但拥有合法合作关系，并且其需要本文档的信息的合作方。对于本文档，未经平头哥（上海）半导体技术有限公司明示同意，则不能使用该文档。在未经平头哥（上海）半导体技术有限公司的书面许可的情形下，不得复制本文档的任何部分，传播、转录、储存在检索系统中或翻译成任何语言或计算机语言。

**商标申明**

平头哥的 LOGO 和其它所有商标归平头哥（上海）半导体技术有限公司及其关联公司所有，未经平头哥（上海）半导体技术有限公司的书面同意，任何法律实体不得使用平头哥的商标或者商业标识。

**注意**

您购买的产品、服务或特性等应受平头哥商业合同和条款的约束，本文档中描述的全部或部分产品、服务或特性可能不在您的购买或使用范围之内。除非合同另有约定，平头哥对本文档内容不做任何明示或默示的声明或保证。

由于产品版本升级或其他原因，本文档内容会不定期进行更新。除非另有约定，本文档仅作为使用指导，本文档中的所有陈述、信息和建议不构成任何明示或暗示的担保。平头哥（上海）半导体技术有限公司不对任何第三方使用本文档产生的损失承担任何法律责任。

**平头哥（上海）半导体技术有限公司 T-HEAD (Shanghai) Semiconductor Co., LTD**

地址: 中国（上海）自由贸易试验区上科路 366 号、川和路 55 弄 2 号 5 层  
网址: [www.t-head.cn](http://www.t-head.cn)

# Revisions

| Rev    | Description     | Author(s) | Date       |
|--------|-----------------|-----------|------------|
| V1.0.0 | Initial version | T-Head    | 2023-08-26 |

# Contents

---

|                                |      |
|--------------------------------|------|
| Revisions .....                | I    |
| Contents .....                 | II   |
| Figures & Tables.....          | III  |
| List of Abbreviations .....    | VIII |
| 1 SRAMC.....                   | 1    |
| 2 LPDDR4 .....                 | 2    |
| 2.1 Overview.....              | 2    |
| 2.2 Main Features .....        | 2    |
| 2.3 Interface .....            | 3    |
| 2.4 Function Description ..... | 7    |
| 2.5 Usage .....                | 11   |
| 3 eMMC/SD .....                | 14   |
| 3.1 Overview.....              | 14   |
| 3.2 Main Features .....        | 14   |
| 3.3 Interface .....            | 15   |
| 3.4 Function Description ..... | 16   |
| 3.5 Usage .....                | 24   |
| 3.6 Registers.....             | 56   |
| 4 QSPI .....                   | 205  |
| 4.1 Overview.....              | 205  |
| 4.2 Main Features .....        | 205  |
| 4.3 Interface .....            | 206  |
| 4.4 Function Description ..... | 207  |
| 4.5 Usage .....                | 219  |
| 4.6 Registers.....             | 219  |

# Figures & Tables

---

|                                                                                             |    |
|---------------------------------------------------------------------------------------------|----|
| Figure & Table 2-1 DDR subsystem block diagram .....                                        | 2  |
| Figure & Table 2-2 64-bit dual channel connection diagram .....                             | 4  |
| Figure & Table 2-3 32-bit single channel connection diagram.....                            | 5  |
| Figure & Table 2-4 Pin description table .....                                              | 5  |
| Figure & Table 2-5 Diagram of the uMCTL2 .....                                              | 8  |
| Figure & Table 2-6 Diagram of the PHY.....                                                  | 9  |
| Figure & Table 2-7 Dual channel architecture .....                                          | 9  |
| Figure & Table 2-8 Address mapping description.....                                         | 10 |
| Figure & Table 2-9 Temperature and voltage parameters .....                                 | 11 |
| Figure & Table 2-10 Reset timing diagram .....                                              | 12 |
| Figure & Table 2-11 DDR initialization flow chart .....                                     | 13 |
| Figure & Table 3-1 Pin description table .....                                              | 15 |
| Figure & Table 3-2 System-level block diagram .....                                         | 17 |
| Figure & Table 3-3 Data flow for card read/write in DWC_msbc .....                          | 20 |
| Figure & Table 3-4 Tuning .....                                                             | 21 |
| Figure & Table 3-5 Error types and categories for SD/eMMC mode .....                        | 24 |
| Figure & Table 3-6 Card initialization sequence for different cards.....                    | 25 |
| Figure & Table 3-7 Command sequence for different cards .....                               | 25 |
| Figure & Table 3-8 Card detection.....                                                      | 26 |
| Figure & Table 3-9 Host controller setup sequence for SD .....                              | 27 |
| Figure & Table 3-10 Host controller setup sequence for eMMC interface.....                  | 28 |
| Figure & Table 3-11 Host controller clock setup sequence.....                               | 29 |
| Figure & Table 3-12 Card clock supply and stop sequence .....                               | 29 |
| Figure & Table 3-13 SD clock frequency change sequence .....                                | 30 |
| Figure & Table 3-14 SD card interface detection sequence .....                              | 31 |
| Figure & Table 3-15 eMMC card setup sequence .....                                          | 32 |
| Figure & Table 3-16 Tuning sequence .....                                                   | 33 |
| Figure & Table 3-17 Mode 1 re-tuning flow sequence .....                                    | 34 |
| Figure & Table 3-18 Auto-tuning sequence .....                                              | 35 |
| Figure & Table 3-19 SD card initialization and identification .....                         | 36 |
| Figure & Table 3-20 SD card initialization and identification (continued).....              | 37 |
| Figure & Table 3-21 Change bus width sequence.....                                          | 38 |
| Figure & Table 3-22 SD bus power control sequence.....                                      | 39 |
| Figure & Table 3-23 SD command issue and complete.....                                      | 40 |
| Figure & Table 3-24 Transaction control with data transfer (not using DMA).....             | 41 |
| Figure & Table 3-25 Transaction control with data transfer (not using DMA, continued) ..... | 42 |
| Figure & Table 3-26 Transaction control with data transfer (using ADMA2).....               | 43 |

|                                                                                                   |     |
|---------------------------------------------------------------------------------------------------|-----|
| Figure & Table 3-27 Transaction control with data transfer (using ADMA2, continued) .....         | 44  |
| Figure & Table 3-28 Transaction control with data transfer (using ADMA3).....                     | 45  |
| Figure & Table 3-29 Signal voltage switch procedure.....                                          | 46  |
| Figure & Table 3-30 Changing SD bus speed mode .....                                              | 47  |
| Figure & Table 3-31 SDIO card interrupt sequence .....                                            | 48  |
| Figure & Table 3-32 Card initialization and identification programming sequence .....             | 49  |
| Figure & Table 3-33 Programming sequence to switch to various speed modes in an eMMC device ..... | 50  |
| Figure & Table 3-34 Programming sequence to change data bus width for an eMMC device .....        | 51  |
| Figure & Table 3-35 Initializing the command queuing engine.....                                  | 51  |
| Figure & Table 3-36 Submitting and completing a task .....                                        | 52  |
| Figure & Table 3-37 Programming sequence to prepare for a boot .....                              | 52  |
| Figure & Table 3-38 Programming sequence for initiating a mandatory boot in non-DMA mode ..       | 53  |
| Figure & Table 3-39 PHY power-up and reset programming sequence.....                              | 54  |
| Figure & Table 3-40 PAD configuration sequence .....                                              | 55  |
| Figure & Table 3-41 Recommended PAD settings for SD PHY in 1.8V mode.....                         | 55  |
| Figure & Table 3-42 Possible read and write behaviors.....                                        | 56  |
| Figure & Table 3-43 Memory access examples .....                                                  | 56  |
| Figure & Table 3-44 Fields for register: SDMASA_R.....                                            | 57  |
| Figure & Table 3-45 Fields for register: BLOCKSIZE_R .....                                        | 58  |
| Figure & Table 3-46 Fields for register: BLOCKCOUNT_R .....                                       | 60  |
| Figure & Table 3-47 Fields for register: ARGUMENT_R.....                                          | 60  |
| Figure & Table 3-48 Fields for register: XFER_MODE_R .....                                        | 61  |
| Figure & Table 3-49 Fields for register: CMD_R.....                                               | 64  |
| Figure & Table 3-50 Fields for register: RESP01_R .....                                           | 67  |
| Figure & Table 3-51 Fields for register: RESP23_R .....                                           | 67  |
| Figure & Table 3-52 Fields for register: RESP45_R .....                                           | 68  |
| Figure & Table 3-53 Fields for register: RESP67_R .....                                           | 68  |
| Figure & Table 3-54 Fields for register: BUF_DATA_R.....                                          | 69  |
| Figure & Table 3-55 Fields for register: PSTATE_REG.....                                          | 69  |
| Figure & Table 3-56 Fields for register: HOST_CTRL1_R.....                                        | 76  |
| Figure & Table 3-57 Fields for register: PWR_CTRL_R.....                                          | 78  |
| Figure & Table 3-58 Fields for register: BGAP_CTRL_R .....                                        | 80  |
| Figure & Table 3-59 Fields for register: WUP_CTRL_R.....                                          | 82  |
| Figure & Table 3-60 Fields for register: CLK_CTRL_R .....                                         | 83  |
| Figure & Table 3-61 Fields for register: TOUT_CTRL_R.....                                         | 86  |
| Figure & Table 3-62 Fields for register: SW_RST_R.....                                            | 87  |
| Figure & Table 3-63 Fields for register: NORMAL_INT_STAT_R.....                                   | 89  |
| Figure & Table 3-64 Fields for register: ERROR_INT_STAT_R.....                                    | 93  |
| Figure & Table 3-65 Fields for register: NORMAL_INT_STAT_EN_R.....                                | 99  |
| Figure & Table 3-66 Fields for register: ERROR_INT_STAT_EN_R .....                                | 103 |

|                                                                       |     |
|-----------------------------------------------------------------------|-----|
| Figure & Table 3-67 Fields for register: NORMAL_INT_SIGNAL_EN_R ..... | 106 |
| Figure & Table 3-68 Fields for register: ERROR_INT_SIGNAL_EN_R .....  | 110 |
| Figure & Table 3-69 Fields for register: AUTO_CMD_STAT_R.....         | 113 |
| Figure & Table 3-70 Fields for register: HOST_CTRL2_R.....            | 116 |
| Figure & Table 3-71 Fields for register: CAPABILITIES1_R.....         | 121 |
| Figure & Table 3-72 Fields for register: CAPABILITIES2_R.....         | 126 |
| Figure & Table 3-73 Fields for register: CURR_CAPABILITIES1_R .....   | 130 |
| Figure & Table 3-74 Fields for register: CURR_CAPABILITIES2_R .....   | 132 |
| Figure & Table 3-75 Fields for register: FORCE_AUTO_CMD_STAT_R .....  | 132 |
| Figure & Table 3-76 Fields for register: FORCE_ERROR_INT_STAT_R ..... | 134 |
| Figure & Table 3-77 Fields for register: ADMA_ERR_STAT_R .....        | 137 |
| Figure & Table 3-78 Fields for register: ADMA_SA_LOW_R .....          | 138 |
| Figure & Table 3-79 Fields for register: ADMA_SA_HIGH_R.....          | 139 |
| Figure & Table 3-80 Fields for register: PRESET_INIT_R .....          | 139 |
| Figure & Table 3-81 Fields for register: PRESET_DS_R.....             | 140 |
| Figure & Table 3-82 Fields for register: PRESET_HS_R.....             | 141 |
| Figure & Table 3-83 Fields for register: PRESET_SDR12_R .....         | 143 |
| Figure & Table 3-84 Fields for register: PRESET_SDR25_R .....         | 144 |
| Figure & Table 3-85 Fields for register: PRESET_SDR50_R .....         | 145 |
| Figure & Table 3-86 Fields for register: PRESET_SDR104_R .....        | 146 |
| Figure & Table 3-87 Fields for register: PRESET_DDR50_R.....          | 147 |
| Figure & Table 3-88 Fields for register: ADMA_ID_LOW_R .....          | 148 |
| Figure & Table 3-89 Fields for register: ADMA_ID_HIGH_R .....         | 148 |
| Figure & Table 3-90 Fields for register: SLOT_INTR_STATUS_R .....     | 149 |
| Figure & Table 3-91 Fields for register: HOST_CNTRL_VERS_R .....      | 149 |
| Figure & Table 3-92 Fields for Register: EMBEDDED_CTRL_R .....        | 150 |
| Figure & Table 3-93 Fields for register: CQVER .....                  | 153 |
| Figure & Table 3-94 Fields for Register: CQCAP .....                  | 154 |
| Figure & Table 3-95 Fields for register: CQCFG .....                  | 155 |
| Figure & Table 3-96 Fields for register: CQCTL.....                   | 157 |
| Figure & Table 3-97 Fields for register: CQIS .....                   | 158 |
| Figure & Table 3-98 Fields for register: CQISE .....                  | 160 |
| Figure & Table 3-99 Fields for register: CQISGE .....                 | 161 |
| Figure & Table 3-100 Fields for register: CQIC .....                  | 163 |
| Figure & Table 3-101 Fields for register: CQTDLBA .....               | 166 |
| Figure & Table 3-102 Fields for register: CQTDLBAU .....              | 167 |
| Figure & Table 3-103 Fields for register: CQTDBR .....                | 167 |
| Figure & Table 3-104 Fields for register: CQTCN .....                 | 168 |
| Figure & Table 3-105 Fields for register: CQDQS.....                  | 169 |
| Figure & Table 3-106 Fields for register: CQDPT .....                 | 169 |
| Figure & Table 3-107 Fields for register: CQTCLR .....                | 170 |

|                                                                 |     |
|-----------------------------------------------------------------|-----|
| Figure & Table 3-108 Fields for register: CQSSC1 .....          | 170 |
| Figure & Table 3-109 Fields for register: CQSSC2 .....          | 172 |
| Figure & Table 3-110 Fields for register: CQCRDCT .....         | 172 |
| Figure & Table 3-111 Fields for register: CQRMEM .....          | 173 |
| Figure & Table 3-112 Fields for register: CQTERRI .....         | 173 |
| Figure & Table 3-113 Fields for register: CQCRI .....           | 175 |
| Figure & Table 3-114 Fields for register: CQCRA .....           | 176 |
| Figure & Table 3-115 Fields for register: PHY_CNFG .....        | 176 |
| Figure & Table 3-116 Fields for register: CMDPAD_CNFG .....     | 177 |
| Figure & Table 3-117 Fields for register: DATPAD_CNFG .....     | 178 |
| Figure & Table 3-118 Fields for register: CLKPAD_CNFG .....     | 179 |
| Figure & Table 3-119 Fields for register: STB PAD_CNFG .....    | 179 |
| Figure & Table 3-120 Fields for register: RSTNPAD_CNFG .....    | 180 |
| Figure & Table 3-121 Fields for register: PADTEST_CNFG .....    | 181 |
| Figure & Table 3-122 Fields for register: PADTEST_OUT .....     | 182 |
| Figure & Table 3-123 Fields for register: PADTEST_IN .....      | 182 |
| Figure & Table 3-124 Fields for register: PRBS_CNFG .....       | 182 |
| Figure & Table 3-125 Fields for register: PHYLPBK_CNFG .....    | 183 |
| Figure & Table 3-126 Fields for register: COMMDL_CNFG .....     | 183 |
| Figure & Table 3-127 Fields for register: SDCLKDL_CNFG .....    | 184 |
| Figure & Table 3-128 Fields for Register: SDCLKDL_DC .....      | 185 |
| Figure & Table 3-129 Fields for register: SMPLDL_CNFG .....     | 186 |
| Figure & Table 3-130 Fields for register: ATDL_CNFG .....       | 187 |
| Figure & Table 3-131 Fields for register: DLL_CTRL .....        | 187 |
| Figure & Table 3-132 Fields for register: DLL_CNFG1 .....       | 188 |
| Figure & Table 3-133 Fields for register: DLL_CNFG2 .....       | 189 |
| Figure & Table 3-134 Fields for register: DLLDL_CNFG .....      | 189 |
| Figure & Table 3-135 Fields for register: DLL_OFFSET .....      | 190 |
| Figure & Table 3-136 Fields for register: DLLMST_TSTDC .....    | 190 |
| Figure & Table 3-137 Fields for register: DLLLB T_CNFG .....    | 191 |
| Figure & Table 3-138 Fields for register: DLL_STATUS .....      | 191 |
| Figure & Table 3-139 Fields for register: DLLDBG_MLKDC .....    | 192 |
| Figure & Table 3-140 Fields for register: DLLDBG_SLKDC .....    | 192 |
| Figure & Table 3-141 Fields for register: MSHC_VER_ID_R .....   | 192 |
| Figure & Table 3-142 Fields for Register: MSHC_VER_TYPE_R ..... | 193 |
| Figure & Table 3-143 Fields for Register: MSHC_CTRL_R .....     | 193 |
| Figure & Table 3-144 Fields for register: MBIU_CTRL_R .....     | 195 |
| Figure & Table 3-145 Fields for register: EMMC_CTRL_R .....     | 196 |
| Figure & Table 3-146 Fields for register: BOOT_CTRL_R .....     | 198 |
| Figure & Table 3-147 Fields for register: AT_CTRL_R .....       | 200 |
| Figure & Table 3-148 Fields for register: AT_STAT_R .....       | 203 |

|                                                                                 |     |
|---------------------------------------------------------------------------------|-----|
| Figure & Table 4-1 Slave selection .....                                        | 208 |
| Figure & Table 4-2 Transmit FIFO Threshold (TFT) decode values .....            | 209 |
| Figure & Table 4-3 Receive FIFO Threshold (RFT) decode values.....              | 209 |
| Figure & Table 4-4 FIFO status for transmit & receive SPI transfers.....        | 211 |
| Figure & Table 4-5 FIFO status for transmit only SPI transfers .....            | 212 |
| Figure & Table 4-6 FIFO status for receive only SPI transfers.....              | 212 |
| Figure & Table 4-7 FIFO status for EEPROM read transfer mode .....              | 213 |
| Figure & Table 4-8 Effects of round-trip routing delays on sclk_out signal..... | 214 |
| Figure & Table 4-9 DMA Transmit Data Level (DMATDL) decode value .....          | 216 |
| Figure & Table 4-10 DMA Receive Data Level (DMARDL) decode value.....           | 216 |
| Figure & Table 4-11 DW_apb_ssi master SPI transfer flow .....                   | 219 |
| Figure & Table 4-12 Possible read and write behaviors.....                      | 219 |
| Figure & Table 4-13 Memory access examples .....                                | 220 |
| Figure & Table 4-14 Fields for register: CTRLR0 .....                           | 221 |
| Figure & Table 4-15 Fields for register: CTRLR1 .....                           | 228 |
| Figure & Table 4-16 Fields for register: SSIENR.....                            | 228 |
| Figure & Table 4-17 Fields for register: SER.....                               | 229 |
| Figure & Table 4-18 Fields for register: BAUDR.....                             | 230 |
| Figure & Table 4-19 Fields for register: TXFTLR.....                            | 231 |
| Figure & Table 4-20 Fields for register: RXFTLR .....                           | 231 |
| Figure & Table 4-21 Fields for register: TXFLR .....                            | 232 |
| Figure & Table 4-22 Fields for register: RXFLR .....                            | 233 |
| Figure & Table 4-23 Fields for register: SR.....                                | 233 |
| Figure & Table 4-24 Fields for register: IMR.....                               | 236 |
| Figure & Table 4-25 Fields for register: ISR.....                               | 237 |
| Figure & Table 4-26 Fields for register: RISR.....                              | 239 |
| Figure & Table 4-27 Fields for register: TXOICR .....                           | 241 |
| Figure & Table 4-28 Fields for register: RXOICR .....                           | 242 |
| Figure & Table 4-29 Fields for register: RXUICR .....                           | 242 |
| Figure & Table 4-30 Fields for register: MSTICR .....                           | 243 |
| Figure & Table 4-31 Fields for register: ICR.....                               | 244 |
| Figure & Table 4-32 Fields for register: DMACR .....                            | 244 |
| Figure & Table 4-33 Fields for register: DMATDLR.....                           | 245 |
| Figure & Table 4-34 Fields for register: DMARDLR .....                          | 246 |
| Figure & Table 4-35 Fields for register: IDR .....                              | 246 |
| Figure & Table 4-36 Fields for register: SSI_VERSION_ID .....                   | 247 |
| Figure & Table 4-37 Fields for register: DRx (for x = 0; x <= 35) .....         | 248 |
| Figure & Table 4-38 Fields for register: RX_SAMPLE_DLY .....                    | 248 |
| Figure & Table 4-39 Fields for register: SPI_CTRLR0 .....                       | 249 |

# List of Abbreviations

| Abbreviations | Full Spelling                   | Chinese Explanation |
|---------------|---------------------------------|---------------------|
| ADMA          | Advanced Direct Memory Access   | 先进的直接内存访问           |
| CAM           | Content Addressable Memory      | 内容可寻址存储器            |
| DDR           | Double Data Rate SDRAM          | 双倍速率同步动态随机存储器       |
| DMA           | Direct Memory Access            | 直接内存访问              |
| eMMC          | Embedded Multi Media Card       | 嵌入式多媒体卡             |
| MSHC          | Mobile Storage Host Controller  | 移动存储主控              |
| QoS           | Quality of Service              | 服务质量                |
| SD Card       | Secure Digital Card             | 安全数字卡               |
| SDIO          | Secure Digital Input and Output | 安全数字输入输出            |

## 1 SRAMC

---

By default, the chip provides 1.5MB +0.5MB on-chip SRAM for software expansion. The last 0.5MB address space can be used only when the DSP reset is released and DSP is not working.



## 2 LPDDR4

### 2.1 Overview

This document describes the initialization steps and precautions when using the DDR subsystem. The DDR subsystem consists of a DDR controller (uMCTL2) and two independent PHYs, as shown in Figure & Table 2-1. The DDRC is responsible for the configuration of logic layers such as arbitration, QoS, and address mapping. The PHYs convert DFI logic signals into LPDDR4 storage control signals and contain PMU, which can independently complete external particle training and initialization.



Figure & Table 2-1 DDR subsystem block diagram

The DDRC interface can receive 5 AXI inputs and supports the standard AMBA AXI4 protocol.

The PHY interface supports up to 64-bit LPDDR4 or LPDDR4x, and the maximum rate is 4267Mbps.

### 2.2 Main Features

The built-in DDRC (uMCTL2) and two independent PHYs realize the data access to the external memory LPDDR4 SDRAM by the master device such as CPU in the SoC system. The following features are supported:

- Supports the standard JEDE LPDDR4/LPDDR4x, the maximum bit rate is 4267Mbps.

- Supports software-triggered ZQ calibration and hardware-based ZQ calibration at fixed intervals.
- Supports dual-channel interleaved 64-bit mode.
- Supports single-channel 32-bit mode.
- Supports software-configured DQ/CA bit exchange.
- Supports periodic delay unit training to compensate for changes in voltage and temperature.
- PHY built-in independent training program:
  - The PHY master interface supports periodic training for LPDDR4.
  - CA bus training
  - Write/read training
  - Reference voltage training for read and write
- Testability features:
  - Address data channel supports internal loopback self-test
  - Self-test of delay unit
  - PLL lock test
  - ZQ calibration test

## 2.3 Interface

The DDR subsystem supports the standard JEDEC LPDDR4 protocol and is compatible with LPDDR4x. It supports 64-bit dual channel mode and 32-bit single channel mode. The specific modes are as follows:

- 64-bit LPDDR4/LPDDR4x, capacity 4GB/8GB



Figure & Table 2-2 64-bit dual channel connection diagram

- 32-bit LPDDR4/LPDDR4x, capacity 2GB/4GB



Figure & Table 2-3 32-bit single channel connection diagram

### 2.3.1 Pin Description

Figure & Table 2-4 Pin description table

| Pin Name       | Direction | Width | Description                                    |
|----------------|-----------|-------|------------------------------------------------|
| DDR0_CKT       | 0         | 2     | Differential clock of channel 0 lower 16 bits  |
| DDR0_CKC       |           |       |                                                |
| DDR0_CA0~5     | 0         | 6     | Command address bus of channel 0 lower 16 bits |
| DDR0_CS0~1     | 0         | 2     | CS of channel 0 lower 16 bits                  |
| DDR0_CKE0~CKE1 | 0         | 2     | Clock enable of channel 0 lower 16 bits        |



| Pin Name       | Direction | Width | Description                                                                          |
|----------------|-----------|-------|--------------------------------------------------------------------------------------|
| DDR0_DQSC0     | IO        | 2     | Bidirectional differential data select of channel 0 bit1~7                           |
| DDR0_DQST0     |           |       |                                                                                      |
| DDR0_DQSC1     | IO        | 2     | Bidirectional differential data select of channel 0 bit8~15                          |
| DDR0_DQST1     |           |       |                                                                                      |
| DDR0_DQ0~15    | IO        | 16    | Data channel of channel 0 lower 16 bits                                              |
| DDR0_DMI0~1    | IO        | 2     | Data mask/inverse of channel 0 lower 16 bits                                         |
| DDR1_CKT       | O         | 2     | Differential clock of channel 0 upper 16 bits                                        |
| DDR1_CKC       |           |       |                                                                                      |
| DDR1_CA0~5     | O         | 6     | Command address bus of channel 0 upper 16 bits                                       |
| DDR1_CS0~1     | O         | 2     | CS of channel 0 upper 16 bits                                                        |
| DDR1_CKE0~CKE1 | O         | 2     | Clock enable of channel 0 upper 16 bits                                              |
| DDR1_DQSC0     | IO        | 2     | Bidirectional differential data select of channel 0 bit16~23                         |
| DDR1_DQST0     |           |       |                                                                                      |
| DDR1_DQSC1     | IO        | 2     | Bidirectional differential data select of channel 0 bit24~31                         |
| DDR1_DQST1     |           |       |                                                                                      |
| DDR1_DQ0~15    | IO        | 16    | Data channel of channel 0 upper 16 bits                                              |
| DDR1_DMI0~1    | IO        | 2     | Data mask/inverse of channel 0 upper 16 bits                                         |
| DDR1_RSTN      | O         | 1     | Reset signal of channel 0, active low                                                |
| DDR1_VREF      | O         | 1     | Reference voltage signal of channel 0, which can be used to monitor internal signals |
| DDR1_ZN        | O         | 1     | Reference resistance of channel 0, external 120ohm resistance, accuracy +/-1%        |
| DDR2_CKT       | O         | 2     | Differential clock of channel 1 lower 16 bits                                        |
| DDR2_CKC       |           |       |                                                                                      |
| DDR2_CA0~5     | O         | 6     | Command address bus of channel 1 lower 16 bits                                       |
| DDR2_CS0~1     | O         | 2     | CS of channel 1 lower 16 bits                                                        |
| DDR2_CKE0~CKE1 | O         | 2     | Clock enable of channel 1 lower 16 bits                                              |
| DDR2_DQSC0     | IO        | 2     | Bidirectional differential data select of channel 1 bit0~7                           |
| DDR2_DQST0     |           |       |                                                                                      |
| DDR2_DQSC1     | IO        | 2     | Bidirectional differential data select of channel 1 bit8~15                          |
| DDR2_DQST1     |           |       |                                                                                      |



| Pin Name                 | Direction | Width | Description                                                                          |
|--------------------------|-----------|-------|--------------------------------------------------------------------------------------|
| DDR2_DQ0~15              | IO        | 16    | Data channel of channel 1 lower 16 bits                                              |
| DDR2_DMI0~1              | IO        | 2     | Data mask/inverse of channel 1 lower 16 bits                                         |
| DDR3_CKT<br>DDR3_CKC     | O         | 2     | Differential clock of channel 1 upper 16 bits                                        |
| DDR3_CAO~5               | O         | 6     | Command address bus of channel 1 upper 16 bits                                       |
| DDR3_CS0~1               | O         | 2     | CS of channel 1 upper 16 bits                                                        |
| DDR3_CKE0~CKE1           | O         | 2     | Clock enable of channel 1 upper 16 bits                                              |
| DDR3_DQSC0<br>DDR3_DQST0 | IO        | 2     | Bidirectional differential data select of channel 1 bit16~23                         |
| DDR3_DQSC1<br>DDR3_DQST1 | IO        | 2     | Bidirectional differential data select of channel 1 bit24~31                         |
| DDR3_DQ0~15              | IO        | 16    | Data channel of channel 1 upper 16 bits                                              |
| DDR3_DMI0~1              | IO        | 2     | Data mask/inverse of channel 1 upper 16 bits                                         |
| DDR2_RSTN                | O         | 1     | Reset signal of channel 1, active low                                                |
| DDR2_VREF                | O         | 1     | Reference voltage signal of channel 1, which can be used to monitor internal signals |
| DDR2_ZN                  | O         | 1     | Reference resistance of channel 1, external 120ohm resistance, accuracy +/-1%        |

## 2.3.2 Electrical Parameters

Refer to the JEDEC protocol description.

## 2.4 Function Description

### 2.4.1 Overview

#### 2.4.1.1 uMCTL2

The uMCTL2 is responsible for converting the AXI protocol into the DFI protocol. It consists of the interleaver and two DDRCs, as shown in Figure & Table 2-5.



Figure & Table 2-5 Diagram of the uMCTL2

The uMCTL2 has the following main modules:

- AXI port interface: This module provides a standard AXI interface. It is responsible for AXI data sending and receiving, address processing and reordering of read data.
- Port arbiter: This module provides arbitration mechanism for each port.
- DDRC: Built-in Content Addressable Memory (CAM), used to store the received commands. Schedules according to row, column and bank addresses and converts the AXI protocol into the DFI protocol and sends to PHY.
- APB register: Used to configure registers for DDRC.

#### 2.4.1.2 PHY

The PHY consists of a soft core PUB and a hardened module. The hardened module consists of four DBYTEs, six AXI4s and one Master. The structure is shown in Figure & Table 2-6.



Figure &amp; Table 2-6 Diagram of the PHY

- PUB: Built-in PMU, responsible for DDR training and initialization.
- DBYTE: Connects to the 1byte data interface of SDRAM.
- ACX4: Connects to the 4-way address/command interface of SDRAM.
- Master: Built-in PLL, providing clock source.

## 2.4.2 Address Mapping

### 2.4.2.1 Channel Interleaving

To improve schedule efficiency and system bandwidth performance, the DDR subsystem adopts a dual channel interleaved architecture. Users can implement interleaving with different granularities according to actual needs. The current system defaults to setting bit9 of the system address as the interleaving bit, that is, users can interleaving access different channels every 512B. In 32-bit single channel mode, users can access only channel 0 by configuring the address map register, and only the 32-bit DDR is connected externally.



Figure &amp; Table 2-7 Dual channel architecture

### 2.4.2.2 Address Mapping Configuration

Different mapping methods are implemented by configuring registers ADDRMAP0~11. The recommended groups of configurations are as follows:

Figure &amp; Table 2-8 Address mapping description

| <b>Mode</b>  | <b>Row Address Width</b> | <b>Column Address Width</b> | <b>Rank Address</b> | <b>Row Address</b> | <b>Channel Address</b> | <b>Bank Address</b> | <b>Column Address</b> |              |
|--------------|--------------------------|-----------------------------|---------------------|--------------------|------------------------|---------------------|-----------------------|--------------|
|              | <b>16</b>                | <b>10</b>                   | <b>1</b>            | <b>[15:0]</b>      | <b>1</b>               | <b>[2:0]</b>        | <b>[9:7]</b>          | <b>[6:0]</b> |
| 8GB<br>64bit | 16                       | 10                          | [32]                | [31:16]            | [9]                    | [15:13]             | [12:10]               | [8:2]        |
| 4GB<br>32bit | 16                       | 10                          | [31]                | [30:15]            | -                      | [14:12]             | [11:9]                | [8:2]        |
| 4GB<br>64bit | 16                       | 10                          | -                   | [31:16]            | [9]                    | [15:13]             | [12:10]               | [8:2]        |
| 2GB<br>32bit | 16                       | 10                          | -                   | [30:15]            | -                      | [14:12]             | [11:9]                | [8:2]        |

### 2.4.3 Auto Refresh Mode

When RFSHCTL3.dis\_auto\_refresh is configured to a value other than 0, the DDRC will automatically generate refresh instructions periodically. In addition, the DDRC supports predictive refresh. When the refresh instruction is held more than one time, the controller can perform predictive refresh. That is, when the CAM does not have transaction of the corresponding rank/bank, the controller will automatically insert the corresponding refresh instruction. The RFSHCTL0.refresh\_to\_x1\_x32 register determines how long the corresponding transaction is not in the CAM before inserting the predictive refresh. Every time a predictive refresh is performed, tREFI consumption count is reduced by one time, so it will buy time for the critical refresh and ensure that the number of predictive refreshes will not exceed that of refreshes that should be.

After setting RFSHCTL0.per\_bank\_refresh=1, per-bank refresh is enabled instead of all-bank refresh. After enabling per-bank refresh, you need to set tREFIpb and tRFCpb to the corresponding registers RFSHTMG.t\_rfc\_nom\_x1\_x32 and RFSHTMG.t\_rfc\_min. In this mode, the controller will schedule transactions to other banks according to the currently refreshed bank to improve potential performance. To improve the efficiency of scheduling, you need to set RFSHTMG.t\_trfc\_nom\_x1\_sel=1. LPDDR4 per-bank refresh can be performed in any bank order. When there is no transaction in the CAM or the current bank has been recharged, the controller will give priority to the per-bank refresh of the current bank. For related register description, refer to DWC\_ddr\_umctl2\_databook.pdf.

### 2.4.4 Low Power Management

DDRC supports a variety of low-power designs. When PWRCTL.dfi\_dram\_clk\_disable=1, the IO clock will be automatically turned off in the following scenarios to save power:

- Self-refresh
- In working mode, no access request

When PWCTL.selfref\_en=1 and the system is in idle state, that is, there is no read/write memory access on the DDRC bus interface for a certain period, DDRC will trigger to enter self-refresh. When the system detects an access request, the DDRC will automatically exit self-refresh immediately and turn on the IO clock.

## 2.4.5 Periodic Training

With the change of voltage and temperature, the LPDDR4 SDRAM parameters tDQSCK and tDQS2DQ will be affected. The DDR subsystem will periodically perform re-training to compensate for the impact of temperature and voltage changes. For detailed principles, refer to dwc\_ddrn\_phy\_training\_firmware\_application\_note.a.2020.06.pdf Chapter 13. For the specs of specific parameters, refer to the respective manufacturer's standards. The following table shows the specs of Micron LPDDR4.

Figure & Table 2-9 Temperature and voltage parameters

| Parameter                             | Name         | min  | Max  | Unit    |
|---------------------------------------|--------------|------|------|---------|
| Read DQS output access from CK_t/CK_c | tDQSCK       | 1500 | 3500 | ps      |
| tDQSCK voltage variation              | tDQSCK_VOLT  | -    | 7    | ps/mv   |
| tDQSCK temperature variation          | tDQSCK_TEMP  | -    | 4    | ps/°C   |
| DQ-to-DQS offset                      | tDQS2DQ      | 200  | 800  | ps      |
| tDQS2DQ voltage variation             | tDQS2DQ_VOLT | -    | 33   | ps/50mv |
| tDQS2DQ temperature variation         | tDQS2DQ_TEMP | -    | 0.6  | ps/°C   |

The compensation interval is configured by the register PhyMstrTrainInterval of the PHY and the default is about 0.7s. For the description of this register, refer to dwc\_lpddr4x\_multiph\_y\_pub\_databook\_2.41a.pdf.

## 2.5 Usage

### 2.5.1 Reset Timing

When performing initialization, the clock and reset relationship must be as shown in Figure & Table 2-10.



Figure & Table 2-10 Reset timing diagram

Reset within the DDR subsystem are register controllable.

1. Release PwrOKIn, `ddr_sysreg.DDR_CFG0[6]=1`.
2. Delay 1us.
3. Release APB reset (`ddr_sysreg.DDR_CFG0[4]=1`) and PHY reset (`ddr_sysreg.DDR_CFG0[7]=1`).
4. Configure the controller registers.
5. Release controller core reset (`ddr_sysreg.DDR_CFG0[5]=1`) and AXI port reset (`ddr_sysreg.DDR_CFG0[13:8]=0x1f`).
6. Initialize the PHY.
7. Execute DFI handshake, the controller enters mission mode.

## 2.5.2 Initialization Process

The DDR initialization flow chart is as follows:



Figure &amp; Table 2-11 DDR initialization flow chart

## 3 eMMC/SD

---

### 3.1 Overview

The DesignWare Cores DWC\_mshc is a highly configurable and programmable, high performance Mobile Storage Host Controller (MSHC) with AXI as the bus interface for data transfer.

DWC\_mshc provides a flexible bus interface that enables you to integrate DWC\_mshc into embedded applications for System-on-a-Chip (SoC) designs. DWC\_mshc has an AXI master interface that supports 64-bit address and data bus. Besides supporting non-DMA mode, DWC\_mshc supports various DMA options such as SDMA, ADMA2, and ADMA3 as specified in the SD Host Controller Standard.

DWC\_mshc primarily targets host-controller and card-reader applications. In such instances, the device memory card to which the DWC\_mshc sends or receives data is typically a device for FLASH mass storage. The DWC\_mshc is optimized for the following applications and systems:

- Portable electronic devices
- High-speed storage applications

Specifically, DWC\_mshc is targeted at these devices:

- Mobile phones and laptops
- Digital cameras and camcorders
- Printer devices
- Embedded applications

### 3.2 Main Features

The main features of DWC\_mshc are shown below.

- Supports SD memory and SD Input/Output (SDIO) digital interface protocol, and compliant with SD HCI specification.
- Uses the same SD-HCI register set for eMMC transfers.
- Supports eMMC protocols including eMMC 5.1.
- Supports SD-HCI host version 4 mode or less.
- Supports the following data transfer types for SD and eMMC modes:
  - CPU
  - SDMA
  - ADMA2
  - ADMA3
- Supports independent controller, slave interface and master interface clocks.
- Supports gating of controller base clock if host controller is inactive.
- Support context aware functional clock gates.
- Applications can gate the slave interface clock if host controller is inactive.
- Data buffering

- 256 + 32 buffer depth
- Automatic packing/unpacking of data to fit buffer width
- Interrupt outputs
  - Combined interrupt outputs
  - Supports interrupt enabling and masking.
- Supports Command Queuing Engine (CQE) and compliant with eMMC CQ HCI.
  - Programmable scheduler algorithm selection of task execution
  - Supports data prefetch for back-to-back write operations.
- Supports tuning:
  - SD/eMMC tuning using CMD19 (SD) or CMD21 (eMMC)
  - Mode 1 re-tuning – Host driver maintains the re-tune timer
  - Fully software driven tuning/re-tuning operations
  - Auto-tuning or mode 3 re-tuning

### 3.3 Interface

In the SoC system, there are 3 instances of DWC\_mshc named eMMC/SDIO0/SDIO1. The data width of eMMC is 8bit with HS400 supported. And the data width of SDIO0 and SDIO1 are 4bit with SDR104 supported. The PADs of eMMC/SDIO0/SDIO1 are shown in Figure & Table 3-1.

Figure & Table 3-1 Pin description table

| Pin Name  | Direction | Width | Description                                                                                                                                      |
|-----------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| EMMC_CLK  | O         | 1     | CLK signal, 1.8V domain                                                                                                                          |
| EMMC_CMD  | IO        | 1     | CMD I/O signal, 1.8V domain                                                                                                                      |
| EMMC_DAT0 | IO        | 1     | DAT0 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT1 | IO        | 1     | DAT1 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT2 | IO        | 1     | DAT2 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT3 | IO        | 1     | DAT3 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT4 | IO        | 1     | DAT4 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT5 | IO        | 1     | DAT5 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT6 | IO        | 1     | DAT6 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DAT7 | IO        | 1     | DAT7 I/O signal, 1.8V domain                                                                                                                     |
| EMMC_DS   | I         | 1     | This signal is generated by the device and only used in HS400 mode. The frequency of this signal follows the frequency of EMMC_CLK, 1.8V domain. |
| EMMC_RSTN | O         | 1     | eMMC card reset signal output, 1.8V domain                                                                                                       |
| SDIO0_CLK | O         | 1     | CLK signal, 1.8V/3.3V domain                                                                                                                     |

| Pin Name    | Direction | Width | Description                                                                                                                                                    |
|-------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDIO0_CMD   | IO        | 1     | CMD I/O signal, 1.8V/3.3V domain                                                                                                                               |
| SDIO0_DAT0  | IO        | 1     | DAT0 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO0_DAT1  | IO        | 1     | DAT1 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO0_DAT2  | IO        | 1     | DAT2 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO0_DAT3  | IO        | 1     | DAT3 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO0_DETIN | I         | 1     | Card detect signal<br>When this is 0, it represents card is connected.<br>When this signal goes from 0 to 1, card insertion interrupt is generated if enabled. |
| SDIO0_WPRTN | I         | 1     | SD card write protect signal<br>When this is 0, it represents card is write protected.                                                                         |
| SDIO1_CLK   | O         | 1     | CLK signal, 1.8V/3.3V domain                                                                                                                                   |
| SDIO1_CMD   | IO        | 1     | CMD I/O signal, 1.8V/3.3V domain                                                                                                                               |
| SDIO1_DAT0  | IO        | 1     | DAT0 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO1_DAT1  | IO        | 1     | DAT1 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO1_DAT2  | IO        | 1     | DAT2 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO1_DAT3  | IO        | 1     | DAT3 I/O signal, 1.8V/3.3V domain                                                                                                                              |
| SDIO1_DETIN | I         | 1     | Card detect signal<br>When this is 0, it represents card is connected.<br>When this signal goes from 0 to 1, card insertion interrupt is generated if enabled. |
| SDIO1_WPRTN | I         | 1     | SD card write protect signal<br>When this is 0, it represents card is write protected.                                                                         |

## 3.4 Function Description

### 3.4.1 Overview of Architecture

This section describes the main functional building blocks of the DWC\_msHC controller, represented in Figure & Table 3-2.



Figure & Table 3-2 System-level block diagram

Following are the various modules in the MSHC:

- **Master Bus Interface Unit (MBIU)**  
This MBIU implements the logic to transfer data on the AMBA Extensible Interface Bus (AXI). The AXI interface transfers data to and from the system memory through the AXI master bus interface.
- **AHB Slave Bus Interface (SBI) module**  
The SBI module implements the logic to primarily access the DWC\_mshc registers by using an external AMBA high-performance (AHB) bus. This module supports only the little endian scheme for register access.
- **JTAG Interface**  
The JTAG interface is not configured for use.
- **DMA Engine**  
The DMA Engine unit handles data transfer between DWC\_mshc and system memory.
- **Host Controller Registers**  
The host controller register unit comprises the standard SD host controller registers as specified in the SD Specifications Part A2 SD Host Controller Standard Specification Version 4.20a. It also includes Command Queuing registers compliance to JEDEC eMMC 5.1 HCI specification.  
These registers are implemented in three clock domains, namely AXI master bus interface clock (aclk), AHB slave bus interface clock (hclk), and controller base clock (bclk). The non-transfer related registers are implemented in the AHB slave clock domain, so that the controller base clock can be gated for power savings.
- **SRAM Controller (Packet buffer interface)**

The SRAM controller interfaces the packet buffer of the host and the transaction controller units (SD/UHS-I/eMMC unit).

- SD/UHS-I/eMMC Unit  
SD/UHS-I/eMMC unit manages the SD/eMMC interface protocols.

- CQE  
This module implements command queuing and includes the following:
  - Task scheduler with the ability to prioritize execution of tasks
  - Control logic for descriptor fetch
  - Control and sequence task submission and execution
  - Status polling
  - Timers and counter dedicated for CQE operation

### 3.4.2 Device and Card Interface

#### 3.4.2.1 SD Card Interface

SD unit is responsible for managing SD interface protocols.

The key features of this unit are as follows:

- Generate DS/High-speed/UHS-I command and data packets.
- Generate CRC and check for command and data packets.
- Handle packet timeouts.
- Support 1-bit DAT and 4-bit DAT modes.
- Handle SDIO card interrupt.
- Supports Default Speed (DS), High-Speed (HS), SDR12, SDR25, SDR50 and SDR104 speed modes.

#### 3.4.2.2 eMMC Card Interface

eMMC unit is responsible for managing eMMC interface protocols.

The key features of this unit are as follows:

- Generate eMMC bus command and data packets.
- Generate CRC and check for command and data packets.
- Handle packet timeouts.
- Support 1-bit DAT, 4-bit DAT, and 8-bit DAT modes.
- Support legacy, High Speed SDR, High Speed DDR, HS200, and HS400 modes.

### 3.4.3 Master Bus Interface

DWC\_mshc utilizes the MBIU to initiate data traffic with the system memory. The system memory read/write transfer requests are initiated by the DMA of DWC\_mshc through a native master interface, which is the Generic Master (GM) interface. Irrespective of the selected system bus protocol, the GM interface is used to interact between the DMA and the MBIU. DMA transfers utilize the read descriptors to transfer (write/read) data from system memory.



The GM interface operates on a packet- or descriptor-level transfer. That is, each request represents a descriptor or packet size transfer. In contrast, the AXI gaskets break the GM request into multiple AXI transfers as appropriate for the interface.

Wait cycles may appear on the master read or write data path. This happens if the RAM controller does not have enough bandwidth to serve both the Transaction Layer Unit (TLU) and the DMA. It can also occur during CQE as the DMA FIFOs are also utilized for message passing.

The AXI master interface is a gasket between the native GM and the AXI bus. DMA read and write accesses are initiated by the DWC\_mshc controller through the AXI master interface to read descriptors, and read/write transfer data. The read and write channels are independent and can be active simultaneously. However, if a read access is dependent on a write access completing first, the controller does not issue the DMA read until it receives the DMA write response from AXI.

### 3.4.4 AHB Slave Bus Interface

The AHB slave interface supports the following features:

- Fully compliant with AMBA 2.0 AHB slave
- Single burst transfer
- 32-bit write or read transfers to DWC\_mshc registers
- Transfer response: OKAY, ERROR, and RETRY responses

### 3.4.5 DMA Engine

The DMA Engine unit handles data transfer between DWC\_mshc and the system memory. The key features of this unit are as follows:

- Support SDMA/ADMA2/ADMA3 modes.
- Fetch the descriptor and data. The same DMA engine is used to interleave data transfer and descriptor fetch. This enables new task descriptor fetches (for CMD44 and CMD45) while DMA is moving data during task execution (for CMD46 and CMD47).
- The AXI transaction ID 0 is used for moving data and AXI transaction ID 1 is used to fetch task descriptors.
- Pre-fetch data for back-to-back eMMC write commands.
- Write back the received data packets to the system memory.

### 3.4.6 SRAM Controller

The SRAM controller interfaces the packet buffer of the host and the transaction controller units (SD/UHS-I/eMMC). The buffer depth is configured as 256 + 32, where size of each location is equal to the AXI data width (64bits).

As write and read transfers to the cards do not occur simultaneously, a single shared buffer is used for read and write operations to save area. During the data transfer command handshake, the read/write bit of the command register is sampled and stored. This internal bit defines whether the DWC\_mshc is in the read or write mode.

The packet buffer uses a single clock single-port RAM synchronous to the controller base clock (bclk).

### 3.4.7 Data Flow for Card Read/Write in DWC\_mshc

Figure & Table 3-3 explains how data flows from the card interface (SD/SDIO/eMMC) to the AXI interface through packet buffer for card read transfer. Received data from the card interface is written into packet buffer. When one block of data (SD/SDIO/eMMC) is received, DMA starts transmitting that data to the system by reading it from packet buffer. For a card write transfer, data flows in the reverse direction. DMA writes data into packet buffer that is subsequently read by the card interface logic.

DMA and card interface logic can work simultaneously as read and write to packet buffer can be interleaved. For card read, DMA can send out previous block while card interface logic is receiving current block. Whereas for card write, DMA can write current block into packet buffer while card interface logic is sending out previous block.



Figure & Table 3-3 Data flow for card read/write in DWC\_mshc

### 3.4.8 Tuning in DWC\_mshc

DWC\_mshc is compatible with SD 4.2 and eMMC 5.1 protocols and both these protocols have speed modes in which the incoming data must be sampled on a clock with a programmable sampling. Therefore, a method called tuning is required to identify the correct phase where the data can be robustly sampled.

Following are the tuning and re-tuning modes supported in DWC\_mshc:

- Tuning flow based on CMD21 (eMMC) or CMD19 (SD)
- Mode 1 (software assisted) re-tuning flow
- Mode 3 (hardware managed) re-tuning (that is, auto-tuning)



- Software driven tuning flow

As shown in Figure & Table 3-4, the output of DWC\_mshc signals tuning\_cclk\_sel and tuning\_cclk\_sel\_update are driven by the internal tuning engine and must be used for phase control of the DelayLine. These outputs are used by tuning engine to change the incoming phase of cclk\_rx clock so that it can find the phase at which incoming data on sd\_dat\_in port can be robustly sampled.



Figure & Table 3-4 Tuning

The high-speed SDR modes that need tuning are eMMC HS200 and SD SDR104. The tuning sequence for SD or eMMC is a software-assisted sequence in which the hardware controls the DelayLine and calculates the phase for robust sampling, and the software determines the necessity for tuning and starting the tuning sequence.

### 3.4.8.1 Mode 1 Re-Tuning

DWC\_mshc implements mode 1 re-tuning as per the SD HCI specification and is available for use even in the eMMC mode of operation. Mode 1 re-tuning is similar to the tuning sequence, and a distinction between the two is made using HOST\_CTRL2\_R.SAMPLE\_CLK\_SEL register field value. The SD HCI specification recommends that software must invoke re-tuning sequence for every 4 MB of data transferred or as per the re-tuning timer maintained by the software.

During re-tuning, the tuning engine tests the validity of the sampling window, using the information gathered in the initial tuning sequence. If the window is unaltered, re-tuning sequence is quick (total CMD21/CMD19 iterations equal to number of Pass-steps +1). In case of any drifts, re-tuning may result in more CMD21/CMD19 iterations (equal to total steps of DelayLine).

Following are the tuning schema available for mode 1 re-tuning:

- Threshold Based Selection Tuning Schema

This mode allows the tuning engine to select the first complete sampling window that meets the threshold criteria defined. In this mode, a complete sampling window is preferred over a partial sampling window. Tuning stops when a complete sampling window meets the threshold criteria. Tuning also stops when all the taps are parsed.

- Backward Compatible Tuning Schema

This mode allows the tuning engine to function as it was in 1.50a and earlier releases of the DWC\_mshc. In this mode, a complete sampling window is preferred over a partial sampling window. Tuning stops when either a complete sampling window is found or when all taps are parsed. There is no minimum threshold on the width of sampling window.

- **Largest Sampling Window Tuning Schema**

This mode allows the tuning algorithm to move through all the taps of delay line to identify the largest sampling window available. In this mode, tuning stops only when all the taps are parsed. The algorithm picks the largest sampling window.

### **3.4.8.2 Software Tuning**

DWC\_mshc implements a fully software-controlled tuning sequence called the software tuning. The software can set the AT\_CTRL\_R. SW\_TUNE\_EN bit to take control of tuning\_cclk\_sel, tuning\_cclk\_sel\_update and sample\_clk\_sel signals which form the tuning and data sampling interface. When AT\_CTRL\_R. SW\_TUNE\_EN is set to 1, the software can write into the AT\_STAT\_R. CENTER\_PH\_CODE bit to change the value of tuning\_cclk\_sel. While using software tuning, software must calculate the center phase and periodic re-tuning of the sampling clock.

### **3.4.8.3 Auto-Tuning or Mode 3 Re-Tuning**

Auto-tuning is a hardware-managed re-tuning feature that complies with the SD HCI Mode3 re-tuning procedure. Auto-tuning removes the need for the host software to re-tune the sampling clock for every 4 MB of data transfer (SD HCI). A tuning sampling clock is recommended in both SD and eMMC modes to ensure ease in timing closure and for robust operation while operating at high SDR speeds, such as SDR104 and HS200.

Following are some functionalities of the auto-tuning feature:

- Requires tuning based on CMD19 (SD) or CMD21 (eMMC) for initialization.  
Once initialized, the auto-tuning engine can detect drifts and calculate corrections when data transfers are in progress.
- Does not depend on tuning commands of SD/eMMC for drift detection or corrections.  
This is necessary as auto-tuning happens in the background during regular data/CMD transfers.
- Detects drifts for all active data lines of the controller.
- Provides a software selectable correction interval.  
Corrections can be applied either at block boundary or between data transfers.
- Handles drifts  
Drift monitoring window is hardware initialized. Software can program the AT\_CTRL\_R register to alter the initialized values, if required. If auto-tuning fails to correct a detected drift, the tuning-error interrupt is set.

Following is a procedure for an auto-tuning operation:

1. Software must initiate tuning sequence based on CMD19 (for SD) or CMD21 (for eMMC) for initializing the Auto-tuning engine.
2. After initialization, the auto-tuning engine is activated by default for all data read transfers.



3. Auto-tuning engine uses a DM DelayLine to generate drift\_cclk\_rx.
4. The drift\_cclk\_rx is generated using the same source as cclk\_rx; however, its phase is controlled by the autotune\_cclk\_sel outputs of the auto-tuning engine.
5. Auto-tuning engine uses the data sampled on drift\_cclk\_rx to check for drifts on the data lines. A drift is detected if following data errors occur:

- Data CRC error
- Start bit error
- End bit error

These drift checks are active only when READ transfers are in progress in HS200/SDR104 modes.

6. On drift detection, auto-tuning engine sweeps through DM DelayLine phases until it finds a sampling window without drifts.
7. The new sampling window range allows the auto-tuning engine to calculate a correction for the sampling phase.
8. The calculated correction is applied on the sampling DelayLine using tuning\_cclk\_sel outputs at the software-selected correction interval.

According to the SD specification, the timer load value is a capability that is a configuration value and not a programmable value. This value must be maintained by the software and not by the hardware. The software must maintain the re-tuning timer and must start this timer at the end of a data transfer and reset it when a new data transfer starts. Software must invoke the CMD-based tuning procedure when this timer expires.

### 3.4.8.4 Interrupts

In DWC\_mshc, interrupts are generated based on various events.

There are two interrupt outputs provided by DWC\_mshc:

- intr
- wakeup\_intr

The interrupt signal must be used as interrupt for different events during active mode. During standby mode, wakeup\_intr must be used to identify any wakeup event, such as card removal or insertion, or an SDIO card interrupt. The interrupts are of level type, that is, the interrupt remains asserted (high) until it is cleared by the host or the software.

The interrupt status registers indicate the events that caused the interrupt generation. Each event can be prevented from asserting the interrupt on the interrupt signal by setting the corresponding mask bits.

A bit in interrupt status register is set only if the corresponding interrupt status enable is set and interrupt event is observed. This bit set in interrupt status register asserts interrupt only if corresponding bit in interrupt signal enable is set.

Host driver is responsible for enabling wakeup signals and disabling interrupt signals when the host system enters its standby mode, and for disabling wakeup signals and enabling interrupt signals when host system goes into active mode. The host driver must not enable both at the same time. Interrupt signals are enabled using interrupt signal enable and wakeup signals are enabled using wakeup event enable.

### 3.4.8.5 Error Detection

Figure & Table 3-5 lists error types and categories into which they can be grouped for SD/eMMC mode.

Figure & Table 3-5 Error types and categories for SD/eMMC mode

| Error Type          | Categories                                                                                                                                                                                                                                                                                                                 |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Command errors      | <ul style="list-style-type: none"> <li>■ Command timeout error</li> <li>■ Command CRC error</li> <li>■ Command end bit error</li> <li>■ Command index error</li> <li>■ Command conflict error</li> <li>■ Response error</li> </ul>                                                                                         |
| Auto command errors | <ul style="list-style-type: none"> <li>■ Command not issued by auto CMD12 error</li> <li>■ Auto command timeout error</li> <li>■ Auto command CRC error</li> <li>■ Auto command end bit error</li> <li>■ Auto command index error</li> <li>■ Auto command conflict error</li> <li>■ Auto command response error</li> </ul> |
| Data errors         | <ul style="list-style-type: none"> <li>■ Data timeout error</li> <li>■ Data CRC error</li> <li>■ Data end bit error</li> <li>■ ADMA error</li> <li>■ Tuning error</li> </ul>                                                                                                                                               |

## 3.5 Usage

Following is the programming sequence required before starting the data transfer with the card:

1. Start providing hclk to DWC\_mshc and apply its reset hresetn. This clock is required for card detection logic and for accessing most of the registers in DWC\_mshc.
2. Check if the card is already inserted by reading Present State Register (PSTATE\_REG). This step is only required for a removable card. If the card is already inserted (eMMC), then go to Step 4.
3. Wait for the card insertion interrupt. This step is only required for removable card. Card detection sequence is described in section “Card Detection”.
4. Setup basic settings for DWC\_mshc as described in section “Host Controller Setup Sequence”. It involves settings such as the bus power voltage level for the card, timeout counter value, setting clock generation parameters. Different setup sequences for SD card (“SD Interface”) and eMMC card (“eMMC Device”) are provided. This step can also be executed immediately after Step 1.

5. Enable input clocks (other than hclk) that are available in DWC\_mshc. Internal clocks (aclk, bclk, tmclk and cqetmclk) are enabled followed by the card clocks (cclk\_tx/cclk\_rx) as discussed in the programming sequence in section “Host Controller Clock Setup Sequence”. At this stage, DWC\_mshc is ready to communicate with a card.
6. Identify the type of card (SD or eMMC card) that is connected to DWC\_mshc as explained in the programming sequence in section “SD Card Interface Detection”. If DWC\_mshc is connected to an eMMC card, then programming sequence described in section “eMMC Card Interface Setup” must be executed. This is a simplified sequence especially for an eMMC card as the type of card is always known. Both the programming sequences provide power and clock to the card.
7. After powering up the card, the card is initialized. Appropriate sequence as shown in Figure & Table 3-6 must to be executed based on type of the connected card.
8. As both host controller and card are initialized, the host can start sending commands to the card to perform the data transfer. Control and data commands are two types of commands that can be issued to the card. The control command is used to read or write any register in the card. The data command is used for writing or reading data to or from the card. Figure & Table 3-7 lists the control and data command sequences for SD and eMMC cards.

Figure & Table 3-6 Card initialization sequence for different cards

| Type of Card | Card Initialization Sequences                                                             |
|--------------|-------------------------------------------------------------------------------------------|
| SD           | SD Card Initialization and Identification (“SD Card Initialization and Identification”)   |
| eMMC         | Initializing and Identifying an eMMC Card (“Initializing and Identifying an eMMC Device”) |

Figure & Table 3-7 Command sequence for different cards

| Type of Card | Command Sequence |                                                                         |
|--------------|------------------|-------------------------------------------------------------------------|
| SD/eMMC      | Control CMD      | Issuing CMD without Data Transfer (“Issuing CMD without Data Transfer”) |
|              | Data CMD         | Issuing CMD with Data Transfer (“Issuing CMD with Data Transfer”)       |

### 3.5.1 Card Detection

Figure & Table 3-8 shows the sequence for detecting a card. The procedure outlined in Figure & Table 3-8 applies to both SD and SDIO cards. This programming sequence is not required for an eMMC device as it is non-removable.



Figure & Table 3-8 Card detection

### 3.5.2 Host Controller Setup Sequence

This section discusses the host controller setup sequence for SD interface and an eMMC device.

### 3.5.2.1 SD Interface



Figure & Table 3-9 Host controller setup sequence for SD

### 3.5.2.2 eMMC Device



Figure & Table 3-10 Host controller setup sequence for eMMC interface

### 3.5.3 Clock Control

This section discusses the programming sequence for setting up internal clocks and card clock provided to DWC\_mshc and for supplying and setting up a clock provided to the card, and for changing the card clock frequency.

#### 3.5.3.1 Host Controller Clock Setup Sequence

Figure & Table 3-11 shows the sequence for setting up clocks for DWC\_mshc. The DWC\_mshc requires number of clock signals from the system. All the input clocks are asynchronous to each other. Based on controls available for enabling clocks required for DWC\_mshc, they are categorized into two types, namely internal clock and card clock.



Figure & Table 3-11 Host controller clock setup sequence

### 3.5.3.2 Card Clock Supply and Stop Sequence

Figure & Table 3-12 shows the flow chart for stopping the clock to card.



Figure & Table 3-12 Card clock supply and stop sequence

### 3.5.3.3 SD Clock Frequency Change Sequence



Figure & Table 3-13 SD clock frequency change sequence

### 3.5.4 Card Interface Setup Sequence

This section discusses the programming sequence for setting up the card interface for an SD and an eMMC card.

### 3.5.4.1 SD Card Interface Detection



Figure & Table 3-14 SD card interface detection sequence

### 3.5.4.2 eMMC Card Interface Setup

Figure & Table 3-15 shows the programming sequence to set up an eMMC device.



Figure & Table 3-15 eMMC card setup sequence

### 3.5.5 Tuning Sequences

This section discusses the tuning sequences for software tuning for SD and eMMC modes.

#### 3.5.5.1 Tuning Flow Sequence

Figure & Table 3-16 shows how to perform mode1 re-tuning, which is the process to start tuning when the HOST\_CTRL2\_R.SAMPLE\_CLK\_SEL register bit is already set to 1. While using a tuning reset before the start of a new tuning, use a dedicated HOST\_CTRL2\_R write to first reset tuning, followed by a second HOST\_CTRL2\_R write to start tuning. A CMD19/CMD21 is used to start the tuning procedure. CMD19/CMD21 is similar to any read command. Therefore, before writing CMD19/CMD21 into the CMD\_R, the settings of BLOCKSIZE\_R, BLOCKCOUNT\_R, and XFERMODE\_R registers must be proper.



Figure &amp; Table 3-16 Tuning sequence

### 3.5.5.2 Mode 1 Re-Tuning Flow

Figure & Table 3-17 shows the Mode 1 re-tuning programming sequence.



Figure & Table 3-17 Mode 1 re-tuning flow sequence

### 3.5.5.3 Mode 3 Re-Tuning/Auto-Tuning Flow Sequence

The auto-tuning feature is enabled by default in DWC\_mshc when the speed mode is switched to SDR104 or HS200. If there is a need to change any of its parameters or to disable it, The AT\_CTRL\_R register can be used to enable or disable this feature. AT\_CTRL\_R can be programmed only when sample\_cclk\_sel is set to 0 before starting tuning.

You must not use mode-1 re-tuning when auto-tuning (mode3) is enabled.



Figure &amp; Table 3-18 Auto-tuning sequence

### 3.5.6 SD/SDIO Transaction Mode

This section includes the sequences to generate and control different types of SD/SDIO transactions that can be classified as transactions without data transfer using the DAT line and transactions with data transfer using the DAT line. This section also discusses the sequence for tuning the flow, controlling the bus power, changing the bus width and speed mode, setting the timeout on a DAT line, initializing and identifying a SD card, and the aborting sequence.

### 3.5.6.1 SD Card Initialization and Identification



Figure & Table 3-19 SD card initialization and identification



Figure &amp; Table 3-20 SD card initialization and identification (continued)

### 3.5.6.2 Changing SD Bus Width

Figure & Table 3-21 shows the sequence for changing bit mode on SD Bus.



Figure & Table 3-21 Change bus width sequence

### 3.5.6.3 SD Bus Power Control

Figure & Table 3-22 shows the sequence for controlling the SD Bus Power.



Figure & Table 3-22 SD bus power control sequence

### 3.5.6.4 Issuing CMD without Data Transfer

Figure & Table 3-23 shows the sequence on how to issue and complete an SD command. An SD command may or may not use a data line (DAT) (which is used for busy signaling). Figure & Table 3-23 shows the procedure to issue commands for both scenarios.



Figure &amp; Table 3-23 SD command issue and complete

### 3.5.6.5 Issuing CMD with Data Transfer

This section includes the sequence to issue a command with data transfer without using DMA and by using SDMA, ADMA2, and ADMA3 modes.



Figure & Table 3-24 Transaction control with data transfer (not using DMA)



Figure & Table 3-25 Transaction control with data transfer (not using DMA, continued)



Figure & Table 3-26 Transaction control with data transfer (using ADMA2)



Figure & Table 3-27 Transaction control with data transfer (using ADMA2, continued)



Figure & Table 3-28 Transaction control with data transfer (using ADMA3)

### 3.5.6.6 UHS-I Signal Voltage Switch Procedure



Figure & Table 3-29 Signal voltage switch procedure

### 3.5.6.7 Changing SD Bus Speed Mode



Figure & Table 3-30 Changing SD bus speed mode

### 3.5.6.8 SDIO Card Interrupt



Figure & Table 3-31 SDIO card interrupt sequence

### 3.5.7 eMMC Transaction Mode

This section discusses the programming sequence for setting the host controller for an eMMC interface, the power sequence, initializing and identify the card, issuing a command with/without data transfer using or not using a DAT line, switching to various speed modes and to change the data bus width. This section also discusses how to program, initiate, and abort different boot speed modes.

### 3.5.7.1 Initializing and Identifying an eMMC Device



Figure & Table 3-32 Card initialization and identification programming sequence



### 3.5.7.2 Issue CMD without Data Transfer for an eMMC Device

The programming sequence for issuing a command without data transfer for an eMMC device is similar to the sequence mentioned in section “Issuing CMD without Data Transfer”.

### 3.5.7.3 Issue CMD with Data Transfer for an eMMC Device

The programming sequence for issuing a command with data transfer for an eMMC device is similar to the programming sequence mentioned in section “Issuing CMD with Data Transfer”. Data transfer can be done with or without using DMA. The supported DMA modes are SDMA, ADMA2, and ADMA3.

### 3.5.7.4 Switch to Various Speed Modes in an eMMC Device



Figure & Table 3-33 Programming sequence to switch to various speed modes in an eMMC device

### 3.5.7.5 Changing the Data Bus Width for an eMMC Device

Figure & Table 3-34 shows the programming sequence to change the data bus width for an eMMC device. In Figure & Table 3-34, note that CMD6 is effective only during transfer state.



Figure & Table 3-34 Programming sequence to change data bus width for an eMMC device

### 3.5.7.6 Command Queuing

Figure & Table 3-35 shows the programming sequence to initialize the command queuing engine.



Figure & Table 3-35 Initializing the command queuing engine

Figure & Table 3-36 shows the sequence to submit and complete a task in a command queuing engine.



Figure & Table 3-36 Submitting and completing a task

### 3.5.7.7 Boot Programming Sequences

Figure & Table 3-37 shows the programming sequence to prepare for a boot. This sequence is common for both the mandatory and alternate modes.



Figure & Table 3-37 Programming sequence to prepare for a boot

Figure & Table 3-38 shows the programming flow to initiate a mandatory boot in non-DMA mode.



Figure & Table 3-38 Programming sequence for initiating a mandatory boot in non-DMA mode

Alternate Boot is a command-based boot operation and can be initiated by issuing CMD0 with the 0xFFFFFFFFA argument. For the programming sequence for initiating an alternate boot, refer to “Issue CMD with Data Transfer for an eMMC Device” with the following exceptions:

- If boot acknowledgment is expected, BOOT\_CTRL\_R shall be programmed to set the timeout counter for boot acknowledgment before setting the CMD\_R register.
- Response check cannot be performed as CMD0 has no response.

When the boot is initiated, device state is assumed to be in pre-boot state and 74 clock cycles has expired after power is stable before issuing CMD0.

### 3.5.8 SD/eMMC PHY Configuration

#### 3.5.8.1 PHY Initial Power-up and Reset



Figure & Table 3-39 PHY power-up and reset programming sequence

#### 3.5.8.2 PAD Configuration Sequence

Use the recommended PAD configuration sequence when changing speed mode.



Figure &amp; Table 3-40 PAD configuration sequence

Figure &amp; Table 3-41 Recommended PAD settings for SD PHY in 1.8V mode

| <b>3.3V/1.8V PHY<br/>1.8V Mode</b> | <b>TXSLEW_CTRL_N*</b> | <b>TXSLEW_CTRL_P*</b> | <b>WEAKPULL_EN</b>                                | <b>RXSEL</b> | <b>PAD_SN*</b> | <b>PAD_SP*</b> |
|------------------------------------|-----------------------|-----------------------|---------------------------------------------------|--------------|----------------|----------------|
| LEGACY                             | 0x1                   | 0x3                   | DAT, CMD, RST:<br>0x1<br><br>CLK: 0x0             | 0x1          | 0x8            | 0x9            |
| HS SDR                             | 0x1                   | 0x3                   | DAT, CMD, RST:<br>0x1<br><br>CLK: 0x0             | 0x1          | 0x8            | 0x9            |
| HS DDR                             | 0x1                   | 0x3                   | DAT, CMD, RST:<br>0x1<br><br>CLK: 0x0             | 0x1          | 0x8            | 0x9            |
| HS 200                             | 0x1                   | 0x3                   | DAT, CMD, RST:<br>0x1<br><br>CLK: 0x0             | 0x1          | 0x8            | 0x9            |
| HS 400                             | 0x1                   | 0x3                   | DAT, CMD, RST:<br>0x1<br><br>CLK: 0x0 STB:<br>0x2 | 0x1          | 0x8            | 0x9            |

| <b>3.3V/1.8V PHY<br/>1.8V Mode</b> | <b>TXSLEW_CTRL_N*</b> | <b>TXSLEW_CTRL_P*</b> | <b>WEAKPULL_EN</b>                            | <b>RXSEL</b> | <b>PAD_SN*</b> | <b>PAD_SP*</b> |
|------------------------------------|-----------------------|-----------------------|-----------------------------------------------|--------------|----------------|----------------|
| HS400<br>ENHANCED                  | 0x1                   | 0x3                   | DAT, CMD, RST:<br>0x1<br>CLK: 0x0 STB:<br>0x2 | 0x1          | 0x8            | 0x9            |

## 3.6 Registers

Figure &amp; Table 3-42 Possible read and write behaviors

| <b>Read (or Write) Behavior</b> | <b>Description</b>                                   |
|---------------------------------|------------------------------------------------------|
| RC                              | A read clears this register field.                   |
| RS                              | A read sets this register field.                     |
| RM                              | A read modifies the contents of this register field. |
| Wo                              | You can only write to this register once field.      |
| W1C                             | A write of 1 clears this register field.             |
| W1S                             | A write of 1 sets this register field.               |
| W1T                             | A write of 1 toggles this register field.            |
| W0C                             | A write of 0 clears this register field.             |
| W0S                             | A write of 0 sets this register field.               |
| W0T                             | A write of 0 toggles this register field.            |
| WC                              | Any write clears this register field.                |
| WS                              | Any write sets this register field.                  |
| WM                              | Any write toggles this register field.               |
| no Read Behavior attribute      | You cannot read this register. It is Write-Only.     |
| no Write Behavior attribute     | You cannot write to this register. It is Read-Only.  |

Figure &amp; Table 3-43 Memory access examples

| <b>Memory Access</b> | <b>Description</b>                                     |
|----------------------|--------------------------------------------------------|
| R                    | Read-only register field.                              |
| W                    | Write-only register field.                             |
| R/W                  | Read/write register field.                             |
| R/W1C                | You can read this register field. Writing 1 clears it. |



|        |                                                                  |
|--------|------------------------------------------------------------------|
| RC/W1C | Reading this register field clears it. Writing 1 clears it.      |
| R/Wo   | You can read this register field. You can only write to it once. |

### 3.6.1 DWC\_mshc\_map/DWC\_mshc\_block Registers

#### 3.6.1.1 SDMASA\_R

- Name: SDMA System Address Register
- Description: This register is used to configure a 32-bit block count or an SDMA system address based on the Host Version 4 Enable bit in the host control 2 register. This register is applicable for both SD and eMMC modes.
- Size: 32 bits
- Offset: 0x0

Figure & Table 3-44 Fields for register: SDMASA\_R

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BLOCKCNT_SDMASA | R/W    | <p>32-bit Block Count (SDMA System Address)</p> <ul style="list-style-type: none"><li>■ SDMA System Address (Host Version 4 Enable = 0): This register contains the system memory address for an SDMA transfer in the 32-bit addressing mode. When the Host Controller stops an SDMA transfer, this register points to the system address of the next contiguous data position. It can be accessed only if no transaction is executing. Reading this register during data transfers may return an invalid value.</li><li>■ 32-bit Block Count (Host Version 4 Enable = 1): From the Host Controller Version 4.10 specification, this register is redefined as 32-bit Block Count. The Host Controller decrements the block count of this register for every block transfer and the data transfer stops when the count reaches zero. This register must be accessed when no transaction is executing. Reading this register during data transfers may return invalid value.</li></ul> <p>Following are the values for BLOCKCNT_SDMASA:</p> <ul style="list-style-type: none"><li>■ 0xFFFF_FFFF: 4G - 1 Block</li><li>■ ...</li><li>■ 0x0000_0002: 2 Blocks</li><li>■ 0x0000_0001: 1 Block</li><li>■ 0x0000_0000: Stop Count</li></ul> <p>Note:</p> <ul style="list-style-type: none"><li>■ For Host Version 4 Enable = 0, the Host driver does not program the system address in this register while operating in ADMA mode. The system address must be programmed in the ADMA System Address</li></ul> |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>register.</p> <ul style="list-style-type: none"> <li>For Host Version 4 Enable = 0, the Host driver programs a non-zero 32-bit block count value in this register when Auto CMD23 is enabled for non-DMA and ADMA modes. Auto CMD23 cannot be used with SDMA.</li> <li>This register must be programmed with a non-zero value for data transfer if the 32-bit Block count register is used instead of the 16-bit Block count register.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: true</p> |

### 3.6.1.2 BLOCKSIZE\_R

- Name: Block Size Register
- Description: This register is used to configure an SDMA buffer boundary and the number of bytes in a data block. This register is applicable for both SD and eMMC modes.
- Size: 16 bits
- Offset: 0x4

Figure & Table 3-45 Fields for register: BLOCKSIZE\_R

| Bits  | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | RSVD_BLOCKSIZE15 | R      | <p>This bit of the BLOCKSIZE_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14:12 | SDMA_BUF_BDARY   | R/W    | <p>SDMA Buffer Boundary</p> <p>These bits specify the size of contiguous buffer in system memory. The SDMA transfer waits at every boundary specified by these fields and the Host Controller generates the DMA interrupt to request the Host Driver to update the SDMA System Address register.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (BYTES_4K): 4K bytes SDMA buffer boundary</li> <li>■ 0x1 (BYTES_8K): 8K bytes SDMA buffer boundary</li> <li>■ 0x2 (BYTES_16K): 16K bytes SDMA buffer boundary</li> <li>■ 0x3 (BYTES_32K): 32K bytes SDMA buffer boundary</li> <li>■ 0x4 (BYTES_64K): 64K bytes SDMA buffer boundary</li> <li>■ 0x5 (BYTES_128K): 128K bytes SDMA buffer boundary</li> </ul> |

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <p>boundary</p> <ul style="list-style-type: none"> <li>■ 0x6 (BYTES_256K): 256K bytes SDMA buffer boundary</li> <li>■ 0x7 (BYTES_512K): 512K bytes SDMA buffer boundary</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:0 | XFER_BLOCK_SIZE | R/W    | <p>Transfer Block Size</p> <p>These bits specify the block size of data transfers. In case of memory, it is set to 512 bytes. It can be accessed only if no transaction is executing. Read operations during transfers may return an invalid value, and write operations are ignored. Following are the values for XFER_BLOCK_SIZE:</p> <ul style="list-style-type: none"> <li>■ 0x1: 1 byte</li> <li>■ 0x2: 2 bytes</li> <li>■ 0x3: 3 bytes</li> <li>■ .....</li> <li>■ 0x1FF: 511 bytes</li> <li>■ 0x200: 512 bytes</li> <li>■ .....</li> <li>■ 0x800: 2048 bytes</li> </ul> <p>Note: This register must be programmed with a non-zero value for data transfer.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.3 BLOCKCOUNT\_R

- Name: 16-bit Block Count Register
- Description: This register is used to configure the number of data blocks. This register is applicable for both SD and eMMC modes.
- Size: 16 bits
- Offset: 0x6

Figure &amp; Table 3-46 Fields for register: BLOCKCOUNT\_R

| Bits | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | BLOCK_CNT | R/W    | <p>16-bit Block Count</p> <ul style="list-style-type: none"> <li>■ If the Host Version 4 Enable bit is set 0 or the 16-bit Block Count register is set to non-zero, the 16-bit Block Count register is selected.</li> <li>■ If the Host Version 4 Enable bit is set 1 and the 16-bit Block Count register is set to zero, the 32-bit Block Count register is selected.</li> </ul> <p>Following are the values for BLOCK_CNT:</p> <ul style="list-style-type: none"> <li>■ 0x0: Stop Count</li> <li>■ 0x1: 1 Block</li> <li>■ 0x2: 2 Blocks</li> <li>■ ... - ...</li> <li>■ 0xFFFF: 65535 Blocks</li> </ul> <p>Note: For Host Version 4 Enable = 0, this register must be set to 0000h before programming the 32-bit block count register when Auto CMD23 is enabled for non-DMA and ADMA modes.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.4 ARGUMENT\_R

- Name: Argument Register
- Description: This register is used to configure the SD/eMMC command argument.
- Size: 32 bits
- Offset: 0x8

Figure &amp; Table 3-47 Fields for register: ARGUMENT\_R

| Bits | Name     | Access | Description                                                                                                                                                                              |
|------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ARGUMENT | R/W    | <p>Command Argument</p> <p>These bits specify the SD/eMMC command argument that is specified in bits 39-8 of the Command format.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.5 XFER\_MODE\_R

- Name: Transfer Mode Register

- Description: This register is used to control the operation of data transfers for an SD/eMMC mode. The Host driver sets this register before issuing a command that transfers data.
- Size: 16 bits
- Offset: 0xc

Figure &amp; Table 3-48 Fields for register: XFER\_MODE\_R

| Bits | Name                | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:9 | RSVD                | R      | <p>These bits of the XFER_MODE_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8    | RESP_INT_DISABLE    | R/W    | <p>Response Interrupt Disable</p> <p>The Host Controller supports response check function to avoid overhead of response error check by the Host driver. Response types of only R1 and R5 can be checked by the Controller.</p> <p>If Host Driver checks the response error, set this bit to 0 and wait for Command Complete Interrupt and then check the response register.</p> <p>If the Host Controller checks the response error, set this bit to 1 and set the Response Error Check Enable bit to 1. The Command Complete Interrupt is disabled by this bit regardless of the Command Complete Signal Enable.</p> <p>Note: During tuning (when the Execute Tuning bit in the Host Control2 register is set), the Command Complete Interrupt is not generated irrespective of the Response Interrupt Disable setting.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (ENABLED): Response Interrupt is enabled.</li> <li>■ 0x1 (DISABLED): Response Interrupt is disabled.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 7    | RESP_ERR_CHK_ENABLE | R/W    | <p>Response Error Check Enable</p> <p>The Host Controller supports response check function to avoid overhead of response error check by Host driver. Response types of only R1 and R5 can be checked by the Controller. If the Host Controller checks the response error, set this bit to 1 and set Response Interrupt Disable to 1. If an error is detected, the Response Error interrupt is generated in the Error Interrupt Status register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | <p>Note:</p> <ul style="list-style-type: none"><li>■ Response error check must not be enabled for any response type other than R1 and R5.</li><li>■ Response check must not be enabled for the tuning command.</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Response Error Check is disabled.</li><li>■ 0x1 (ENABLED): Response Error Check is enabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                            |
| 6    | RESP_TYPE     | R/W    | <p>Response Type R1/R5</p> <p>This bit selects either R1 or R5 as a response type when the Response Error Check is selected.</p> <p>Error statuses checked in R1:</p> <ul style="list-style-type: none"><li>■ OUT_OF_RANGE</li><li>■ ADDRESS_ERROR</li><li>■ BLOCK_LEN_ERROR</li><li>■ WP_VIOLATION</li><li>■ CARD_IS_LOCKED</li><li>■ COM_CRC_ERROR</li><li>■ CARD_ECC_FAILED</li><li>■ CC_ERROR</li><li>■ ERROR</li></ul> <p>Response Flags checked in R5:</p> <ul style="list-style-type: none"><li>■ COM_CRC_ERROR</li><li>■ ERROR</li><li>■ FUNCTION_NUMBER</li><li>■ OUT_OF_RANGE</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (RESP_R1): R1 (memory)</li><li>■ 0x1 (RESP_R5): R5 (SDIO)</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 5    | MULTI_BLK_SEL | R/W    | <p>Multi/Single Block Select</p> <p>This bit is set when issuing multiple-block transfer commands using the DAT line. If this bit is set to 0, it is</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Bits | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |        | <p>not necessary to set the Block Count register.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (SINGLE): Single block</li><li>■ 0x1 (MULTI): Multiple block</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                     |
| 4    | DATA_XFER_DIR      | R/W    | <p>Data Transfer Direction Select</p> <p>This bit defines the direction of DAT line data transfers. This bit is set to 1 by the Host Driver to transfer data from the SD/eMMC card to the Host Controller and it is set to 0 for all other commands.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (READ): Read (card to host)</li><li>■ 0x0 (WRITE): Write (host to card)</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                       |
| 3:2  | AUTO_CMD_ENABLE    | R/W    | <p>Auto Command Enable</p> <p>This field determines use of Auto Command functions.</p> <p>Note: In SDIO, this field must be set as 00b (Auto Command Disabled).</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (AUTO_CMD_DISABLED): Auto command disabled.</li><li>■ 0x1 (AUTO_CMD12_ENABLED): Auto CMD12 enable.</li><li>■ 0x2 (AUTO_CMD23_ENABLED): Auto CMD23 enable.</li><li>■ 0x3 (AUTO_CMD_AUTO_SEL): Auto CMD auto select.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 1    | BLOCK_COUNT_ENABLE | R/W    | <p>Block Count Enable</p> <p>This bit is used to enable the Block Count register, which is relevant for multiple block transfers. If this bit is set to 0, the Block Count register is disabled, which is useful in executing an infinite transfer. The Host Driver must set this bit to 0 when ADMA is used.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (ENABLED): Enable</li><li>■ 0x0 (DISABLED): Disable</li></ul>                                                                      |



| Bits | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0    | DMA_ENABLE | R/W    | <p>DMA Enable</p> <p>This bit enables the DMA functionality. If this bit is set to 1, a DMA operation begins when the Host Driver writes to the Command register. You can select one of the DMA modes by using DMA Select in the Host Control 1 register.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (ENABLED): DMA data transfer</li><li>■ 0x0 (DISABLED): No data transfer or non-DMA data transfer</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.6 CMD\_R

- Name: Command Register
- Description: This register is used to provide the information related to a command and a response packet. This register is applicable for an SD/eMMC mode.
- Size: 16 bits
- Offset: 0xe

Figure & Table 3-49 Fields for register: CMD\_R

| Bits  | Name      | Access | Description                                                                                                                                                                                |
|-------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RSVD      | R      | <p>These bits of the CMD_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                            |
| 13:8  | CMD_INDEX | R/W    | <p>Command Index</p> <p>These bits are set to the command number that is specified in bits 45-40 of the Command Format.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>            |
| 7:6   | CMD_TYPE  | R/W    | <p>Command Type</p> <p>These bits indicate the command type.</p> <p>Note: While issuing Abort CMD using CMD12/CMD52 or reset CMD using CMD0/CMD52, CMD_TYPE field shall be set to 0x3.</p> |



| Bits | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |        | <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x3 (ABORT_CMD): Abort</li><li>■ 0x2 (RESUME_CMD): Resume</li><li>■ 0x1 (SUSPEND_CMD): Suspend</li><li>■ 0x0 (NORMAL_CMD): Normal</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5    | DATA_PRESENT_SEL   | R/W    | <p>Data Present Select</p> <p>This bit is set to 1 to indicate that data is present and that the data is transferred using the DAT line. This bit is set to 0 in the following instances:</p> <ul style="list-style-type: none"><li>■ Command using the CMD line</li><li>■ Command with no data transfer but using busy signal on the DAT[0] line</li><li>■ Resume command</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (NO_DATA): No data present.</li><li>■ 0x1 (DATA): Data present.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                               |
| 4    | CMD_IDX_CHK_ENABLE | R/W    | <p>Command Index Check Enable</p> <p>This bit enables the Host Controller to check the index field in the response to verify if it has the same value as the command index. If the value is not the same, it is reported as a Command Index error.</p> <p>Note:</p> <ul style="list-style-type: none"><li>■ Index Check enable must be set to 0 for the command with no response, R2 response, R3 response and R4 response.</li><li>■ For the tuning command, this bit must always be set to enable the index check.</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Disable</li><li>■ 0x1 (ENABLED): Enable</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 3    | CMD_CRC_CHK_ENABLE | R/W    | Command CRC Check Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  |        | <p>This bit enables the Host Controller to check the CRC field in the response. If an error is detected, it is reported as a Command CRC error.</p> <p>Note:</p> <ul style="list-style-type: none"> <li>■ CRC Check enable must be set to 0 for the command with no response, R3 response, and R4 response.</li> <li>■ For the tuning command, this bit must always be set to 1 to enable the CRC check.</li> </ul> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (DISABLED): Disable</li> <li>■ 0x1 (ENABLED): Enable</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 2    | SUB_CMD_FLAG     | R/W    | <p>Sub Command Flag</p> <p>This bit distinguishes between a main command and a sub command.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (MAIN): Main command</li> <li>■ 0x1 (SUB): Sub command</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                   |
| 1:0  | RESP_TYPE_SELECT | R/W    | <p>Response Type Select</p> <p>This bit indicates the type of response expected from the card.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (NO_RESP): No response</li> <li>■ 0x1 (RESP_LEN_136): Response length 136</li> <li>■ 0x2 (RESP_LEN_48): Response length 48</li> <li>■ 0x3 (RESP_LEN_48B): Response length 48; Check Busy after response</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                               |

### 3.6.1.7 RESP01\_R

- Name: Response Register 0/1
- Description: This register stores bits 39-08 of the response field for an SD/eMMC mode. In UHS-II mode, this register stores the response of the TRANS\_ABORT CCMD. The response for an

SD/eMMC command can be a maximum of 128 bits. These 128 bits are segregated into four 32-bit registers: RESP01\_R, RESP23\_R, RESP45\_R and RESP67\_R.

- Size: 32 bits
- Offset: 0x10

Figure & Table 3-50 Fields for register: RESP01\_R

| Bits | Name   | Access | Description                                                                                                                                                                                                                                                                                                                                            |
|------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RESP01 | R      | <p>Command Response</p> <p>These bits reflect 39-8 bits of SD/eMMC Response Field. In UHS-II mode, it stores the response of the TRANS_ABORT CCMD.</p> <p>Note: For Auto CMD, the 32-bit response (bits 39-8 of the Response Field) is updated in the RESP67_R register.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.8 RESP23\_R

- Name: Response Register 2/3
- Description: This register stores bits 71-40 of the Response Field for an SD/eMMC mode. This register is used to store the response from the cards. The response can be a maximum of 128 bits.

These 128 bits are segregated into four 32-bit registers: RESP01\_R, RESP23\_R, RESP45\_R and RESP67\_R. In UHS-II mode, this register is reserved.

- Size: 32 bits
- Offset: 0x14

Figure & Table 3-51 Fields for register: RESP23\_R

| Bits | Name   | Access | Description                                                                                                                                                                                           |
|------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RESP23 | R      | <p>Command Response</p> <p>These bits reflect 71-40 bits of the SD/eMMC response field. In UHS-II mode, it is reserved.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.9 RESP45\_R

- Name: Response Register 4/5

- Description: This register stores bits 103-72 of the response field for an SD/eMMC mode. In UHS-II mode, this register is used to store the lower 4-byte CMD12 response. The response for SD/eMMC command can be a maximum of 128 bits. These 128 bits are segregated into four 32-bit registers: RESP01\_R, RESP23\_R, RESP45\_R and RESP67\_R.
- Size: 32 bits
- Offset: 0x18

Figure &amp; Table 3-52 Fields for register: RESP45\_R

| Bits | Name   | Access | Description                                                                                                                                                                                                              |
|------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RESP45 | R      | <p>Command Response</p> <p>These bits reflect bits 103-72 of the response field. In UHSII mode, it stores the lower 4-byte CMD12 response.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.10 RESP67\_R

- Name: Response Register 6/7
- Description: This register stores bits 135-104 of the response field for an SD/eMMC mode. In UHSII mode, this register stores the upper 4-byte CMD12 response. The SD/eMMC response can be a maximum of 128 bits. These 128 bits are segregated into four 32-bit registers: RESP01\_R, RESP23\_R, RESP45\_R and RESP67\_R.
- Size: 32 bits
- Offset: 0x1c

Figure &amp; Table 3-53 Fields for register: RESP67\_R

| Bits | Name   | Access | Description                                                                                                                                                                                                                                                                                                                                  |
|------|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RESP67 | R      | <p>Command Response</p> <p>These bits reflect bits 135-104 of SD/eMMC response field. In UHS-II mode, it stores the upper 4-byte CMD12 response.</p> <p>Note: For Auto CMD, this register also reflects the 32-bit response (bits 39-8 of the Response Field).</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.11 BUF\_DATA\_R

- Name: Buffer Data Port Register

- Description: This register is used to access the packet buffer. This register is applicable for an SD/eMMC/UHS-II mode.
- Size: 32 bits
- Offset: 0x20

Figure &amp; Table 3-54 Fields for register: BUF\_DATA\_R

| Bits | Name     | Access | Description                                                                                                                                                        |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BUF_DATA | R/W    | <p>Buffer Data</p> <p>These bits enable access to the Host Controller packet buffer.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.12 PSTATE\_REG

- Name: Present State Register
- Description: This register indicates the present status of the host controller. This register is applicable for an SD/eMMC/UHS-II mode.
- Size: 32 bits
- Offset: 0x24

Figure &amp; Table 3-55 Fields for register: PSTATE\_REG

| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|------|----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | UHS2_IF_DETECT | R      | <p>UHS-II Interface Detection</p> <p>This bit indicates whether a card supports the UHS-II interface. For SD/eMMC mode, this bit always returns 0.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): UHS-II interface is not detected.</li> <li>■ 0x1 (TRUE): UHS-II interface is detected.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 30   | LANE_SYNC      | R      | <p>Lane Synchronization</p> <p>This bit indicates whether a lane is synchronized in the UHSII mode. For SD/eMMC mode, this bit always returns 0.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): UHS-II PHY is not initialized.</li> <li>■ 0x1 (TRUE): UHS-II PHY is initialized.</li> </ul>                                                                                   |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                    |
| 29   | IN_DORMANT_ST | R      | <p>In Dormant Status</p> <p>This bit indicates whether UHS-II lanes enter dormant state in the UHS-II mode. For SD/eMMC mode, this bit always returns 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not in dormant state</li><li>■ 0x1 (TRUE): In dormant state</li></ul> <p>Value After Reset:</p> <p>=mshc_present_state_in_dormant_reset_val</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 28   | SUB_CMD_STAT  | R      | <p>Sub Command Status</p> <p>This bit is used to distinguish between a main command and a sub command status.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Main command status</li><li>■ 0x1 (TRUE): Sub command status</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                       |
| 27   | CMD_ISSUE_ERR | R      | <p>Command Not Issued by Error</p> <p>This bit is set if a command cannot be issued after setting the command register due to an error except the Auto CMD12 error.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No error for issuing a command.</li><li>■ 0x1 (TRUE): Command cannot be issued.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>              |
| 26   | RSVD_26       | R      | <p>This bit of the PRESENT_ST_R register is reserved bits. It always returns 0.</p> <p>Value After Reset: 0x0</p>                                                                                                                                                                                                                                                                                                            |



| Bits  | Name              | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                   |        | Exists: Always<br>Volatile: True                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 25    | HOST_REG_VOL      | R      | <p>Host Regulator Voltage Stable</p> <p>This bit is used to check whether the host regulator voltage is stable for switching the voltage of UHS-I mode. This bit reflects the synchronized value of the host_reg_vol_stable signal.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Host regulator voltage is not stable.</li><li>■ 0x1 (TRUE): Host regulator voltage is stable.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 24    | CMD_LINE_LVL      | R      | <p>Command-Line Signal Level</p> <p>This bit is used to check the CMD line level to recover from errors and for debugging. These bits reflect the value of the sd_cmd_in signal. This bit is irrelevant for an UHS-II mode and always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                |
| 23:20 | DAT_3_0           | R      | <p>DAT[3:0] Line Signal Level</p> <p>This bit is used to check the DAT line level to recover from errors and for debugging. These bits reflect the value of the sd_dat_in (lower nibble) signal. These bits are irrelevant for the UHS-II mode and always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                            |
| 19    | WR_PROTECT_SW_LVL | R      | <p>Write Protect Switch Pin Level</p> <p>This bit is supported only for memory and combo cards. This bit reflects the synchronized value of the card_write_prot signal.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Write protected.</li><li>■ 0x1 (TRUE): Write enabled.</li></ul>                                                                                                                                                                               |



| Bits  | Name                  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                       |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                   |
| 18    | CARD_DETECT_PIN_LEVEL | R      | <p>Card Detect Pin Level</p> <p>This bit reflects the inverse synchronized value of the card_detect_n signal.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No card present.</li><li>■ 0x1 (TRUE): Card present.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                              |
| 17    | CARD_STABLE           | R      | <p>Card Stable</p> <p>This bit indicates the stability of the Card Detect Pin Level. A card is not detected if this bit is set to 1 and the value of the CARD_INSERTED bit is 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Reset or Debouncing</li><li>■ 0x1 (TRUE): No card or inserted</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>  |
| 16    | CARD_INSERTED         | R      | <p>Card Inserted</p> <p>This bit indicates whether a card has been inserted. The host controller debounces this signal so that host driver need not wait for it to stabilize.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Reset, Debouncing, or No card</li><li>■ 0x1 (TRUE): Card inserted</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 15:12 | RSVD_15_12            | R      | <p>These bits of the PRESENT_STAT_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                    |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                |
|------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | Volatile: True                                                                                                                                                                                                                                                                                                                                                                             |
| 11   | BUF_RD_ENABLE  | R      | <p>Buffer Read Enable</p> <p>This bit is used for non-DMA transfers. This bit is set if valid data exists in the Host buffer.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Read disable.</li><li>■ 0x1 (ENABLED): Read enable.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                           |
| 10   | BUF_WR_ENABLE  | R      | <p>Buffer Write Enable</p> <p>This bit is used for non-DMA transfers. This bit is set if space is available for writing data.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Write disable.</li><li>■ 0x1 (ENABLED): Write enable.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                         |
| 9    | RD_XFER_ACTIVE | R      | <p>Read Transfer Active</p> <p>This bit indicates whether a read transfer is active for SD/eMMC mode. This bit irrelevant for the UHS-II mode and always returns 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (INACTIVE): No valid data</li><li>■ 0x1 (ACTIVE): Transferring data</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 8    | WR_XFER_ACTIVE | R      | <p>Write Transfer Active</p> <p>This status indicates whether a write transfer is active for SD/eMMC mode. It is irrelevant for UHS-II mode and always returns 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (INACTIVE): No valid data</li><li>■ 0x1 (ACTIVE): Transferring data</li></ul>                                                                             |

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:4  | DAT_7_4         | R      | <p>DAT[7:4] Line Signal Level</p> <p>This bit is used to check the DAT line level to recover from errors and for debugging. These bits reflect the value of the sd_dat_in (upper nibble) signal. These bits are irrelevant for the UHS-II mode and always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3    | RE_TUNE_REQ     | R      | <p>Re-Tuning Request</p> <p>DWC_mshc does not generate retuning request. The software must maintain the Retuning timer.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2    | DAT_LINE_ACTIVE | R      | <p>DAT Line Active (SD/eMMC Mode only)</p> <p>This bit indicates whether one of the DAT lines on the SD/eMMC bus is in use. This bit is irrelevant for the UHS-II mode.</p> <p>In the case of read transactions, this bit indicates whether a read transfer is executing on the SD/eMMC bus.</p> <p>In the case of write transactions, this bit indicates whether a write transfer is executing on the SD/eMMC bus.</p> <p>For a command with busy, this status indicates whether the command executing busy is executing on an SD or eMMC bus.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): DAT line inactive</li> <li>■ 0x1 (ACTIVE): DAT line active</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 1    | CMD_INHIBIT_DAT | R      | <p>Command Inhibit (DAT)</p> <p>This bit is applicable for SD/eMMC mode and is</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             |        | <p>generated if either DAT line active or Read transfer active is set to 1. If this bit is set to 0, it indicates that the Host Controller can issue subsequent SD/eMMC commands. For the UHS-II mode, this bit is irrelevant and always returns 0.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (READY): Can issue command which used DAT line.</li> <li>■ 0x1 (NOT_READY): Cannot issue command which used DAT line.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0    | CMD_INHIBIT | R      | <p>Command Inhibit (CMD)</p> <p>This bit indicates the following:</p> <ul style="list-style-type: none"> <li>■ SD/eMMC mode: If this bit is set to 0, it indicates that the CMD line is not in use and the host controller can issue an SD/eMMC command using the CMD line. This bit is set when the command register is written. This bit is cleared when the command response is received. This bit is not cleared by the response of auto CMD12/23 but cleared by the response of read/write command.</li> <li>■ UHS-II mode: If this bit is set to 0, it indicates that a command packet can be issued by the host controller.</li> </ul> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (READY): Host controller is ready to issue a command.</li> <li>■ 0x1 (NOT_READY): Host controller is not ready to issue a command.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.13 HOST\_CTRL1\_R

- Name: Host Control 1 Register
- Description: This register is used to control the operation of the host controller. This register is applicable for an SD/eMMC/UHS-II mode.
- Size: 8 bits

- Offset: 0x28

Figure & Table 3-56 Fields for register: HOST\_CTRL1\_R

| Bits | Name                 | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | CARD_DETECT_SIG_SEL  | R/W    | <p>Card Detect Signal Selection</p> <p>This bit selects a source for card detection. When the source for the card detection is switched, the interrupt must be disabled during the switching period.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (CARD_DT_TEST_LEVEL): Card Detect Test Level is selected. (for test purpose)</li> <li>■ 0x0 (SDCD_PIN): SDCD# (card_detect_n signal) is selected. (for normal use)</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 6    | CARD_DETECT_TEST_LVL | R/W    | <p>Card Detect Test Level</p> <p>This bit is enabled while the Card Detect Signal Selection is set to 1 and it indicates whether a card inserted or not.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (CARD_INSERTED): Card inserted</li> <li>■ 0x0 (No_CARD): No card</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                               |
| 5    | EXT_DAT_XFER         | R/W    | <p>Extended Data Transfer Width</p> <p>This bit controls 8-bit bus width mode of embedded device. This bit is not applicable for UHS-II mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (EIGHT_BIT): 8-bit bus width</li> <li>■ 0x0 (DEFAULT): Bus width is selected by the data transfer width.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                  |
| 4:3  | DMA_SEL              | R/W    | <p>DMA Select</p> <p>This field is used to select the DMA type.</p> <p>When Host Version 4 Enable is 1 in host control 2 register:</p> <ul style="list-style-type: none"> <li>■ 0x0: SDMA is selected.</li> <li>■ 0x1: Reserved.</li> </ul>                                                                                                                                                                                                                                                            |

| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <ul style="list-style-type: none"> <li>■ 0x2: ADMA2 is selected.</li> <li>■ 0x3: ADMA2 or ADMA3 is selected.</li> </ul> <p>When Host Version 4 Enable is 0 in Host Control 2 register:</p> <ul style="list-style-type: none"> <li>■ 0x0: SDMA is selected.</li> <li>■ 0x1: Reserved.</li> <li>■ 0x2: 32-bit Address ADMA2 is selected.</li> <li>■ 0x3: 64-bit Address ADMA2 is selected.</li> </ul> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (SDMA): SDMA is selected.</li> <li>■ 0x1 (RSVD_BIT): Reserved.</li> <li>■ 0x2 (ADMA2): ADMA2 is selected.</li> <li>■ 0x3 (ADMA2_3): ADMA2 or ADMA3 is selected.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                           |
| 2    | HIGH_SPEED_EN  | R/W    | <p>High Speed Enable (SD/eMMC Mode only)</p> <p>In SD/eMMC mode, this bit is used to determine the selection of preset value for High Speed mode. Before setting this bit, the Host Driver checks the High Speed Support in the Capabilities register.</p> <p>Note: DWC_MSHC always outputs the sd_cmd_out and sd_dat_out lines at the rising edge of cclk_tx clock irrespective of this bit. Please refer to the section "Connecting the Clock IO interface" in the Mobile Storage Host Controller user guide on clocking requirement for an SD/eMMC card.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (HIGH_SPEED): High speed mode</li> <li>■ 0x0 (NORMAL_SPEED): Normal speed mode</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 1    | DAT_XFER_WIDTH | R/W    | <p>Data Transfer Width</p> <p>For SD/eMMC mode, this bit selects the data transfer width of the host controller. The host driver sets it to match the data width of the SD/eMMC card. In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                |
|------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          |        | <ul style="list-style-type: none"> <li>■ 0x1 (FOUR_BIT): 4-bit mode</li> <li>■ 0x0 (ONE_BIT): 1-bit mode</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                                                                                                                               |
| 0    | LED_CTRL | R/W    | LED Control<br>This bit is used to caution the user not to remove the card while the SD card is being accessed. The value is reflected on the led_control signal.<br>Values: <ul style="list-style-type: none"> <li>■ 0x0 (OFF): LED off.</li> <li>■ 0x1 (ON): LED on.</li> </ul> Value After Reset: 0x0<br>Exists: Always |

### 3.6.1.14 PWR\_CTRL\_R

- Name: Power control register
- Description: This register is used to control the bus power for the card. This register is applicable for an SD, eMMC, and UHS-II modes.
- Size: 8 bits
- Offset: 0x29

Figure & Table 3-57 Fields for register: PWR\_CTRL\_R

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5  | SD_BUS_VOL_VDD2 | R/W    | SD Bus Voltage Select for VDD2.<br>This bit determines supply voltage range to VDD2 of UHS-II card. This bit can be set to 0x5 if 1.8V VDD2 Support in the Capabilities register is set to 1. This is irrelevant for SD/eMMC card.<br>Values: <ul style="list-style-type: none"> <li>■ 0x7 (NOT_USED7): Not used</li> <li>■ 0x6 (NOT_USED6): Not used</li> <li>■ 0x5 (V_1_8): 1.8V</li> <li>■ 0x4 (V_1_2): Reserved for 1.2V</li> <li>■ 0x3 (RSVD3): Reserved</li> <li>■ 0x2 (RSVD2): Reserved</li> <li>■ 0x1 (RSVD1): Reserved</li> <li>■ 0x0 (NO_VDD2): VDD2 not supported.</li> </ul> |



| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4    | SD_BUS_PWR_VDD2 | R/W    | <p>SD Bus Power for VDD2</p> <p>This bit enables VDD2 power of UHS-II card. This setting is available on the <code>sd_vdd2_on</code> output of <code>DWC_mshc</code> so that it can be used to control the VDD2 power supply of the card.</p> <p>This is irrelevant for SD/eMMC card.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (OFF): Power off.</li><li>■ 0x1 (ON): Power on.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3:1  | SD_BUS_VOL_VDD1 | R/W    | <p>SD Bus Voltage Select for VDD1/eMMC Bus Voltage Select for VDD</p> <p>These bits enable the host driver to select the voltage level for an SD/eMMC card. Before setting this register, the host driver checks the Voltage Support bits in the Capabilities register. If an unsupported voltage is selected, the host system does not supply the SD bus voltage. The value set in this field is available on the <code>DWC_mshc</code> output signal (<code>sd_vdd1_sel</code>), which is used by the voltage switching circuitry.</p> <p>SD Bus Voltage Select options:</p> <ul style="list-style-type: none"><li>■ 0x7: 3.3V (Typical)</li><li>■ 0x6: 3.0V (Typical)</li><li>■ 0x5: 1.8V (Typical) for embedded</li><li>■ 0x4: 0x0 - Reserved</li></ul> <p>eMMC Bus Voltage Select options:</p> <ul style="list-style-type: none"><li>■ 0x7: 3.3V (Typical)</li><li>■ 0x6: 1.8V (Typical)</li><li>■ 0x5: 1.2V (Typical)</li><li>■ 0x4: 0x0 - Reserved</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x7 (V_3_3): 3.3V (Typ.)</li><li>■ 0x6 (V_3_0): 3.0V (Typ.)</li><li>■ 0x5 (V_1_8): 1.8V (Typ.) for embedded</li><li>■ 0x4 (RSVD4): Reserved</li></ul> |

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <ul style="list-style-type: none"> <li>■ 0x3 (RSVD3): Reserved</li> <li>■ 0x2 (RSVD2): Reserved</li> <li>■ 0x1 (RSVD1): Reserved</li> <li>■ 0x0 (RSVD0): Reserved</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0    | SD_BUS_PWR_VDD1 | R/W    | <p>SD Bus Power for VDD1</p> <p>This bit enables VDD1 power of the card. This setting is available on the <code>sd_vdd1_on</code> output of <code>DWC_mshc</code> so that it can be used to control the VDD1 power supply of the card. Before setting this bit, the SD host driver sets the SD Bus Voltage Select bit. If the host controller detects a No Card state, this bit is cleared.</p> <p>In SD mode, if this bit is cleared, the host controller stops the SD clock by clearing the <code>SD_CLK_IN</code> bit in the <code>CLK_CTRL_R</code> register.</p> <p>In UHS-II mode, before clearing this bit, the host driver clears the <code>SD_CLK_IN</code> bit in the <code>CLK_CTRL_R</code> register.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (OFF): Power off.</li> <li>■ 0x1 (ON): Power on.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.15 BGAP\_CTRL\_R

- Name: Block Gap Control Register
- Description: This register is used by the host driver to control any operation related to Block Gap. This register is applicable for an SD/eMMC/UHS-II mode.
- Size: 8 bits
- Offset: 0x2a

Figure & Table 3-58 Fields for register: BGAP\_CTRL\_R

| Bits | Name        | Access | Description                                                                                                                                 |
|------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4  | RSVD_7_4    | R      | <p>These bits of the Block Gap Control register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 3    | INT_AT_BGAP | R/W    | Interrupt At Block Gap                                                                                                                      |



| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>This bit is valid only in the 4-bit mode of an SDIO card and is used to select a sample point in the interrupt cycle. Setting to 1 enables interrupt detection at the block gap for a multiple block transfer. In UHS-II mode, this bit is disabled.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLE): Disabled</li><li>■ 0x1 (ENABLE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                               |
| 2    | RD_WAIT_CTRL | R/W    | <p>Read Wait Control</p> <p>This bit is used to enable the read wait protocol to stop read data using DAT[2] line if the card supports read wait. Otherwise, the Host Controller has to stop the card clock to hold the read data. In UHS-II mode, Read Wait is disabled.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLE): Disable Read Wait Control.</li><li>■ 0x1 (ENABLE): Enable Read Wait Control.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>         |
| 1    | CONTINUE_REQ | R/W    | <p>Continue Request</p> <p>This bit is used to restart the transaction, which was stopped using the Stop At Block Gap Request. The Host Controller automatically clears this bit when the transaction restarts. If stop at block gap request is set to 1, any write to this bit is ignored.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (NO_AFFECT): No effect</li><li>■ 0x1 (RESTART): Restart</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 0    | STOP_BG_REQ  | R/W    | <p>Stop At Block Gap Request</p> <p>This bit is used to stop executing read and write transactions at the next block gap for non-DMA, SDMA, and ADMA transfers.</p> <p>Values:</p>                                                                                                                                                                                                                                                                                                                     |



| Bits | Name | Access | Description                                                                                                                                           |
|------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <ul style="list-style-type: none"><li>■ 0x0 (XFER): Transfer</li><li>■ 0x1 (STOP): Stop</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.16 WUP\_CTRL\_R

- Name: Wakeup Control Register
- Description: This register is mandatory for the Host Controller, but the wakeup functionality depends on the Host Controller system hardware and software. The Host Driver maintains voltage on the SD Bus by setting the SD Bus Power to 1 in the Power Control Register, while a wakeup event through the Card Interrupt is desired.
- Size: 8 bits
- Offset: 0x2b

Figure & Table 3-59 Fields for register: WUP\_CTRL\_R

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3  | RSVD_7_3     | R      | <p>These bits of Wakeup Control register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                           |
| 2    | CARD_REMOVAL | R/W    | <p>Wakeup Event Enable on SD Card Removal</p> <p>This bit enables wakeup event through Card Removal assertion in the Normal Interrupt Status register. For the SDIO card, Wake Up Support (FN_WUS) in the Card Information Structure (CIS) register does not affect this bit.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Disable</li><li>■ 0x1 (ENABLED): Enable</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 1    | CARD_INSERT  | R/W    | <p>Wakeup Event Enable on SD Card Insertion</p> <p>This bit enables wakeup event through Card Insertion assertion in the Normal Interrupt Status register. FN_WUS (Wake Up Support) in CIS does not affect this bit.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Disable</li></ul>                                                                                                                                              |

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          |        | <ul style="list-style-type: none"> <li>■ 0x1 (ENABLED): Enable</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                          |
| 0    | CARD_INT | R/W    | <p>Wakeup Event Enable on Card Interrupt</p> <p>This bit enables wakeup event through a Card Interrupt assertion in the Normal Interrupt Status register. This bit can be set to 1 if FN_WUS (Wake Up Support) in CIS is set to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (DISABLED): Disable</li> <li>■ 0x1 (ENABLED): Enable</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.17 CLK\_CTRL\_R

- Name: Clock Control Register
- Description: This register controls SDCLK (card clock) in an SD/eMMC mode and RCLK in UHS-II mode. This register is applicable for an SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x2c

Figure & Table 3-60 Fields for register: CLK\_CTRL\_R

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | FREQ_SEL | R/W    | <p>SDCLK/RCLK Frequency Select</p> <p>These bits are used to select the frequency of the SDCLK signal. These bits depend on setting of Preset Value Enable in the Host Control 2 register. If Preset Value Enable = 0, these bits are set by the host driver. If Preset Value Enable = 1, these bits are automatically set to a value specified in one of the Preset Value register. The value is reflected on the lower 8-bit of the card_clk_freq_sel signal.</p> <p>10-bit Divided Clock Mode</p> <ul style="list-style-type: none"> <li>■ 0x3FF: 1/2046 divided clock</li> <li>■ .....</li> <li>■ N: 1/2N divided clock</li> <li>■ .....</li> <li>■ 0x002: 1/4 divided clock</li> </ul> |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <ul style="list-style-type: none"><li>■ 0x001: 1/2 divided clock</li><li>■ 0x000: Base clock (10MHz - 255MHz)</li></ul> <p>Programmable Clock Mode: Enables the host system to select a fine grain SD clock frequency:</p> <ul style="list-style-type: none"><li>■ 0x3FF: Base clock * M /1024</li><li>■ .....</li><li>■ N-1: Base clock * M /N</li><li>■ .....</li><li>■ 0x002: Base clock * M /3</li><li>■ 0x001: Base clock * M /2</li><li>■ 0x000: Base clock * M</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                     |
| 7:6  | UPPER_FREQ_SEL | R/W    | <p>These bits specify the upper 2 bits of 10-bit SDCLK/RCLK Frequency Select control. The value is reflected on the upper 2 bits of the card_clk_freq_sel signal.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                               |
| 5    | CLK_GEN_SELECT | R/W    | <p>Clock Generator Select</p> <p>This bit is used to select the clock generator mode in SDCLK/RCLK Frequency Select. If Preset Value Enable = 0, this bit is set by the host driver. If Preset Value Enable = 1, this bit is automatically set to a value specified in one of the Preset Value registers. The value is reflected on the card_clk_gen_sel signal.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Divided clock mode</li><li>■ 0x1 (TRUE): Programmable clock mode</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 4    | RSVD_4         | R      | <p>This bit of the CLK_CTRL_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bits | Name                | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | PLL_ENABLE          | R/W    | <p>PLL Enable</p> <p>This bit is used to activate the PLL (applicable when Host Version 4 Enable = 1). When Host Version 4 Enable = 0, INTERNAL_CLK_EN bit may be used to activate PLL. The value is reflected on the card_clk_en signal.</p> <p>Note: If this bit is not used to activate the PLL when Host Version 4 Enable = 1, it is recommended to set this bit to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): PLL is in low power mode.</li> <li>■ 0x1 (TRUE): PLL is enabled.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                        |
| 2    | SD_CLK_EN           | R/W    | <p>SD/eMMC Clock Enable</p> <p>This bit stops the SDCLK or RCLK when set to 0. The SDCLK/RCLK Frequency Select bit can be changed when this bit is set to 0. The value is reflected on the clk2card_on pin.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Disable providing SDCLK/RCLK.</li> <li>■ 0x1 (TRUE): Enable providing SDCLK/RCLK.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                      |
| 1    | INTERNAL_CLK_STABLE | R      | <p>Internal Clock Stable</p> <p>This bit enables the host driver to check the clock stability twice after the Internal Clock Enable bit is set and after the PLL Enable bit is set. This bit reflects the synchronized value of the intclk_stable signal after the Internal Clock Enable bit is set to 1 and also reflects the synchronized value of the card_clk_stable signal after the PLL Enable bit is set to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not ready</li> <li>■ 0x1 (TRUE): Ready</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 0    | INTERNAL_CLK_EN     | R/W    | Internal Clock Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>This bit is set to 0 when the host driver is not using the host controller or the host controller awaits a wakeup interrupt. The host controller must stop its internal clock to enter a very low power state. However, registers can still be read and written to. The value is reflected on the intclk_en signal.</p> <p>Note: If this bit is not used to control the internal clock (base clock and master clock), it is recommended to set this bit to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Stop</li> <li>■ 0x1 (TRUE): Oscillate</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.18 TOUT\_CTRL\_R

- Name: Timeout Control Register
- Description: This register is used to set the Data Timeout Counter value for an SD/eMMC mode according to the timer clock defined by the Capabilities register, while initializing the host controller.
- Size: 8 bits
- Offset: 0x2e

Figure & Table 3-61 Fields for register: TOUT\_CTRL\_R

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4  | RSVD_7_4 | R      | <p>These bits of the Timeout Control register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                            |
| 3:0  | TOUT_CNT | R/W    | <p>Data Timeout Counter Value</p> <p>This value determines the interval by which DAT line timeouts are detected. The timeout clock frequency is generated by dividing the base clock TMCLK value by this value. When setting this register, prevent inadvertent timeout events by clearing the Data Timeout Error Status Enable (in the Error Interrupt Status Enable register). The values for these bits are:</p> <ul style="list-style-type: none"> <li>■ 0xF : Reserved</li> <li>■ 0xE : TMCLK x 2^27</li> </ul> |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                      |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <ul style="list-style-type: none"> <li>■ .....</li> <li>■ 0x1 : TMCLK x 2<sup>14</sup></li> <li>■ 0x0 : TMCLK x 2<sup>13</sup></li> </ul> <p>Note: During a boot operating in eMMC mode, an application must configure the boot data timeout value (approximately 1 second) in this bit.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.19 SW\_RST\_R

- Name: Software Reset Register
- Description: This register is used to generate a reset pulse by writing 1 to each bit of this register. After completing the reset, the host controller clears each bit. As it takes some time to complete a software reset, the host driver confirms that these bits are 0. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 8 bits
- Offset: 0x2f

Figure & Table 3-62 Fields for register: SW\_RST\_R

| Bits | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3  | RSVD_7_3   | R      | <p>These bits of the SW_RST_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2    | SW_RST_DAT | R/W    | <p>Software Reset For DAT line</p> <p>This bit is used in SD/eMMC mode and it resets only a part of the data circuit and the DMA circuit is also reset. The following registers and bits are cleared by this bit:</p> <ul style="list-style-type: none"> <li>■ Buffer Data Port register <ul style="list-style-type: none"> <li>- Buffer is cleared and initialized.</li> </ul> </li> <li>■ Present State register <ul style="list-style-type: none"> <li>- Buffer Read Enable</li> <li>- Buffer Write Enable</li> <li>- Read Transfer Active</li> <li>- Write Transfer Active</li> <li>- DAT Line Active</li> <li>- Command Inhibit (DAT)</li> </ul> </li> </ul> |



| Bits | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |        | <ul style="list-style-type: none"><li>■ Block Gap Control register<ul style="list-style-type: none"><li>- Continue Request</li><li>- Stop At Block Gap Request</li></ul></li><li>■ Normal Interrupt Status register<ul style="list-style-type: none"><li>- Buffer Read Ready</li><li>- Buffer Write Ready</li><li>- DMA Interrupt</li><li>- Block Gap Event</li><li>- Transfer Complete</li></ul></li></ul> <p>In UHS-II mode, this bit shall be set to 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Work</li><li>■ 0x1 (TRUE): Reset</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 1    | SW_RST_CMD | R/W    | <p>Software Reset For CMD line</p> <p>This bit resets only a part of the command circuit is able to issue a command. This bit is also used to initialize a UHS-II command circuit. This reset is effective only for a command issuing circuit (including response error statuses related to Command Inhibit (CMD) control) and does not affect the data transfer circuit. Host controller can continue data transfer even after this reset is executed while handling subcommand-response errors.</p> <p>The following registers and bits are cleared by this bit:</p> <ul style="list-style-type: none"><li>■ Present State register: Command Inhibit (CMD) bit</li><li>■ Normal Interrupt Status register: Command Complete bit</li><li>■ Error Interrupt Status: Response error statuses related to Command Inhibit (CMD) bit</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Work</li><li>■ 0x1 (TRUE): Reset</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

| Bits | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | SW_RST_ALL | R/W    | <p>Software Reset for All</p> <p>This reset affects the entire host controller except for the card detection circuit. During its initialization, the host driver sets this bit to 1 to reset the host controller. All registers are reset except the capabilities register. If this bit is set to 1, the host driver must issue reset command and reinitialize the card.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Work</li> <li>■ 0x1 (TRUE): Reset</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.20 NORMAL\_INT\_STAT\_R

- Name: Normal Interrupt Status Register
- Description: This register reflects the status of the normal interrupt. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x30

Figure & Table 3-63 Fields for register: NORMAL\_INT\_STAT\_R

| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                            |
|------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | ERR_INTERRUPT | R      | <p>Error Interrupt</p> <p>If any of the bits in the Error Interrupt Status register are set, then this bit is set.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 14   | CQE_EVENT     | R/W1C  | <p>Command Queuing Event</p> <p>This status is set if Command Queuing/Crypto related event has occurred in eMMC/SD mode. Read CQHCl's CQIS/CRNQIS register for more details. In UHS-II Mode, this bit is irrelevant.</p> <p>Values:</p>                                                                                |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No event</li><li>■ 0x1 (TRUE): Command Queuing Event is detected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                              |
| 13   | FX_EVENT      | R      | <p>FX Event</p> <p>This status is set when R [14] of response register is set to 1 and Response Type R1/R5 is set to 0 in Transfer Mode register. This interrupt is used with response check function.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No event</li><li>■ 0x1 (TRUE): FX Event is detected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 12   | RE_TUNE_EVENT | R      | <p>Re-tuning Event</p> <p>This bit is set if the Re-Tuning Request changes from 0 to 1. Re-Tuning request is not supported.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                               |
| 11   | INT_C         | R      | <p>INT_C (Embedded)</p> <p>This bit is set if INT_C is enabled and if INT_C# pin is in low level. The INT_C# pin is not supported.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                        |
| 10   | INT_B         | R      | <p>INT_B (Embedded)</p> <p>This bit is set if INT_B is enabled and if INT_B# pin is in low level. The INT_B# pin is not supported.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                        |
| 9    | INT_A         | R      | <p>INT_A (embedded)</p> <p>This bit is set if INT_A is enabled and if INT_A# pin is in</p>                                                                                                                                                                                                                                                                                                                              |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <p>low level. The INT_A# pin is not supported.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                               |
| 8    | CARD_INTERRUPT | R      | <p>Card Interrupt</p> <p>This bit reflects the synchronized value of:</p> <ul style="list-style-type: none"><li>■ DAT [1] interrupt input for SD mode</li><li>■ DAT [2] interrupt input for UHS-II mode</li></ul> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No card interrupt</li><li>■ 0x1 (TRUE): Generate card interrupt.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 7    | CARD_REMOVAL   | R/W1C  | <p>Card Removal</p> <p>This bit is set if the Card Inserted in the Present State register changes from 1 to 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Card state stable or Debouncing</li><li>■ 0x1 (TRUE): Card removed</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                              |
| 6    | CARD_INSERTION | R/W1C  | <p>Card Insertion</p> <p>This bit is set if the Card Inserted in the Present State register changes from 0 to 1.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Card state stable or Debouncing</li><li>■ 0x1 (TRUE): Card inserted</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                           |
| 5    | BUF_RD_READY   | R/W1C  | <p>Buffer Read Ready</p> <p>This bit is set if the Buffer Read Enable changes from 0 to 1.</p>                                                                                                                                                                                                                                                                                                                                             |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not ready to read buffer.</li><li>■ 0x1 (TRUE): Ready to read buffer.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                               |
| 4    | BUF_WR_READY  | R/W1C  | <p>Buffer Write Ready</p> <p>This bit is set if the Buffer Write Enable changes from 0 to 1.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not ready to write buffer.</li><li>■ 0x1 (TRUE): Ready to write buffer.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                            |
| 3    | DMA_INTERRUPT | R/W1C  | <p>DMA Interrupt</p> <p>This bit is set if the host controller detects the SDMA Buffer Boundary during transfer. In case of ADMA, by setting the Int field in the descriptor table, the host controller generates this interrupt. This interrupt is not generated after a transfer Complete.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No DMA interrupt</li><li>■ 0x1 (TRUE): DMA interrupt is generated.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 2    | BGAP_EVENT    | R/W1C  | <p>Block Gap Event</p> <p>This bit is set when both read/write transaction is stopped at block gap due to a Stop at Block Gap Request.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No Block Gap Event</li><li>■ 0x1 (TRUE): Transaction stopped at block gap.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                               |

| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | XFER_COMPLETE | R/W1C  | <p>Transfer Complete</p> <p>This bit is set when a read/write transfer and a command with status busy is completed.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not complete</li> <li>■ 0x1 (TRUE): Command execution is completed.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                          |
| 0    | CMD_COMPLETE  | R/W1C  | <p>Command Complete</p> <p>In SD/eMMC Mode, this bit is set when the end bit of a response except for Auto CMD12 and Auto CMD23. In UHSII Mode, this bit is set when response packet is received.</p> <p>This interrupt is not generated when the Response Interrupt Disable in Transfer Mode Register is set to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No command complete</li> <li>■ 0x1 (TRUE): Command complete.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.21 ERROR\_INT\_STAT\_R

- Name: Error Interrupt Status Register
- Description: This register enables an interrupt when the Error Interrupt Status Enable is enabled and at least one of the statuses is set to 1. Writing to 1 clears the bit and writing to 0 retains the bit unchanged. Signals defined in this register can be enabled by the Error Interrupt Status Enable register, but not by the Error Interrupt Signal Enable register. More than one status can be cleared with a single register write. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x32

Figure & Table 3-64 Fields for register: ERROR\_INT\_STAT\_R

| Bits | Name        | Access | Description                                                                               |
|------|-------------|--------|-------------------------------------------------------------------------------------------|
| 15   | VENDOR_ERR3 | R/W1C  | This bit (VENDOR_ERR3) of the ERROR_INT_STAT_R register is reserved. It always returns 0. |

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 14   | VENDOR_ERR2  | R/W1C  | <p>This bit (VENDOR_ERR2) of the ERROR_INT_STAT_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                   |
| 13   | VENDOR_ERR1  | R/W1C  | <p>This bit (VENDOR_ERR1) of the ERROR_INT_STAT_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                   |
| 12   | BOOT_ACK_ERR | R/W1C  | <p>Boot Acknowledgement Error</p> <p>This bit is set when there is a timeout for boot acknowledgement or when detecting boot ack status having a value other than 010. This is applicable only when boot acknowledgement is expected in eMMC mode.</p> <p>In SD/UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                     |
| 11   | RESP_ERR     | R/W1C  | <p>Response Error</p> <p>Host Controller Version 4.00 supports response error check function to avoid overhead of response error check by host driver during DMA execution. If Response Error Check Enable is set to 1 in the Transfer Mode register, host controller checks R1 or R5 response. If an error is detected in a response, this bit is set to 1. This is applicable in SD/eMMC mode.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> </ul> |

| Bits | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |        | <ul style="list-style-type: none"> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10   | TUNING_ERR | R/W1C  | <p>Tuning Error</p> <p>This bit is set when an unrecoverable error is detected in a tuning circuit except during the tuning procedure (occurrence of an error during tuning procedure is indicated by Sampling Clock Select in the Host Control 2 register). By detecting Tuning Error, host driver needs to abort a command executing and perform tuning. To reset tuning circuit, Sampling Clock Select is set to 0 before executing tuning procedure. The Tuning Error has higher priority than the other error interrupts generated during data transfer. By detecting Tuning Error, the host driver must discard data transferred by a current read/write command and retry data transfer after the host controller retrieved from the tuning circuit error. This is applicable in SD/eMMC mode.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 9    | ADMA_ERR   | R/W1C  | <p>ADMA Error</p> <p>This bit is set when the host controller detects error during ADMA-based data transfer. The error could be due to the following reasons:</p> <ul style="list-style-type: none"> <li>■ Error response received from system bus (master I/F)</li> <li>■ ADMA3, ADMA2 descriptors invalid</li> <li>■ CQE task or transfer descriptors invalid</li> </ul> <p>When the error occurs, the state of the ADMA is saved in the ADMA Error Status register.</p> <p>In eMMC CQE mode:</p> <p>The host controller generates this interrupt when it detects an invalid descriptor data (Valid=0) at the ST_FDS state. ADMA Error State in the ADMA Error Status</p>                                                                                                                                                                                                                                                                                                                                                                              |



| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>indicates that an error has occurred in ST_FDS state. The host driver may find that Valid bit is not set at the error descriptor.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No error</li><li>■ 0x1 (TRUE): Error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8    | AUTO_CMD_ERR | R/W1C  | <p>Auto CMD Error</p> <p>This error status is used by Auto CMD12 and Auto CMD23 in SD/eMMC mode. This bit is set when detecting that any of the bits D00 to D05 in Auto CMD Error Status register has changed from 0 to 1. D07 is effective in case of Auto CMD12. Auto CMD Error Status register is valid while this bit is set to 1 and may be cleared by clearing of this bit.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No error</li><li>■ 0x1 (TRUE): Error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                          |
| 7    | CUR_LMT_ERR  | R/W1C  | <p>Current Limit Error</p> <p>By setting the SD Bus Power bit in the Power Control register, the host controller is requested to supply power for the SD bus. If the host controller supports the Current Limit function, it can be protected from an illegal card by stopping power supply to the card in which case this bit indicates a failure status. A reading of 1 for this bit means that the host controller is not supplying power to the SD card due to some failure. A reading of 0 for this bit means that the host controller is supplying power and no error has occurred. The host controller may require some sampling time to detect the current limit. DWC_msHC host controller does not support this function, this bit is always set to 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No error</li></ul> |

| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  |        | <ul style="list-style-type: none"> <li>■ 0x1 (TRUE): Power fail.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                             |
| 6    | DATA_END_BIT_ERR | R/W1C  | <p>Data End Bit Error</p> <p>This error occurs in SD/eMMC mode either when detecting 0 at the end bit position of read data that uses the DAT line or at the end bit position of the CRC status.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                               |
| 5    | DATA_CRC_ERR     | R/W1C  | <p>Data CRC Error</p> <p>This error occurs in SD/eMMC mode when detecting CRC error when transferring read data which uses the DAT line, when detecting the Write CRC status having a value other than 010 or when writing CRC status timeout.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 4    | DATA_TOUT_ERR    | R/W1C  | <p>Data Timeout Error</p> <p>This bit is set in SD/eMMC mode when detecting one of the following timeout conditions:</p> <ul style="list-style-type: none"> <li>■ Busy timeout for R1b, R5b type</li> <li>■ Busy timeout after Write CRC status</li> <li>■ Write CRC status timeout</li> <li>■ Read data timeout</li> </ul> <p>In UHS-II mode, this bit is irrelevant.</p>                                                                                                                        |

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Time out</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                       |
| 3    | CMD_IDX_ERR     | R/W1C  | <p>Command Index Error</p> <p>This bit is set if a Command Index error occurs in the command response in SD/eMMC mode.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                |
| 2    | CMD_END_BIT_ERR | R/W1C  | <p>Command End Bit Error</p> <p>This bit is set when detecting that the end bit of a command response is 0 in SD/eMMC mode.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): End bit error generated.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                        |
| 1    | CMD_CRC_ERR     | R/W1C  | <p>Command CRC Error</p> <p>Command CRC Error is generated in SD/eMMC mode for following two cases.</p> <ul style="list-style-type: none"> <li>■ If a response is returned and the Command Timeout Error is set to 0 (indicating no timeout), this bit is set to 1 when detecting a CRC error in the command response.</li> <li>■ The host controller detects a CMD line conflict by monitoring the CMD line when a command is issued. If the host controller drives the CMD line to 1 level, but detects 0 level on the CMD line at the next</li> </ul> |

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>SD clock edge, then the host controller aborts the command (stop driving CMD line) and set this bit to 1. The Command Timeout Error is also set to 1 to distinguish a CMD line conflict.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): CRC error generated.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                   |
| 0    | CMD_TOUT_ERR | R/W1C  | <p>Command Timeout Error</p> <p>In SD/eMMC Mode, this bit is set only if no response is returned within 64 SD clock cycles from the end bit of the command. If the host controller detects a CMD line conflict, along with Command CRC Error bit, this bit is set to 1, without waiting for 64 SD/eMMC card clock cycles.</p> <p>In UHS-II mode, this bit is irrelevant.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): No error</li> <li>■ 0x1 (TRUE): Time out</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.22 NORMAL\_INT\_STAT\_EN\_R

- Name: Normal Interrupt Status Enable Register
- Description: This register enables the interrupt status for Normal Interrupt Status register (NORMAL\_INT\_STAT\_R) when NORMAL\_INT\_STAT\_R is set to 1. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x34

Figure & Table 3-65 Fields for register: NORMAL\_INT\_STAT\_EN\_R

| Bits | Name    | Access | Description                                                                     |
|------|---------|--------|---------------------------------------------------------------------------------|
| 15   | RSVD_15 | R      | This bit of the NORMAL_INT_STAT_EN_R register is reserved. It always returns 0. |

| Bits | Name                  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                       |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14   | CQE_EVENT_STAT_EN     | R/W    | <p>CQE Event Status Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                          |
| 13   | FX_EVENT_STAT_EN      | R/W    | <p>FX Event Status Enable</p> <p>This bit is added from Version 4.10.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                               |
| 12   | RE_TUNE_EVENT_STAT_EN | R/W    | <p>Re-Tuning Event (UHS-I only) Status Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                       |
| 11   | INT_C_STAT_EN         | R/W    | <p>INT_C (Embedded) Status Enable</p> <p>If this bit is set to 0, the host controller clears the interrupt request to the system. The host driver may clear this bit before servicing the INT_C and may set this bit again after all interrupt requests to INT_C pin are cleared to prevent inadvertent interrupts.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 10   | INT_B_STAT_EN         | R/W    | <p>INT_B (Embedded) Status Enable</p> <p>If this bit is set to 0, the host controller clears the interrupt request to the system. The host driver may clear this bit before servicing the INT_B and may set this</p>                                                                                                                                                                                                                                                                              |



| Bits | Name                   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                        |        | <p>bit again after all interrupt requests to INT_B pin are cleared to prevent inadvertent interrupts.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9    | INT_A_STAT_EN          | R/W    | <p>INT_A (Embedded) Status Enable</p> <p>If this bit is set to 0, the host controller clears the interrupt request to the system. The host driver may clear this bit before servicing the INT_A and may set this bit again after all interrupt requests to INT_A pin are cleared to prevent inadvertent interrupts.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                  |
| 8    | CARD_INTERRUPT_STAT_EN | R/W    | <p>Card Interrupt Status Enable</p> <p>If this bit is set to 0, the host controller clears the interrupt request to the system. The card interrupt detection is stopped when this bit is cleared and restarted when this bit is set to 1. The host driver may clear the Card Interrupt Status Enable before servicing the card interrupt and may set this bit again after all interrupt requests from the card are cleared to prevent inadvertent interrupts.</p> <p>By setting this bit to 0, interrupt input must be masked by implementation so that the interrupt input is not affected by external signal in any state (for example, floating).</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 7    | CARD_REMOVAL_STAT_EN   | R/W    | <p>Card Removal Status Enable</p> <p>Values:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Bits | Name                   | Access | Description                                                                                                                                                                                    |
|------|------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                        |        | <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                |
| 6    | CARD_INSERTION_STAT_EN | R/W    | Card Insertion Status Enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> Value After Reset: 0x0<br>Exists: Always     |
| 5    | BUF_RD_READY_STAT_EN   | R/W    | Buffer Read Ready Status Enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> Value After Reset: 0x0<br>Exists: Always  |
| 4    | BUF_WR_READY_STAT_EN   | R/W    | Buffer Write Ready Status Enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 3    | DMA_INTERRUPT_STAT_EN  | R/W    | DMA Interrupt Status Enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> Value After Reset: 0x0<br>Exists: Always      |
| 2    | BGAP_EVENT_STAT_EN     | R/W    | Block Gap Event Status Enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> Value After Reset: 0x0<br>Exists: Always    |

| Bits | Name                  | Access | Description                                                                                                                                                                                                      |
|------|-----------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | XFER_COMPLETE_STAT_EN | R/W    | <p>Transfer Complete Status Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 0    | CMD_COMPLETE_STAT_EN  | R/W    | <p>Command Complete Status Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>  |

### 3.6.1.23 ERROR\_INT\_STAT\_EN\_R

- Name: Error Interrupt Status Enable Register
- Description: This register sets the interrupt status for Error Interrupt Status register (ERROR\_INT\_STAT\_R), when ERROR\_INT\_STAT\_EN\_R is set to 1. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x36

Figure & Table 3-66 Fields for register: ERROR\_INT\_STAT\_EN\_R

| Bits | Name                | Access | Description                                                                                                                                                                                                                                          |
|------|---------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | VENDOR_ERR_STAT_EN3 | R/W    | <p>The 15th bit of Error Interrupt Status Enable register is reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 14   | VENDOR_ERR_STAT_EN2 | R/W    | <p>The 14th bit of Error Interrupt Status Enable register is reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p>                       |

| Bits | Name                 | Access | Description                                                                                                                                                                                                                                                                                                                                                  |
|------|----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                      |        | Exists: Always                                                                                                                                                                                                                                                                                                                                               |
| 13   | VENDOR_ERR_STAT_EN1  | R/W    | <p>The 13th bit of Error Interrupt Status Enable register is reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                         |
| 12   | BOOT_ACK_ERR_STAT_EN | R/W    | <p>Boot Acknowledgment Error (eMMC mode only)</p> <p>Setting this bit to 1 enables setting of Boot Acknowledgment Error in Error Interrupt Status register (ERROR_INT_STAT_R).</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 11   | RESP_ERR_STAT_EN     | R/W    | <p>Response Error Status Enable (SD mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                 |
| 10   | TUNING_ERR_STAT_EN   | R/W    | <p>Tuning Error Status Enable (UHS-I mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                |
| 9    | ADMA_ERR_STAT_EN     | R/W    | <p>ADMA Error Status Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                    |

| Bits | Name                     | Access | Description                                                                                                                                                                                                                           |
|------|--------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | AUTO_CMD_ERR_STAT_EN     | R/W    | <p>Auto CMD Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 7    | CUR_LMT_ERR_STAT_EN      | R/W    | <p>Current Limit Error Status Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                    |
| 6    | DATA_END_BIT_ERR_STAT_EN | R/W    | <p>Data End Bit Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 5    | DATA_CRC_ERR_STAT_EN     | R/W    | <p>Data CRC Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 4    | DATA_TOUT_ERR_STAT_EN    | R/W    | <p>Data Timeout Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 3    | CMD_IDX_ERR_STAT_EN      | R/W    | <p>Command Index Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> </ul>                                                                                   |

| Bits | Name                    | Access | Description                                                                                                                                                                                                                              |
|------|-------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                         |        | <ul style="list-style-type: none"> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                              |
| 2    | CMD_END_BIT_ERR_STAT_EN | R/W    | <p>Command End Bit Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 1    | CMD_CRC_ERR_STAT_EN     | R/W    | <p>Command CRC Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 0    | CMD_TOUT_ERR_STAT_EN    | R/W    | <p>Command Timeout Error Status Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.24 NORMAL\_INT\_SIGNAL\_EN\_R

- Name: Normal Interrupt Signal Enable Register
- Description: This register is used to select the interrupt status that is indicated to the host system as the interrupt. All these status bits share the same 1-bit interrupt line. Setting any of these bits to 1, enables interrupt generation. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x38

Figure & Table 3-67 Fields for register: NORMAL\_INT\_SIGNAL\_EN\_R

| Bits | Name    | Access | Description                                             |
|------|---------|--------|---------------------------------------------------------|
| 15   | RSVD_15 | R      | This bit of the NORMAL_INT_STAT_R register is reserved. |

| Bits | Name                    | Access | Description                                                                                                                                                                                                  |
|------|-------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                         |        | <p>It always returns 0.<br/>         Value After Reset: 0x0<br/>         Exists: Always</p>                                                                                                                  |
| 14   | CQE_EVENT_SIGNAL_EN     | R/W    | <p>Command Queuing Engine Event Signal Enable<br/>         Values:<br/>         ■ 0x0 (FALSE): Masked<br/>         ■ 0x1 (TRUE): Enabled<br/>         Value After Reset: 0x0<br/>         Exists: Always</p> |
| 13   | FX_EVENT_SIGNAL_EN      | R/W    | <p>FX Event Signal Enable<br/>         Values:<br/>         ■ 0x0 (FALSE): Masked<br/>         ■ 0x1 (TRUE): Enabled<br/>         Value After Reset: 0x0<br/>         Exists: Always</p>                     |
| 12   | RE_TUNE_EVENT_SIGNAL_EN | R/W    | <p>Re-Tuning Event (UHS-I only) Signal Enable<br/>         Values:<br/>         ■ 0x0 (FALSE): Masked<br/>         ■ 0x1 (TRUE): Enabled<br/>         Value After Reset: 0x0<br/>         Exists: Always</p> |
| 11   | INT_C_SIGNAL_EN         | R/W    | <p>INT_C (Embedded) Signal Enable<br/>         Values:<br/>         ■ 0x0 (FALSE): Masked<br/>         ■ 0x1 (TRUE): Enabled<br/>         Value After Reset: 0x0<br/>         Exists: Always</p>             |
| 10   | INT_B_SIGNAL_EN         | R/W    | <p>INT_B (Embedded) Signal Enable<br/>         Values:<br/>         ■ 0x0 (FALSE): Masked<br/>         ■ 0x1 (TRUE): Enabled<br/>         Value After Reset: 0x0<br/>         Exists: Always</p>             |
| 9    | INT_A_SIGNAL_EN         | R/W    | INT_A (Embedded) Signal Enable                                                                                                                                                                               |

| Bits | Name                     | Access | Description                                                                                                                                                                                                      |
|------|--------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                          |        | <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                        |
| 8    | CARD_INTERRUPT_SIGNAL_EN | R/W    | <p>Card Interrupt Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>    |
| 7    | CARD_REMOVAL_SIGNAL_EN   | R/W    | <p>Card Removal Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>      |
| 6    | CARD_INSERTION_SIGNAL_EN | R/W    | <p>Card Insertion Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>    |
| 5    | BUF_RD_READY_SIGNAL_EN   | R/W    | <p>Buffer Read Ready Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 4    | BUF_WR_READY_SIGNAL_EN   | R/W    | <p>Buffer Write Ready Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p>                      |

| Bits | Name                    | Access | Description                                                                                                                                                                                                      |
|------|-------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                         |        | Exists: Always                                                                                                                                                                                                   |
| 3    | DMA_INTERRUPT_SIGNAL_EN | R/W    | <p>DMA Interrupt Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 2    | BGAP_EVENT_SIGNAL_EN    | R/W    | <p>Block Gap Event Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>   |
| 1    | XFER_COMPLETE_SIGNAL_EN | R/W    | <p>Transfer Complete Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 0    | CMD_COMPLETE_SIGNAL_EN  | R/W    | <p>Command Complete Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>  |

### 3.6.1.25 ERROR\_INT\_SIGNAL\_EN\_R

- Name: Error Interrupt Signal Enable Register
- Description: This register is used to select the interrupt status that is notified to the host system as an interrupt. All these status bits share the same 1-bit interrupt line. Setting any of these bits to 1 enables interrupt generation. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x3a

Figure &amp; Table 3-68 Fields for register: ERROR\_INT\_SIGNAL\_EN\_R

| Bits | Name                   | Access | Description                                                                                                                                                                                                                                                                                                                                                             |
|------|------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | VENDOR_ERR_SIGNAL_EN3  | R/W    | <p>The 16th bit of Error Interrupt Signal Enable is reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                             |
| 14   | VENDOR_ERR_SIGNAL_EN2  | R/W    | <p>The 15th bit of Error Interrupt Signal Enable is reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                             |
| 13   | VENDOR_ERR_SIGNAL_EN1  | R/W    | <p>The 14th bit of Error Interrupt Signal Enable is reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                             |
| 12   | BOOT_ACK_ERR_SIGNAL_EN | R/W    | <p>Boot Acknowledgment Error (eMMC mode only)</p> <p>Setting this bit to 1 enables generating interrupt signal when Boot Acknowledgement Error in Error Interrupt Status register is set.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 11   | RESP_ERR_SIGNAL_EN     | R/W    | <p>Response Error Signal Enable (SD mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                            |
| 10   | TUNING_ERR_SIGNAL_EN   | R/W    | Tuning Error Signal Enable (UHS-I mode only)                                                                                                                                                                                                                                                                                                                            |

| Bits | Name                       | Access | Description                                                                                                                                                                                                                           |
|------|----------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                            |        | <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                             |
| 9    | ADMA_ERR_SIGNAL_EN         | R/W    | <p>ADMA Error Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                             |
| 8    | AUTO_CMD_ERR_SIGNAL_EN     | R/W    | <p>Auto CMD Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 7    | CUR_LMT_ERR_SIGNAL_EN      | R/W    | <p>Current Limit Error Signal Enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                    |
| 6    | DATA_END_BIT_ERR_SIGNAL_EN | R/W    | <p>Data End Bit Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 5    | DATA_CRC_ERR_SIGNAL_EN     | R/W    | <p>Data CRC Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Masked</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |



| Bits | Name                          | Access | Description                                                                                                                                                                                                                           |
|------|-------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | DATA_TOUT_ERR_SIGNAL_EN       | R/W    | <p>Data Timeout Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>    |
| 3    | CMD_IDX_ERR_SIGNAL_EN         | R/W    | <p>Command Index Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): No error</li><li>■ 0x1 (TRUE): Error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>   |
| 2    | CMD_END_BIT_ERR_SIGNAL_E<br>N | R/W    | <p>Command End Bit Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 1    | CMD_CRC_ERR_SIGNAL_EN         | R/W    | <p>Command CRC Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 0    | CMD_TOUT_ERR_SIGNAL_EN        | R/W    | <p>Command Timeout Error Signal Enable (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Masked</li><li>■ 0x1 (TRUE): Enabled</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.26 AUTO\_CMD\_STAT\_R

- Name: Auto CMD Status Register
- Description: This register is used to indicate the CMD12 response error of Auto CMD12, and the CMD23 response error of Auto CMD23. The host driver can determine the kind of Auto CMD12/CMD23 errors that can occur in this register. Auto CMD23 errors are indicated in bit 04-01. This register is valid only when Auto CMD Error is set. This register is applicable for SD/eMMC mode.
- Size: 16 bits
- Offset: 0x3c

Figure & Table 3-69 Fields for register: AUTO\_CMD\_STAT\_R

| Bits | Name                          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RSVD_15_8                     | R      | <p>These bits of the AUTO_CMD_STAT_R register are reserved bits. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                             |
| 7    | CMD_NOT_ISSUED_AUTO_CM<br>D12 | R      | <p>Command Not Issued By Auto CMD12 Error</p> <p>If this bit is set to 1, CMD_wo_DAT is not executed due to an Auto CMD12 Error (D04-D01) in this register.</p> <p>This bit is set to 0 when Auto CMD Error is generated by Auto CMD23.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (TRUE): Not issued</li> <li>■ 0x0 (FALSE): No Error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 6    | RSVD_6                        | R      | <p>This bit of the AUTO_CMD_STAT_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                      |
| 5    | AUTO_CMD_RESP_ERR             | R      | <p>Auto CMD Response Error</p> <p>This bit is set when Response Error Check Enable in the Transfer Mode register is set to 1 and an error is detected in R1 response of either Auto CMD12 or CMD13. This status is ignored if any bit between D00 to</p>                                                                                                                                                                                         |



| Bits | Name              | Access | Description                                                                                                                                                                                                                                                                                                                    |
|------|-------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                   |        | <p>D04 is set to 1.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Error</li><li>■ 0x0 (FALSE): No Error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                           |
| 4    | AUTO_CMD_IDX_ERR  | R      | <p>Auto CMD Index Error</p> <p>This bit is set if the command index error occurs in response to a command.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Error</li><li>■ 0x0 (FALSE): No Error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                    |
| 3    | AUTO_CMD_EBIT_ERR | R      | <p>Auto CMD End Bit Error</p> <p>This bit is set when detecting that the end bit of command response is 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): End Bit Error generated.</li><li>■ 0x0 (FALSE): No error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 2    | AUTO_CMD_CRC_ERR  | R      | <p>Auto CMD CRC Error</p> <p>This bit is set when detecting a CRC error in the command response.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): CRC Error generated.</li><li>■ 0x0 (FALSE): No error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>               |
| 1    | AUTO_CMD_TOUT_ERR | R      | <p>Auto CMD Timeout Error</p> <p>This bit is set if no response is returned with 64 SDCLK</p>                                                                                                                                                                                                                                  |



| Bits | Name                | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|---------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     |        | <p>cycles from the end bit of the command.</p> <p>If this bit is set to 1, error status bits (D04-D01) are meaningless.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Time out</li><li>■ 0x0 (FALSE): No error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                    |
| 0    | AUTO_CMD12_NOT_EXEC | R      | <p>Auto CMD12 Not Executed</p> <p>If multiple memory block data transfer is not started due to a command error, this bit is not set because it is not necessary to issue an Auto CMD12. Setting this bit to 1 means that the host controller cannot issue Auto CMD12 to stop multiple memory block data transfer, due to some error. If this bit is set to 1, error status bits (D04-D01) are meaningless.</p> <p>This bit is set to 0 when Auto CMD Error is generated by Auto CMD23.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Not executed</li><li>■ 0x0 (FALSE): Executed</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.27 HOST\_CTRL2\_R

- Name: Host Control 2 Register
- Description: This register is used to control how the host controller operates. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x3e

Figure &amp; Table 3-70 Fields for register: HOST\_CTRL2\_R

| Bits | Name              | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|-------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | PRESET_VAL_ENABLE | R/W    | <p>Preset Value Enable</p> <p>This bit enables automatic selection of SDCLK frequency and Driver strength Preset Value registers. When Preset Value Enable is set, SDCLK frequency generation (Frequency Select and Clock Generator Select) and the driver strength selection are performed by the controller. These values are selected from set of Preset Value registers based on selected speed mode.</p> <p>Note: For more information, see the FAQ on Preset Register in the DWC_mshc Databook.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): SDCLK and Driver Strength are controlled by host driver.</li> <li>■ 0x1 (TRUE): Automatic Selection by Preset Value is enabled.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 14   | ASYNC_INT_ENABLE  | R/W    | <p>Asynchronous Interrupt Enable</p> <p>This bit can be set if a card supports asynchronous interrupts and Asynchronous Interrupt Support is set to 1 in the Capabilities register.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Disabled</li> <li>■ 0x1 (TRUE): Enabled</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                           |
| 13   | ADDRESSING        | R/W    | <p>64-bit Addressing</p> <p>This bit is effective when Host Version 4 Enable is set to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): 32 bits addressing</li> <li>■ 0x1 (TRUE): 64 bits addressing</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12   | HOST_VER4_ENABLE  | R/W    | <p>Host Version 4 Enable</p> <p>This bit selects either Version 3.00 compatible mode or Version 4 mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <p>Functions of following fields are modified for Host Version 4 mode:</p> <ul style="list-style-type: none"><li>■ SDMA Address: SDMA uses ADMA System Address (05Fh-058h) instead of SDMA System Address register (003h-000h).</li><li>■ ADMA2/ADMA3 selection: ADMA3 is selected by DMA select in Host Control 1 register.</li><li>■ 64-bit ADMA Descriptor Size: 128-bit descriptor is used instead of 96-bit descriptor when 64-bit Addressing is set to 1.</li><li>■ Selection of 32-bit/64-bit System Addressing: Either 32-bit or 64-bit system addressing is selected by 64-bit Addressing bit in this register.</li><li>■ 32-bit Block Count: SDMA System Address register (003h-000h) is modified to 32-bit Block Count register.</li></ul> <p>Note: It is recommended not to program ADMA3 Integrated Descriptor Address registers, UHS-II registers and Command Queuing registers (if applicable) while operating in Host version less than 4 mode (Host Version 4 Enable = 0).</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Version 3.00 compatible mode</li><li>■ 0x1 (TRUE): Version 4 mode</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 11   | CMD23_ENABLE   | R/W    | <p>CMD23 Enable</p> <p>If the card supports CMD23, this bit is set to 1. This bit is used to select Auto CMD23 or Auto CMD12 for ADMA3 data transfer.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Auto CMD23 is disabled.</li><li>■ 0x1 (TRUE): Auto CMD23 is enabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10   | ADMA2_LEN_MODE | R/W    | <p>ADMA2 Length Mode</p> <p>This bit selects ADMA2 Length mode to be either 16-bit or 26-bit.</p> <p>Values:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): 16-bit data length mode</li> <li>■ 0x1 (TRUE): 26-bit data length mode</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9    | RSVD_9         | R      | This bit of the HOST_CTRL2_R register is reserved. It always returns 0.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8    | UHS2_IF_ENABLE | R/W    | UHS-II Interface Enable<br>This bit is used to enable the UHS-II Interface. The value is reflected on the uhs2_if_en pin.<br>Values: <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): SD/eMMC interface disabled.</li> <li>■ 0x1 (TRUE): UHS-II interface enabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                           |
| 7    | SAMPLE_CLK_SEL | R/W    | Sampling Clock Select<br>This bit is used by the host controller to select the sampling clock in SD/eMMC mode to receive CMD and DAT. This bit is set by the tuning procedure and is valid after the completion of tuning (when Execute Tuning is cleared). Setting this bit to 1 means that tuning is completed successfully and setting this bit to 0 means that tuning has failed. The value is reflected on the sample_cclk_sel pin. This bit is irrelevant in UHS-II mode.<br>Values: <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Fixed clock is used to sample data.</li> <li>■ 0x1 (TRUE): Tuned clock is used to sample data.</li> </ul> Value After Reset: 0x0<br>Exists: Always<br>Volatile: True |
| 6    | EXEC_TUNING    | R/W    | Execute Tuning<br>This bit is set to 1 to start the tuning procedure in UHSI/eMMC speed modes and this bit is automatically cleared when tuning procedure is completed. This bit is irrelevant in UHS-II mode.<br>Values:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  |        | <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not tuned or Tuning completed</li><li>■ 0x1 (TRUE): Execute tuning</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5:4  | DRV_STRENGTH_SEL | R/W    | <p>Driver Strength Select</p> <p>This bit is used to select the host controller output driver in 1.8V signaling UHS-I/eMMC speed modes. The bit depends on setting of Preset Value Enable. The value is reflected on the uhs1_drv_sth pin. This bit is irrelevant in UHS-II mode.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (TYPEB): Driver TYPE B is selected.</li><li>■ 0x1 (TYPEA): Driver TYPE A is selected.</li><li>■ 0x2 (TYPEC): Driver TYPE C is selected.</li><li>■ 0x3 (TYPED): Driver TYPE D is selected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                  |
| 3    | SIGNALING_EN     | R/W    | <p>1.8V Signaling Enable</p> <p>This bit controls voltage regulator for I/O cell in UHS-I/eMMC speed mode. Setting this bit from 0 to 1 starts changing the signal voltage from 3.3V to 1.8V. Host controller clears this bit if switching to 1.8 signaling fails. The value is reflected on the uhs1_swvolt_en pin. This bit shall be set to 0 in UHS-II mode</p> <p>Note: This bit must be set for all UHS-I speed modes (SDR12/SDR25/SDR50/SDR104/DDR50).</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (V_3_3): 3.3V signalling</li><li>■ 0x1 (V_1_8): 1.8V signalling</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 2:0  | UHS_MODE_SEL     | R/W    | <p>UHS Mode/eMMC Speed Mode Select</p> <p>These bits are used to select UHS mode in SD mode of operation. In eMMC mode, these bits are used to select eMMC speed mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>UHS Mode (SD/UHS-II mode only)</p> <ul style="list-style-type: none"> <li>■ 0x0: SDR12</li> <li>■ 0x1: SDR25</li> <li>■ 0x2: SDR50</li> <li>■ 0x3: SDR104</li> <li>■ 0x4: DDR50</li> <li>■ 0x5: Reserved</li> <li>■ 0x6: Reserved</li> <li>■ 0x7: UHS-II</li> </ul> <p>eMMC Speed Mode (eMMC mode only)</p> <ul style="list-style-type: none"> <li>■ 0x0: Legacy</li> <li>■ 0x1: High speed SDR</li> <li>■ 0x2: Reserved</li> <li>■ 0x3: HS200</li> <li>■ 0x4: High speed DDR</li> <li>■ 0x5: Reserved</li> <li>■ 0x6: Reserved</li> <li>■ 0x7: HS400</li> </ul> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (SDR12): SDR12/Legacy</li> <li>■ 0x1 (SDR25): SDR25/High speed SDR</li> <li>■ 0x2 (SDR50): SDR50</li> <li>■ 0x3 (SDR104): SDR104/HS200</li> <li>■ 0x4 (DDR50): DDR50/High speed DDR</li> <li>■ 0x5 (RSVD5): Reserved</li> <li>■ 0x6 (RSVD6): Reserved</li> <li>■ 0x7 (UHS2): UHS-II/HS400</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.28 CAPABILITIES1\_R

- Name: Capabilities 1 Register - 0 to 31
- Description: This register provides the host driver with information specific to the host controller implementation. The host controller may implement these values as fixed or loaded from the flash memory during power on initialization. Capabilities register is segregated into

two 32-bit registers: CAPABILITIES1\_R and CAPABILITIES2\_R. The CAPABILITIES1\_R register is the lower part of Capabilities register.

- Size: 32 bits
- Offset: 0x40

Figure & Table 3-71 Fields for register: CAPABILITIES1\_R

| Bits  | Name              | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | SLOT_TYPE_R       | R      | <p>Slot Type</p> <p>These bits indicate usage of a slot by a specific host system.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (REMOVABLE_SLOT): Removable card slot</li> <li>■ 0x1 (EMBEDDED_SLOT): Embedded slot for one device</li> <li>■ 0x2 (SHARED_SLOT): Shared bus slot (SD mode)</li> <li>■ 0x3 (UHS2_EMBEDDED_SLOT): UHS-II multiple embedded devices</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                             |
| 29    | ASYNC_INT_SUPPORT | R      | <p>Asynchronous Interrupt Support (SD mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Asynchronous interrupt is not supported.</li> <li>■ 0x1 (TRUE): Asynchronous interrupt is supported.</li> </ul> <p>Value After Reset: 0X1</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                  |
| 28    | SYS_ADDR_64_V3    | R      | <p>64-bit System Address Support for V3</p> <p>This bit sets the host controller to support 64-bit system addressing of V3 mode.</p> <p>SDMA cannot be used in 64-bit addressing in Version 3 mode.</p> <p>If this bit is set to 1, 64-bit ADMA2 with using 96-bit descriptor can be enabled by setting Host Version 4 Enable (HOST_VER4_ENABLE = 0) and DMA select (DMA_SEL = 11b).</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): 64-bit system address for V3 is not supported.</li> <li>■ 0x1 (TRUE): 64-bit system address for V3 is</li> </ul> |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <p>supported.</p> <p>Value After Reset: 0X1</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27   | SYS_ADDR_64_V4 | R      | <p>64-bit System Address Support for V4</p> <p>This bit sets the host controller to support 64-bit system addressing of V4 mode. When this bit is set to 1, full or part of 64-bit address must be used to decode the Host Controller Registers so that Host Controller Registers can be placed above system memory area. 64-bit address decode of Host Controller registers is effective regardless of setting to 64-bit addressing in Host Control 2.</p> <p>If this bit is set to 1, 64-bit DMA Addressing for version 4 is enabled by setting Host Version 4 Enable (HOST_VER4_ENABLE = 1) and by setting 64-bit Addressing (ADDRESSING =1) in the Host Control 2 register. SDMA can be used and ADMA2 uses 128-bit descriptor.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): 64-bit system address for V4 is not supported.</li><li>■ 0x1 (TRUE): 64-bit system address for V4 is supported.</li></ul> <p>Value After Reset: 0X1</p> <p>Exists: Always</p> |
| 26   | VOLT_18        | R      | <p>Voltage Support for 1.8V</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): 1.8V is not supported.</li><li>■ 0x1 (TRUE): 1.8V is supported.</li></ul> <p>Value After Reset:</p> <p>DWC_MSHC_VOLT18_VDD1_SUPPORT</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 25   | VOLT_30        | R      | <p>Voltage Support for SD 3.0V or Embedded 1.2V</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): SD 3.0V or Embedded 1.2V is not supported.</li><li>■ 0x1 (TRUE): SD 3.0V or Embedded is supported.</li></ul> <p>Value After Reset:</p> <p>DWC_MSHC_VOLT30_VDD1_SUPPORT</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



| Bits | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|--------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |        | Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 24   | VOLT_33            | R      | <p>Voltage Support for 3.3V</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): 3.3V is not supported.</li><li>■ 0x1 (TRUE): 3.3V is supported.</li></ul> <p>Value After Reset:</p> <p>DWC_MSHC_VOLT33_VDD1_SUPPORT</p> <p>Exists: Always</p>                                                                                                                                                                                         |
| 23   | SUS_RES_SUPPORT    | R      | <p>Suspense/Resume Support</p> <p>This bit indicates whether the host controller supports Suspend/Resume functionality. If this bit is 0, the host driver does not issue either Suspend or Resume commands because the Suspend and Resume mechanism is not supported.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not supported</li><li>■ 0x1 (TRUE): Supported</li></ul> <p>Value After Reset: 0X0</p> <p>Exists: Always</p> |
| 22   | SDMA_SUPPORT       | R      | <p>SDMA Support</p> <p>This bit indicates whether the host controller is capable of using SDMA to transfer data between the system memory and the host controller directly.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): SDMA is not supported.</li><li>■ 0x1 (TRUE): SDMA is supported.</li></ul> <p>Value After Reset: 0X1</p> <p>Exists: Always</p>                                                                         |
| 21   | HIGH_SPEED_SUPPORT | R      | <p>High Speed Support</p> <p>This bit indicates whether the host controller and the host system supports High Speed mode and they can supply the SD Clock frequency from 25MHz to 50MHz.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): High Speed is not supported.</li><li>■ 0x1 (TRUE): High Speed is supported.</li></ul> <p>Value After Reset: 0X1</p>                                                                      |

| Bits  | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                |        | Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 20    | RSVD_20        | R      | <p>This bit of the CAPABILITIES1_R is a reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19    | ADMA2_SUPPORT  | R      | <p>ADMA2 Support</p> <p>This bit indicates whether the host controller is capable of using ADMA2.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): ADMA2 is not supported.</li> <li>■ 0x1 (TRUE): ADMA2 is supported.</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                |
| 18    | Embedded_8_BIT | R      | <p>8-bit Support for Embedded Device</p> <p>This bit indicates whether the host controller is capable of using an 8-bit bus width mode. This bit is not effective when the Slot Type is set to 10b.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): 8-bit Bus Width is not supported.</li> <li>■ 0x1 (TRUE): 8-bit Bus Width is supported.</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                          |
| 17:16 | MAX_BLK_LEN    | R      | <p>Maximum Block Length</p> <p>This bit indicates the maximum block size that the host driver can read and write to the buffer in the host controller. The buffer transfers this block size without wait cycles. The transfer block length is always 512 bytes for the SD Memory irrespective of this bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (ZERO): 512 Byte</li> <li>■ 0x1 (ONE): 1024 Byte</li> <li>■ 0x2 (TWO): 2048 Byte</li> <li>■ 0x3 (THREE): Reserved</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |
| 15:8  | BASE_CLK_FREQ  | R      | <ul style="list-style-type: none"> <li>■ Base Clock Frequency for SD clock</li> </ul> <p>These bits indicate the base (maximum) clock</p>                                                                                                                                                                                                                                                                                                                                                                                                                   |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | <p>frequency for the SD Clock. The definition of these bits depend on the Host Controller Version.</p> <p>6-Bit Base Clock Frequency: This mode is supported by the Host Controller version 1.00 and 2.00. The upper 2 bits are not effective and are always 0. The unit values are 1MHz. The supported clock range is 10MHz to 63MHz.</p> <ul style="list-style-type: none"><li>– 0x00: Get information through another method.</li><li>– 0x01: 1MHz</li><li>– 0x02: 2MHz</li><li>– .....</li><li>– 0x3F: 63MHz</li><li>– 0x40-0xFF: Not supported</li></ul> <p>■ 8-Bit Base Clock Frequency: This mode is supported by the Host Controller version 3.00. The unit values are 1MHz. The supported clock range is 10MHz to 255MHz.</p> <ul style="list-style-type: none"><li>– 0x00: Get information through another method.</li><li>– 0x01: 1MHz</li><li>– 0x02: 2MHz</li><li>– .....</li><li>– 0xFF: 255MHz</li></ul> <p>If the frequency is 16.5MHz, the larger value is set to 0001001b (17MHz) because the host driver uses this value to calculate the clock divider value and it does not exceed the upper limit of the SD Clock frequency. If these bits are all 0, the host system has to get information using a different method.</p> <p>Value After Reset: 0xC8</p> <p>Exists: Always</p> |
| 7    | TOUT_CLK_UNIT | R      | <p>Timeout Clock Unit</p> <p>This bit shows the unit of base clock frequency used to detect Data Timeout Error.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (KHZ): KHz</li><li>■ 0x1 (MHZ): MHz</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6    | RSVD_6        | R      | <p>This bit of the CAPABILITIES1_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5:0  | TOUT_CLK_FREQ | R      | <p>Timeout Clock Frequency</p> <p>This bit shows the base clock frequency used to detect Data Timeout Error. The Timeout Clock unit defines the unit of timeout clock frequency. It can be KHz or MHz.</p> <ul style="list-style-type: none"><li>■ 0x00: Get information through another method.</li><li>■ 0x01: 1KHz/1MHz</li><li>■ 0x02: 2KHz/2MHz</li><li>■ 0x03: 3KHz/3MHz</li><li>■ .....</li><li>■ 0x3F: 63KHz/63MHz</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |

### 3.6.1.29 CAPABILITIES2\_R

- Name: Capabilities Register - 32 to 63
- Description: This register provides the host driver with information specific to the host controller implementation. The host controller may implement these values as fixed or as loaded from flash memory during power on initialization. Capabilities register is segregated into two 32-bit registers, namely CAPABILITIES1\_R and CAPABILITIES2\_R. The CAPABILITIES2\_R register is upper part of Capabilities register.
- Size: 32 bits
- Offset: 0x44

Figure & Table 3-72 Fields for register: CAPABILITIES2\_R

| Bits  | Name             | Access | Description                                                                                                                                                 |
|-------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RSVD_62_63       | R      | <p>These bits (RSVD_62_63) of the CAPABILITIES2_R register are reserved bits. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 29    | RSVD_61          | R      | <p>This bit (RSVD_61) of the CAPABILITIES2_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>             |
| 28    | VDD2_18V_SUPPORT | R      | <p>1.8V VDD2 Support</p> <p>This bit indicates support of VDD2 for the host system.</p> <p>Values:</p>                                                      |



| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 |        | <ul style="list-style-type: none"><li>■ 0x0 (FALSE): 1.8V VDD2 is not supported.</li><li>■ 0x1 (TRUE): 1.8V VDD2 is supported.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                            |
| 27    | ADMA3_SUPPORT   | R      | <p>ADMA3 Support</p> <p>This bit indicates whether the host controller is capable of using ADMA3.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): ADMA3 is not supported.</li><li>■ 0x1 (TRUE): ADMA3 is supported.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                                                                                               |
| 26:24 | RSVD_56_58      | R      | <p>These bits (RSVD_56_58) of the CAPABILITIES2_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                  |
| 23:16 | CLK_MUL         | R      | <p>Clock Multiplier</p> <p>These bits indicate the clock multiplier of the programmable clock generator. Setting these bits to 0 means that the host controller does not support a programmable clock generator.</p> <ul style="list-style-type: none"><li>■ 0x0: Clock Multiplier is not supported.</li><li>■ 0x1: Clock Multiplier M = 2</li><li>■ 0x2: Clock Multiplier M = 3</li><li>■ .....</li><li>■ 0xFF: Clock Multiplier M = 256</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 15:14 | RE_TUNING_MODES | R      | <p>Re-Tuning Modes (UHS-I only)</p> <p>These bits select the re-tuning method and limit the maximum data length.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (MODE1): Timer</li><li>■ 0x1 (MODE2): Timer and Re-Tuning Request (Not supported)</li><li>■ 0x2 (MODE3): Auto Re-Tuning (for transfer)</li></ul>                                                                                                                                                                        |



| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  |        | <ul style="list-style-type: none"><li>■ 0x3 (RSVD_MODE): Reserved</li></ul> <p>Value After Reset: 0x2</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                     |
| 13   | USE_TUNING_SDR50 | R      | <p>Use Tuning for SDR50 (UHS-I only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (ZERO): SDR50 does not require tuning.</li><li>■ 0x1 (ONE): SDR50 requires tuning.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                |
| 12   | RSVD_44          | R      | <p>This bit (RSVD_44) of the CAPABILITIES2_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                     |
| 11:8 | RETUNE_CNT       | R      | <p>Timer Count for Re-Tuning (UHS-I only)</p> <ul style="list-style-type: none"><li>■ 0x0: Re-Tuning Timer disabled</li><li>■ 0x1: 1 seconds</li><li>■ 0x2: 2 seconds</li><li>■ 0x3: 4 seconds</li><li>■ .....</li><li>■ 0xB: 1024 seconds</li><li>■ 0xC: Reserved</li><li>■ 0xD: Reserved</li><li>■ 0xE: Reserved</li><li>■ 0xF: Get information from other sources.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |
| 7    | RSVD_39          | R      | <p>This bit (RSVD_39) of the CAPABILITIES2_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                     |
| 6    | DRV_TYPED        | R      | <p>Driver Type D Support (UHS-I only)</p> <p>This bit indicates support of Driver Type D for 1.8 Signaling.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Driver Type D is not supported.</li></ul>                                                                                                                                                                                                       |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                         |
|------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Driver Type D is supported.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                                                                                       |
| 5    | DRV_TYPEC      | R      | <p>Driver Type C Support (UHS-I only)</p> <p>This bit indicates support of Driver Type C for 1.8 Signaling.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Driver Type C is not supported.</li><li>■ 0x1 (TRUE): Driver Type C is supported.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |
| 4    | DRV_TYPEA      | R      | <p>Driver Type A Support (UHS-I only)</p> <p>This bit indicates support of Driver Type A for 1.8 Signaling.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Driver Type A is not supported.</li><li>■ 0x1 (TRUE): Driver Type A is supported.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |
| 3    | UHS2_SUPPORT   | R      | <p>UHS-II Support (UHS-II only)</p> <p>This bit indicates whether host controller supports UHS-II.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): UHS-II is not supported.</li><li>■ 0x1 (TRUE): UHS-II is supported.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                        |
| 2    | DDR50_SUPPORT  | R      | <p>DDR50 Support (UHS-I only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): DDR50 is not supported.</li><li>■ 0x1 (TRUE): DDR50 is supported.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                               |
| 1    | SDR104_SUPPORT | R      | <p>SDR104 Support (UHS-I only)</p> <p>This bit means that SDR104 requires tuning.</p>                                                                                                                                                                                                                                               |



| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               |        | <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): SDR104 is not supported.</li> <li>■ 0x1 (TRUE): SDR104 is supported.</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                                                                  |
| 0    | SDR50_SUPPORT | R      | <p>SDR50 Support (UHS-I only)</p> <p>This bit indicates that SDR50 is supported. The bit 13 (USE_TUNING_SDR50) indicates whether SDR50 requires tuning or not.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): SDR50 is not supported.</li> <li>■ 0x1 (TRUE): SDR50 is supported.</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |

### 3.6.1.30 CURR\_CAPABILITIES1\_R

- Name: Maximum Current Capabilities Register - 0 to 31
- Description: This register indicates the maximum current capability for each voltage, for VDD1. The value is meaningful if the Voltage Support is set in the Capabilities register. If this information is supplied by the host system through another method, all the Maximum Current Capabilities registers are set to 0.
- Size: 32 bits
- Offset: 0x48

Figure & Table 3-73 Fields for register: CURR\_CAPABILITIES1\_R

| Bits  | Name        | Access | Description                                                                                                                                                                                                                                                                  |
|-------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RSVD_31_24  | R      | <p>These bits of the CURR_CAPABILITIES1_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                               |
| 23:16 | MAX_CUR_18V | R      | <p>Maximum Current for 1.8V</p> <p>This bit specifies the Maximum Current for 1.8V VDD1 power supply for the card.</p> <ul style="list-style-type: none"> <li>■ 0: Get information through another method.</li> <li>■ 1: 4mA</li> <li>■ 2: 8mA</li> <li>■ 3: 13mA</li> </ul> |

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                               |
|------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             |        | <ul style="list-style-type: none"> <li>■ .....</li> <li>■ 255: 1020mA</li> </ul> <p>Value After Reset: 0x19</p> <p>Exists: Always</p>                                                                                                                                                                                                                                     |
| 15:8 | MAX_CUR_30V | R      | <p>Maximum Current for 3.0V</p> <p>This bit specifies the Maximum Current for 3.0V VDD1 power supply for the card.</p> <ul style="list-style-type: none"> <li>■ 0: Get information through another method.</li> <li>■ 1: 4mA</li> <li>■ 2: 8mA</li> <li>■ 3: 13mA</li> <li>■ .....</li> <li>■ 255: 1020mA</li> </ul> <p>Value After Reset: 0x19</p> <p>Exists: Always</p> |
| 7:0  | MAX_CUR_33V | R      | <p>Maximum Current for 3.3V</p> <p>This bit specifies the Maximum Current for 3.3V VDD1 power supply for the card.</p> <ul style="list-style-type: none"> <li>■ 0: Get information through another method.</li> <li>■ 1: 4mA</li> <li>■ 2: 8mA</li> <li>■ 3: 13mA</li> <li>■ .....</li> <li>■ 255: 1020mA</li> </ul> <p>Value After Reset: 0x19</p> <p>Exists: Always</p> |

### 3.6.1.31 CURR\_CAPABILITIES2\_R

- Name: Maximum Current Capabilities Register - 32 to 63
- Description: This register indicates the maximum current capability for each voltage (for VDD2). The value is meaningful if Voltage Support is set in the Capabilities register. If this information is supplied by the host system through another method, all the Maximum Current Capabilities registers are set to 0.
- Size: 32 bits
- Offset: 0x4c

Figure &amp; Table 3-74 Fields for register: CURR\_CAPABILITIES2\_R

| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                          |
|------|------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RSVD_63_40       | R      | <p>These bits of the CURR_CAPABILITIES2_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                       |
| 7:0  | MAX_CUR_VDD2_18V | R      | <p>Maximum Current for 1.8V VDD2</p> <p>This bit specifies the Maximum Current for 1.8V VDD2 power supply for the UHS-II card.</p> <ul style="list-style-type: none"> <li>■ 0: Get information through another method.</li> <li>■ 1: 4mA</li> <li>■ 2: 8mA</li> <li>■ 3: 13mA</li> <li>■ .....</li> <li>■ 255: 1020mA</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.32 FORCE\_AUTO\_CMD\_STAT\_R

- Name: Force Event Register for Auto CMD Error Status register
- Description: The register is not a physically implemented but is an address at which the Auto CMD Error Status register can be written. This register is applicable for SD/eMMC mode.
  - 1: Sets each bit of the Auto CMD Error Status register.
  - 0: No effect
- Size: 16 bits
- Offset: 0x50

Figure &amp; Table 3-75 Fields for register: FORCE\_AUTO\_CMD\_STAT\_R

| Bits | Name                             | Access | Description                                                                                                                                                                                        |
|------|----------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RSVD_15_8                        | R      | <p>These bits of the FORCE_AUTO_CMD_STAT_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                    |
| 7    | FORCE_CMD_NOT_ISSUED_AU_TO_CMD12 | W      | <p>Force Event for Command Not Issued By Auto CMD12 Error</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (TRUE): Command Not Issued By Auto CMD12 Error Status is set.</li> </ul> |



| Bits | Name                        | Access | Description                                                                                                                                                                                                                                                 |
|------|-----------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                             |        | <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not affected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                            |
| 6    | RSVD_6                      | R      | <p>This bit of the FORCE_AUTO_CMD_STAT_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                               |
| 5    | FORCE_AUTO_CMD_RESP_ER<br>R | W      | <p>Force Event for Auto CMD Response Error</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Auto CMD Response Error Status is set.</li><li>■ 0x0 (FALSE): Not affected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 4    | FORCE_AUTO_CMD_IDX_ERR      | W      | <p>Force Event for Auto CMD Index Error</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Auto CMD Index Error Status is set.</li><li>■ 0x0 (FALSE): Not affected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>       |
| 3    | FORCE_AUTO_CMD_EBIT_ERR     | W      | <p>Force Event for Auto CMD End Bit Error</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Auto CMD End Bit Error Status is set.</li><li>■ 0x0 (FALSE): Not affected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>   |
| 2    | FORCE_AUTO_CMD_CRC_ERR      | W      | <p>Force Event for Auto CMD CRC Error</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Auto CMD CRC Error Status is set.</li><li>■ 0x0 (FALSE): Not affected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>           |
| 1    | FORCE_AUTO_CMD_TOUT_ER<br>R | W      | <p>Force Event for Auto CMD Timeout Error</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Auto CMD Timeout Error Status is set.</li></ul>                                                                                            |



| Bits | Name                          | Access | Description                                                                                                                                                                                                                                                    |
|------|-------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                               |        | <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                             |
| 0    | FORCE_AUTO_CMD12_NOT_EX<br>EC | W      | <p>Force Event for Auto CMD12 Not Executed</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (TRUE): Auto CMD12 Not Executed Status is set.</li> <li>■ 0x0 (FALSE): Not affected.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.33 FORCE\_ERROR\_INT\_STAT\_R

- Name: Force Event Register for Error Interrupt Status
- Description: This register is not physically implemented but is an address at which the Error Interrupt Status register can be written. The effect of a write to this address is reflected in the Error Interrupt Status register if the corresponding bit of the Error Interrupt Status Enable register is set. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 16 bits
- Offset: 0x52

Figure & Table 3-76 Fields for register: FORCE\_ERROR\_INT\_STAT\_R

| Bits | Name               | Access | Description                                                                                                                                                      |
|------|--------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | FORCE_VENDOR_ERR3  | W      | <p>This bit (FORCE_VENDOR_ERR3) of the FORCE_ERROR_INT_STAT_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 14   | FORCE_VENDOR_ERR2  | W      | <p>This bit (FORCE_VENDOR_ERR2) of the FORCE_ERROR_INT_STAT_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 13   | FORCE_VENDOR_ERR1  | W      | <p>This bit (FORCE_VENDOR_ERR1) of the FORCE_ERROR_INT_STAT_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 12   | FORCE_BOOT_ACK_ERR | W      | Force Event for Boot Ack error                                                                                                                                   |

| Bits | Name               | Access | Description                                                                                                                                                                                                                                                      |
|------|--------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |        | <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Boot ack Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                           |
| 11   | FORCE_RESP_ERR     | W      | <p>Force Event for Response Error (SD mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Response Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>      |
| 10   | FORCE_TUNING_ERR   | W      | <p>Force Event for Tuning Error (UHS-I Mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Tuning Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>       |
| 9    | FORCE_ADMA_ERR     | W      | <p>Force Event for ADMA Error</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): ADMA Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                             |
| 8    | FORCE_AUTO_CMD_ERR | W      | <p>Force Event for Auto CMD Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Auto CMD Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 7    | FORCE_CUR_LMT_ERR  | W      | <p>Force Event for Current Limit Error</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Current Limit Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p>                                 |



| Bits | Name                   | Access | Description                                                                                                                                                                                                                                                                 |
|------|------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                        |        | Exists: Always                                                                                                                                                                                                                                                              |
| 6    | FORCE_DATA_END_BIT_ERR | W      | <p>Force Event for Data End Bit Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not affected.</li><li>■ 0x1 (TRUE): Data End Bit Error Status is set.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>       |
| 5    | FORCE_DATA_CRC_ERR     | W      | <p>Force Event for Data CRC Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not affected.</li><li>■ 0x1 (TRUE): Data CRC Error Status is set.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>               |
| 4    | FORCE_DATA_TOUT_ERR    | W      | <p>Force Event for Data Timeout Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not affected.</li><li>■ 0x1 (TRUE): Data Timeout Error Status is set.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>       |
| 3    | FORCE_CMD_IDX_ERR      | W      | <p>Force Event for Command Index Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not affected.</li><li>■ 0x1 (TRUE): Command Index Error Status is set.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>     |
| 2    | FORCE_CMD_END_BIT_ERR  | W      | <p>Force Event for Command End Bit Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Not affected.</li><li>■ 0x1 (TRUE): Command End Bit Error Status is set.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

| Bits | Name               | Access | Description                                                                                                                                                                                                                                                                    |
|------|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | FORCE_CMD_CRC_ERR  | W      | <p>Force Event for Command CRC Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Command CRC Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>         |
| 0    | FORCE_CMD_TOUT_ERR | W      | <p>Force Event for Command Timeout Error (SD/eMMC mode only)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Not affected.</li> <li>■ 0x1 (TRUE): Command Timeout Error Status is set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.1.34 ADMA\_ERR\_STAT\_R

- Name: ADMA Error Status Register
- Description: This register stores the ADMA state during an ADMA error. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 8 bits
- Offset: 0x54

Figure & Table 3-77 Fields for register: ADMA\_ERR\_STAT\_R

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|------|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3  | RSVD_7_3     | R      | <p>These bits of the ADMA_ERR_STAT_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                         |
| 2    | ADMA_LEN_ERR | R      | <p>ADMA Length Mismatch Error States</p> <p>This error occurs in the following instances:</p> <ul style="list-style-type: none"> <li>■ While the Block Count Enable is being set, the total data length specified by the descriptor table is different from that specified by the Block Count and Block Length.</li> <li>■ When the total data length cannot be divided by the block length.</li> </ul> |



| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (NO_ERR): No error</li><li>■ 0x1 (ERROR): Error</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1:0  | ADMA_ERR_STATES | R      | <p>ADMA Error States</p> <p>These bits indicate the state of ADMA when an error occurs during ADMA data transfer.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (ST_STOP): Stop DMA - SYS_ADR register points to a location next to the error descriptor.</li><li>■ 0x1 (ST_FDS): Fetch Descriptor - SYS_ADR register points to the error descriptor.</li><li>■ 0x2 (UNUSED): Never set this state.</li><li>■ 0x3 (ST_TFR): Transfer Data - SYS_ADR register points to a location next to the error descriptor.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.35 ADMA\_SA\_LOW\_R

- Name: ADMA System Address Register - Low
- Description: This register holds the lower 32-bit system address for DMA transfer. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 32 bits
- Offset: 0x58

Figure & Table 3-78 Fields for register: ADMA\_SA\_LOW\_R

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                              |
|------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ADMA_SA_LOW | R/W    | <p>ADMA System Address</p> <p>These bits indicate the lower 32 bits of the ADMA system address.</p> <ul style="list-style-type: none"><li>■ SDMA: If Host Version 4 Enable is set to 1, this register stores the system address of the data location.</li><li>■ ADMA2: This register stores the byte address of the executing command of the descriptor table.</li></ul> |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                              |
|------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <ul style="list-style-type: none"> <li>■ ADMA3: This register is set by ADMA3. ADMA2 increments the address of this register that points to the next line, every time a descriptor line is fetched.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.36 ADMA\_SA\_HIGH\_R

- Name: ADMA System Address Register - High
- Description: This register holds the upper 32-bit system address for the DMA transfer. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 32 bits
- Offset: 0x5c

Figure & Table 3-79 Fields for register: ADMA\_SA\_HIGH\_R

| Bits | Name         | Access | Description                                                                                                                                                                   |
|------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ADMA_SA_HIGH | R/W    | <p>ADMA System Address</p> <p>These bits indicate the upper 32 bits of the ADMA system address.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.37 PRESET\_INIT\_R

- Name: Preset Value for Initialization
- Description: This register defines Preset Value for Initialization in SD/eMMC mode.
- Size: 16 bits
- Offset: 0x60

Figure & Table 3-80 Fields for register: PRESET\_INIT\_R

| Bits  | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                          |
|-------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL | R      | <p>Driver Strength Select Value</p> <p>These bits indicate that the driver strength is supported by 1.8V signaling bus speed modes. These bits are meaningless for 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> </ul> |

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                        |
|-------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 |        | <ul style="list-style-type: none"> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                                                                                                                            |
| 13:11 | RSVD_13_11      | R      | These bits of the PRESET_INIT_R register are reserved.<br>They always return 0.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                        |
| 10    | CLK_GEN_SEL_VAL | R      | Clock Generator Select Value<br>This bit is effective when the host controller supports a programmable clock generator.<br>Values: <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 9:0   | FREQ_SEL_VAL    | R      | SDCLK/RCLK Frequency Select Value<br>10-bit preset value to be set in SDCLK/RCLK Frequency Select field of the Clock Control register described by a host system.<br>Value After Reset: 250<br>Exists: Always                                                                                                                                      |

### 3.6.1.38 PRESET\_DS\_R

- Name: Preset Value for Default Speed
- Description: This register defines Preset Value for Default Speed mode in SD mode.
- Size: 16 bits
- Offset: 0x62

Figure & Table 3-81 Fields for register: PRESET\_DS\_R

| Bits  | Name        | Access | Description                                                                                                                                                                                                |
|-------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL | R      | Driver Strength Select Value<br>These bits indicate the driver strength value supported by 1.8V signaling bus speed modes. This field is meaningless for the default speed mode as it uses 3.3V signaling. |

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 |        | <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                              |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_DS_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when host controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>10-bit preset value to be set in SDCLK/RCLK Frequency Select field of the Clock Control register described by a Host System.</p> <p>Value After Reset: 4</p> <p>Exists: Always</p>                                                                                                                                       |

### 3.6.1.39 PRESET\_HS\_R

- Name: Preset Value for High Speed
- Description: This register defines Preset Value for High Speed mode in SD mode.
- Size: 16 bits
- Offset: 0x64

Figure & Table 3-82 Fields for register: PRESET\_HS\_R

| Bits  | Name        | Access | Description                                                                                        |
|-------|-------------|--------|----------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL | R      | <p>Driver Strength Select Value</p> <p>These bits indicate the driver strength value supported</p> |

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 |        | <p>by 1.8V signaling bus speed modes. This field is meaningless for high speed mode as it uses 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_HS_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                      |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when host controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                       |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>10-bit preset value to be set in SDCLK/RCLK Frequency Select field of the Clock Control register described by a host system.</p> <p>Value After Reset: 2</p> <p>Exists: Always</p>                                                                                                                                                                                                             |

### 3.6.1.40 PRESET\_SDR12\_R

- Name: Preset Value for SDR12
- Description: This register defines Preset Value for SDR12 and Legacy speed mode in SD and eMMC mode respectively.
- Size: 16 bits
- Offset: 0x66

Figure &amp; Table 3-83 Fields for register: PRESET\_SDR12\_R

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL     | R      | <p>Driver Strength Select Value</p> <p>These bits indicate the driver strength value supported for the SDR12 bus speed mode. These bits are meaningless for 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_SDR12_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                              |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when host controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                                  |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>10-bit preset value to be set in SDCLK/RCLK Frequency Select field of the Clock Control register described by a host system.</p> <p>Value After Reset: 4</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                        |

### 3.6.1.41 PRESET\_SDR25\_R

- Name: Preset Value for SDR25
- Description: This register defines Preset Value for SDR25 and High Speed SDR speed mode in SD and eMMC mode respectively.
- Size: 16 bits

- Offset: 0x68

Figure &amp; Table 3-84 Fields for register: PRESET\_SDR25\_R

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL     | R      | <p>Driver Strength Select Value</p> <p>These bits indicate the driver strength value supported for the SDR25 bus speed mode. These bits are meaningless for 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_SDR25_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                              |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when Host Controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                                  |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>10-bit preset value to be set in SDCLK/RCLK Frequency Select field of the Clock Control register described by a Host System.</p> <p>Value After Reset: 2</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                        |

### 3.6.1.42 PRESET\_SDR50\_R

- Name: Preset Value for SDR50
- Description: This register defines Preset Value for SDR50 speed mode in SD mode.
- Size: 16 bits

- Offset: 0x6a

Figure &amp; Table 3-85 Fields for register: PRESET\_SDR50\_R

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL     | R      | <p>Driver Strength Select Value</p> <p>These bits indicate driver strength value supported for SDR50 bus speed mode. These bits are meaningless for 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_SDR50_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                      |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when host controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                          |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>10-bit preset value to be set in SDCLK/RCLK Frequency Select field of the Clock Control register described by a host system.</p> <p>Value After Reset: 1</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                |

### 3.6.1.43 PRESET\_SDR104\_R

- Name: Preset Value for SDR104
- Description: This register defines Preset Value for SDR104 and HS200 speed modes in SD and eMMC modes, respectively.

- Size: 16 bits
- Offset: 0x6c

Figure &amp; Table 3-86 Fields for register: PRESET\_SDR104\_R

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL     | R      | <p>Driver Strength Select Value</p> <p>These bits indicate driver strength value supported for SDR104 bus speed mode. These bits are meaningless for 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_SDR104_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                      |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when host controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                           |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>These bits specify a 10-bit preset value that must be set in the SDCLK/RCLK Frequency Select field of the Clock Control register described by a host system.</p> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                 |

### 3.6.1.44 PRESET\_DDR50\_R

- Name: Preset Value for DDR50

- Description: This register defines the Preset Value for DDR50 and High Speed DDR speed modes in SD and eMMC modes, respectively.
- Size: 16 bits
- Offset: 0x6e

Figure &amp; Table 3-87 Fields for register: PRESET\_DDR50\_R

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | DRV_SEL_VAL     | R      | <p>Driver Strength Select Value</p> <p>These bits indicate driver strength value supported for DDR50 bus speed mode. These bits are meaningless for 3.3V signaling.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (TYPEB): Driver Type B is selected.</li> <li>■ 0x1 (TYPEA): Driver Type A is selected.</li> <li>■ 0x2 (TYPEC): Driver Type C is selected.</li> <li>■ 0x3 (TYPED): Driver Type D is selected.</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 13:11 | RSVD_13_11      | R      | <p>These bits of the PRESET_DDR50_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                      |
| 10    | CLK_GEN_SEL_VAL | R      | <p>Clock Generator Select Value</p> <p>This bit is effective when host controller supports programmable clock generator.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Host Controller Ver2.0 Compatible Clock Generator</li> <li>■ 0x1 (PROG): Programmable Clock Generator</li> </ul> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                          |
| 9:0   | FREQ_SEL_VAL    | R      | <p>SDCLK/RCLK Frequency Select Value</p> <p>These bits specify a 10-bit preset value that must be set in the SDCLK/RCLK Frequency Select field of the Clock Control register, as described by a host system.</p> <p>Value After Reset: 2</p> <p>Exists: Always</p>                                                                                                                                                                                                                            |

### 3.6.1.45 ADMA\_ID\_LOW\_R

- Name: ADMA3 Integrated Descriptor Address Register - Low
- Description: This register holds the lower 32-bit Integrated Descriptor address. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 32 bits
- Offset: 0x78

Figure &amp; Table 3-88 Fields for register: ADMA\_ID\_LOW\_R

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ADMA_ID_LOW | R/W    | <p>ADMA Integrated Descriptor Address</p> <p>These bits indicate the lower 32 bits of the ADMA Integrated Descriptor address. The start address of Integrated Descriptor is set to these register bits. The ADMA3 fetches one Descriptor Address and increments these bits to indicate the next descriptor address.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.46 ADMA\_ID\_HIGH\_R

- Name: ADMA3 Integrated Descriptor Address Register - High
- Description: This register holds the upper 32-bit Integrated Descriptor address. This register is applicable for SD/eMMC/UHS-II mode.
- Size: 32 bits
- Offset: 0x7c

Figure &amp; Table 3-89 Fields for register: ADMA\_ID\_HIGH\_R

| Bits | Name         | Access | Description                                                                                                                                                                                                 |
|------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ADMA_ID_HIGH | R/W    | <p>ADMA Integrated Descriptor Address</p> <p>These bits indicate the upper 32 bits of the ADMA Integrated Descriptor address.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.47 SLOT\_INTR\_STATUS\_R

- Name: Slot Interrupt Status Register
- Description: This register indicates the interrupt status of each slot.
- Size: 16 bits

- Offset: 0xfc

Figure &amp; Table 3-90 Fields for register: SLOT\_INTR\_STATUS\_R

| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | RESERVED_15_8 | R      | <p>These bits of the SLOT_INTR_STATUS_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:0  | INTR_SLOT     | R      | <p>Interrupt signal for each Slot</p> <p>These status bits indicate the logical OR of interrupt signal and wakeup signal for each slot. A maximum of 8 slots can be defined. If one interrupt signal is associated with multiple slots, the host driver can identify the interrupt that is generated by reading these bits. By a power on reset or by setting Software Reset For All bit, the interrupt signals are de-asserted and this status reads 00h.</p> <ul style="list-style-type: none"> <li>■ Bit 00: Slot 1</li> <li>■ Bit 01: Slot 2</li> <li>■ Bit 02: Slot 3</li> <li>■ .....</li> <li>■ .....</li> <li>■ Bit 07: Slot 8</li> </ul> <p>Note: MSHC host controller support single card slot. This register shall always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.1.48 HOST\_CNTRL\_VERS\_R

- Name: Host Controller Version
- Description: This register is used to indicate the Host Controller Version number.
- Size: 16 bits
- Offset: 0xfe

Figure &amp; Table 3-91 Fields for register: HOST\_CNTRL\_VERS\_R

| Bits | Name               | Access | Description                                                                               |
|------|--------------------|--------|-------------------------------------------------------------------------------------------|
| 15:8 | VENDOR_VERSION_NUM | R      | <p>Vendor Version Number</p> <p>This field is reserved for the vendor version number.</p> |

| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  |        | <p>Host driver must not use this status.</p> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:0  | SPEC_VERSION_NUM | R      | <p>Specification Version Number</p> <p>These bits indicate the host controller specification version. The upper and lower 4 bits indicate the version. Values 0x06-0xFF are reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (VER_1_00): SD Host Controller Specification Version 1.00</li> <li>■ 0x1 (VER_2_00): SD Host Controller Specification Version 2.00</li> <li>■ 0x2 (VER_3_00): SD Host Controller Specification Version 3.00</li> <li>■ 0x3 (VER_4_00): SD Host Controller Specification Version 4.00</li> <li>■ 0x4 (VER_4_10): SD Host Controller Specification Version 4.10</li> <li>■ 0x5 (VER_4_20): SD Host Controller Specification Version 4.20</li> </ul> <p>Value After Reset: 5</p> <p>Exists: Always</p> |

## 3.6.2 DWC\_mshc\_map/DWC\_mshc\_embedded\_control\_block Registers

### 3.6.2.1 EMBEDDED\_CTRL\_R

- Name: Embedded Control Register
- Description: This register controls the embedded device. When the host controller is connected to a removable device, this register is not used.
- Size: 32 bits
- Offset: 0xf6c

Figure & Table 3-92 Fields for Register: EMBEDDED\_CTRL\_R

| Bits | Name    | Access | Description                                                                                                               |
|------|---------|--------|---------------------------------------------------------------------------------------------------------------------------|
| 31   | RSVD_31 | R      | <p>This bit (RSVD_31) of the EMBEDDED_CTRL_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> |



| Bits  | Name              | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                   |        | Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30:24 | BACK_END_PWR_CTRL | R/W    | <p>Back-End Power Control (SD mode)</p> <p>Each bit of this field controls back-end power supply for an embedded device.</p> <ul style="list-style-type: none"><li>■ 0: Back-End Power is off.</li><li>■ 1: Back-End Power is supplied.</li></ul> <p>D24: Back-End Power for Device 1</p> <p>D25: Back-End Power for Device 2</p> <p>D26: Back-End Power for Device 3</p> <p>D27: Back-End Power for Device 4</p> <p>D28: Back-End Power for Device 5</p> <p>D29: Back-End Power for Device 6</p> <p>D30: Back-End Power for Device 7</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 23    | RSVD_23           | R      | <p>This bit (RSVD_23) of the EMBEDDED_CTRL_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 22:20 | INT_PIN_SEL       | R/W    | <p>Interrupt Pin Select</p> <p>These bits enable the interrupt pin inputs.</p> <ul style="list-style-type: none"><li>■ 000: Interrupts (INT_A, INT_B, INT_C) are disabled.</li><li>■ xx1: INT_A is enabled.</li><li>■ x1x: INT_B is enabled.</li><li>■ 1xx: INT_C is enabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                   |
| 19    | RSVD_19           | R      | <p>This bit (RSVD_19) of the EMBEDDED_CTRL_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18:16 | CLK_PIN_SEL       | R/W    | <p>Clock Pin Select (SD Mode)</p> <p>This bit is selected by one of clock pin outputs.</p> <ul style="list-style-type: none"><li>■ 0x0: Clock pins are disabled.</li><li>■ 0x1: CLK [1] is selected.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                |



| Bits | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                  |        | <ul style="list-style-type: none"><li>■ 0x2: CLK [2] is selected.</li><li>■ ..</li><li>■ ..</li><li>■ ..</li><li>■ 0x7: CLK [7] is selected.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15   | RSVD_15          | R      | <p>This bit (RSVD_15) of the EMBEDDED_CTRL_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14:8 | BUS_WIDTH_PRESET | R      | <p>Bus Width Preset (SD mode)</p> <p>Each bit of this field specifies the bus width for each embedded device. The shared bus supports mixing of 4-bit and 8-bit bus width devices.</p> <ul style="list-style-type: none"><li>■ D08: Bus Width Preset for Device 1</li><li>■ D09: Bus Width Preset for Device 2</li><li>■ D10: Bus Width Preset for Device 3</li><li>■ D11: Bus Width Preset for Device 4</li><li>■ D12: Bus Width Preset for Device 5</li><li>■ D13: Bus Width Preset for Device 6</li><li>■ D14: Bus Width Preset for Device 7</li></ul> <p>Function of each bit is defined as follows:</p> <ul style="list-style-type: none"><li>■ 0: 4-bit bus width mode</li><li>■ 1: 8-bit bus width mode</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 7:6  | RSVD_7_6         | R      | <p>These bits (RSVD_7_6) of the EMBEDDED_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5:4  | NUM_INT_PIN      | R      | <p>Number of Interrupt Input Pins</p> <p>This field indicates support of interrupt input pins for an embedded system.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | RSVD_3      | R      | <p>This bit (RSVD_3) of the EMBEDDED_CTRL_R register is reserved. It always returns 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                      |
| 2:0  | NUM_CLK_PIN | R      | <p>Number of Clock Pins (SD mode)</p> <p>This field indicates support of clock pins to select one of devices for shared bus system. Up to 7 clock pins can be supported.</p> <ul style="list-style-type: none"> <li>■ 0x0: Shared bus is not supported.</li> <li>■ 0x1: 1 SDCLK is supported.</li> <li>■ 0x2 - 2 SDCLK is supported.</li> <li>■ ..</li> <li>■ ..</li> <li>■ ..</li> <li>■ 0x7: 7 SDCLK is supported.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.3 DWC\_mshc\_map/DWC\_mshc\_vendor2\_block Registers

#### 3.6.3.1 CQVER

- Name: Command Queuing Version Register
- Description: This register provides information about the version of the eMMC command queueing standard, which is implemented by the CQE in BCD format.
- Size: 32 bits
- Offset: 0x180

Figure & Table 3-93 Fields for register: CQVER

| Bits  | Name            | Access | Description                                                                                                                                           |
|-------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | EMMMC_VER_RSVD  | R      | <p>These bits of the CQVER register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                       |
| 11:8  | EMMMC_VER_MAJOR | R      | <p>This bit indicates the eMMC major version (1st digit left of decimal point) in BCD format.</p> <p>Value After Reset: 0x5</p> <p>Exists: Always</p> |



| Bits | Name            | Access | Description                                                                                                                                             |
|------|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4  | EMMC_VER_MINOR  | R      | <p>This bit indicates the eMMC minor version (1st digit right of decimal point) in BCD format.</p> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>  |
| 3:0  | EMMC_VER_SUFFIX | R      | <p>This bit indicates the eMMC version suffix (2nd digit right of decimal point) in BCD format.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.3.2 CQCAP

- Name: Command Queuing Capabilities Register
- Description: This register indicates the capabilities of the command queuing engine.
- Size: 32 bits
- Offset: 0x180 + 0x4

Figure & Table 3-94 Fields for Register: CQCAP

| Bits  | Name           | Access | Description                                                                                                                                                                                                                                                                                                        |
|-------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | CQCCAP_RSVD3   | R      | <p>These bits [31:29] of the CQCAP register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                            |
| 28    | CRYPTO_SUPPORT | R      | <p>Crypto Support</p> <p>This bit indicates whether the Host controller supports cryptographic operations.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FALSE): Crypto is not supported.</li><li>■ 0x1 (TRUE): Crypto is supported.</li></ul> <p>Value After Reset: 0</p> <p>Exists: Always</p> |
| 27:16 | CQCCAP_RSVD2   | R      | <p>These bits [27:16] of the CQCAP register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                            |
| 15:12 | ITCFMUL        | R      | <p>Internal Timer Clock Frequency Multiplier (ITCFMUL)</p> <p>This field indicates the frequency of the clock used for interrupt coalescing timer and for determining the SQS polling period. See ITCFVAL definition for details.</p>                                                                              |

| Bits  | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                            |
|-------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |              |        | <p>Values 0x5 to 0xF are reserved.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (CLK_1KHz): 1KHz clock</li> <li>■ 0x1 (CLK_10KHz): 10KHz clock</li> <li>■ 0x2 (CLK_100KHz): 100KHz clock</li> <li>■ 0x3 (CLK_1MHz): 1MHz clock</li> <li>■ 0x4 (CLK_10MHz): 10MHz clock</li> </ul> <p>Value After Reset: 3</p> <p>Exists: Always</p> |
| 11:10 | CQCCAP_RSVD1 | R      | <p>These bits of the CQCCAP register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                       |
| 9:0   | ITCFVAL      | R      | <p>Internal Timer Clock Frequency Value (ITCFVAL)</p> <p>This field scales the frequency of the timer clock provided by ITCFMUL. The final clock frequency of actual timer clock is calculated as ITCFVAL* ITCFMUL.</p> <p>Value After Reset: 0</p> <p>Exists: Always</p>                                                                              |

### 3.6.3.3 CQCFG

- Name: Command Queuing Configuration Register
- Description: This register controls CQE behavior affecting the general operation of command queuing engine.
- Size: 32 bits
- Offset: 0x180 + 0x8

Figure & Table 3-95 Fields for register: CQCFG

| Bits  | Name         | Access | Description                                                                                                                                                                                                                  |
|-------|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | CQCCFG_RSVD3 | R      | <p>These bits (CQCCFG_RSVD3) of the CQCFG register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                               |
| 12    | DCMD_EN      | R/W    | <p>This bit indicates to the hardware whether the task descriptor in slot #31 of the TDL is a data transfer descriptor or a direct-command descriptor. CQE uses this bit when a task is issued in slot #31, to determine</p> |



| Bits | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                |        | <p>how to decode the task descriptor.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (SLOT31_DCMD_ENABLE): Task descriptor in slot #31 is a DCMD task descriptor.</li><li>■ 0x0 (SLOT31_DCMD_DISABLE): Task descriptor in slot #31 is a data transfer task descriptor.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p>                                                                                                            |
| 11:9 | CQCCFG_RSVD2   | R      | <p>These bits (CQCCFG_RSVD2) of the CQCFG register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                               |
| 8    | TASK_DESC_SIZE | R/W    | <p>Bit Value Description</p> <p>This bit indicates the size of task descriptor used in host memory. This bit can only be configured when Command Queuing Enable bit is 0 (Command queuing is disabled).</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TASK_DESC_128b): Task descriptor size is 128 bits.</li><li>■ 0x0 (TASK_DESC_64b): Task descriptor size is 64 bits.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p>        |
| 7:2  | CQCCFG_RSVD1   | R      | <p>These bits (CQCCFG_RSVD1) of the CQCFG register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                               |
| 1    | Reserved       | R      |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0    | CQ_EN          | R/W    | <p>Enable command queuing engine (CQE)</p> <p>When CQE is disabled, the software controls the eMMC bus using the registers between the addresses 0x000 to 0x1FF. Before the software writes to this bit, the software verifies that the eMMC host controller is in idle state and there are no ongoing commands or data transfers. When software wants to exit command queuing mode, it clears all previous tasks (if any) before setting this bit to 0.</p> |



| Bits | Name | Access | Description                                                                                                                                                                                                                                |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (CQE_ENABLE): Enable command queuing.</li><li>■ 0x0 (CQE_DISABLE): Disable command queuing.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> <p>Testable: Restore</p> |

### 3.6.3.4 CQCTL

- Name: Command Queuing Control Register
- Description: This register controls CQE behavior affecting the general operation of command queuing module or simultaneous operation of multiple tasks.
- Size: 32 bits
- Offset: 0x180 + 0xc

Figure & Table 3-96 Fields for register: CQCTL

| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | CQCTL_RSVD2   | R      | <p>These bits (CQCTL_RSVD2) of the CQCTL register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                  |
| 8    | CLR_ALL_TASKS | R/W    | <p>Clear all tasks</p> <p>This bit can only be written when the controller is halted. This bit does not clear tasks in the device. The software has to use the CMDQ_TASK_MGMT command to clear device's queue.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (CLEAR_ALL_TASKS): Clears all the tasks in the controller.</li><li>■ 0x0 (NO_EFFECT): Programming 0 has no effect.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 7:1  | CQCTL_RSVD1   | R      | <p>These bits (CQCTL_RSVD1) of the CQCTL register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                        |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | Volatile: True                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0    | HALT | R/W    | <p>Halt request and resume</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (HALT_CQE): Software writes 1 to this bit when it wants to acquire software control over the eMMC bus and to disable CQE from issuing command on the bus.</li><li>■ 0x0 (RESUME_CQE): Software writes 0 to this bit to exit from the halt state and resume CQE activity.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.3.5 CQIS

- Name: Command Queuing Interrupt Status Register
- Description: This register indicates pending interrupts that require service. Each bit in this register is asserted in response to a specific event, only if the respective bit is set in the CQISE register.
- Size: 32 bits
- Offset: 0x180 + 0x10

Figure & Table 3-97 Fields for register: CQIS

| Bits | Name       | Access | Description                                                                                                                                          |
|------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | CQIS_RSVD1 | R      | <p>These bits of the CQIS register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 5    | Reserved   | R      |                                                                                                                                                      |
| 4    | Reserved   | R      |                                                                                                                                                      |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | TCL  | R/W1C  | <p>Task cleared interrupt</p> <p>This status bit is asserted (if CQISE.TCL_STE=1) when a task clear operation is completed by CQE. The completed task clear operation is either an individual task clear (by writing CQTCLR) or clearing of all tasks (by writing CQCTL). A value of 1 clears this status bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (SET): TCL interrupt is set.</li> <li>■ 0x0 (NOTSET): TCL interrupt is not set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                         |
| 2    | RED  | R/W1C  | <p>Response error detected interrupt</p> <p>This status bit is asserted (if CQISE.RED_STE=1) when a response is received with an error bit set in the device status field. Configure the CQRMEM register to identify device status bit fields that may trigger an interrupt and that are masked. A value of 1 clears this status bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (SET): RED interrupt is set.</li> <li>■ 0x0 (NOTSET): RED interrupt is not set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                  |
| 1    | TCC  | R/W1C  | <p>Task complete interrupt</p> <p>This status bit is asserted (if CQISE.TCC_STE=1) when at least one of the following conditions are met:</p> <ul style="list-style-type: none"> <li>■ A task is completed and the INT bit is set in its task descriptor.</li> <li>■ Interrupt caused by interrupt coalescing logic due to timeout.</li> <li>■ Interrupt coalescing logic reached the configured threshold.</li> <li>■ A value of 1 clears this status bit.</li> </ul> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (SET): TCC interrupt is set.</li> <li>■ 0x0 (NOTSET): TCC interrupt is not set.</li> </ul> <p>Value After Reset: 0x0</p> |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | Exists: Always<br>Volatile: True                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0    | HAC  | R/W1C  | <p>Halt complete interrupt</p> <p>This status bit is asserted (only if CQISE.HAC_STE=1) when halt bit in the CQCTL register transitions from 0 to 1 indicating that the host controller has completed its current ongoing task and has entered halt state. A value of 1 clears this status bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (SET): HAC interrupt is set.</li> <li>■ 0x0 (NOTSET): HAC interrupt is not set.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always<br/>Volatile: True</p> |

### 3.6.3.6 CQISE

- Name: Command Queuing Interrupt Status Enable Register
- Description: This register enables and disables the reporting of the corresponding interrupt to host software in the CQIS register. When a bit is set (1) and the corresponding interrupt condition is active, then the bit in CQIS is asserted. Interrupt sources that are disabled (when '0') are not indicated in the CQIS register. This register is bit-index matched to the CQIS register.
- Size: 32 bits
- Offset: 0x180 + 0x14

Figure & Table 3-98 Fields for register: CQISE

| Bits | Name         | Access | Description                                                                                                                                                                                                                                          |
|------|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | CQISTE_RSVD1 | R      | <p>These bits of the CQISE register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                      |
| 5    | Reserved     | R      |                                                                                                                                                                                                                                                      |
| 4    | Reserved     | R      |                                                                                                                                                                                                                                                      |
| 3    | TCL_STE      | R/W    | <p>Task cleared interrupt status enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (INT_STS_ENABLE): CQIS.TCL is set when its interrupt condition is active.</li> <li>■ 0x0 (INT_STS_DISABLE): CQIS.TCL is disabled.</li> </ul> |

| Bits | Name    | Access | Description                                                                                                                                                                                                                                                                                      |
|------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |         |        | Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                         |
| 2    | RED_STE | R/W    | Response error detected interrupt status enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x1 (INT_STS_ENABLE): CQIS.RED is set when its interrupt condition is active.</li> <li>■ 0x0 (INT_STS_DISABLE): CQIS.RED is disabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 1    | TCC_STE | R/W    | Task complete interrupt status enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x1 (INT_STS_ENABLE): CQIS.TCC is set when its interrupt condition is active.</li> <li>■ 0x0 (INT_STS_DISABLE): CQIS.TCC is disabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always           |
| 0    | HAC_STE | R/W    | Halt complete interrupt status enable<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x1 (INT_STS_ENABLE): CQIS.HAC is set when its interrupt condition is active.</li> <li>■ 0x0 (INT_STS_DISABLE): CQIS.HAC is disabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always           |

### 3.6.3.7 CQISGE

- Name: Command Queuing Interrupt Signal Enable Register
- Description: This register enables and disables the generation of interrupts to host software. When a bit is set and the corresponding bit in CQIS is set, then an interrupt is generated. Interrupt sources that are disabled are still indicated in the CQIS register. This register is bit-index matched to the CQIS register.
- Size: 32
- Offset: 0x180 + 0x18bits

Figure & Table 3-99 Fields for register: CQISGE

| Bits | Name         | Access | Description                                                           |
|------|--------------|--------|-----------------------------------------------------------------------|
| 31:6 | CQISGE_RSVD1 | R      | These bits of the CQISGE register are reserved. They always return 0. |



| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                          |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                  |
| 5    | Reserved | R      |                                                                                                                                                                                                                                                                                                                                      |
| 4    | Reserved | R      |                                                                                                                                                                                                                                                                                                                                      |
| 3    | TCL_SGE  | R/W    | <p>Task cleared interrupt signal enable</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (INT_SIG_ENABLE): CQIS.TCL interrupt signal generation is active.</li><li>■ 0x0 (INT_SIG_DISABLE): CQIS.TCL interrupt signal generation is disabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>            |
| 2    | RED_SGE  | R/W    | <p>Response error detected interrupt signal enable</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (INT_SIG_ENABLE): CQIS.RED interrupt signal generation is active.</li><li>■ 0x0 (INT_SIG_DISABLE): CQIS.RED interrupt signal generation is disabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 1    | TCC_SGE  | R/W    | <p>Task complete interrupt signal enable</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (INT_SIG_ENABLE): CQIS.TCC interrupt signal generation is active.</li><li>■ 0x0 (INT_SIG_DISABLE): CQIS.TCC interrupt signal generation is disabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>           |
| 0    | HAC_SGE  | R/W    | <p>Halt complete interrupt signal enable</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (INT_SIG_ENABLE): CQIS.HAC interrupt signal generation is active.</li><li>■ 0x0 (INT_SIG_DISABLE): CQIS.HAC interrupt signal generation is disabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>           |

### 3.6.3.8 CQIC

- Name: Command Queuing Interrupt Coalescing Register
- Description: This register controls and configures interrupt coalescing feature.
- Size: 32 bits
- Offset: 0x180 + 0x1c

Figure & Table 3-100 Fields for register: CQIC

| Bits  | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | INTC_EN    | R/W    | <p>Interrupt Coalescing Enable Bit</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE_INT_COALESCING): Interrupt coalescing mechanism is active. Interrupts are counted and timed, and coalesced interrupts are generated.</li> <li>■ 0x0 (DISABLE_INT_COALESCING): Interrupt coalescing mechanism is disabled (default).</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                           |
| 30:21 | CQIC_RSVD3 | R      | <p>These bits (CQIC_RSVD3) of the CQIC register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 20    | INTC_STAT  | R      | <p>Interrupt Coalescing Status Bit</p> <p>This bit indicates to the software whether any tasks (with INT=0) have completed and counted towards interrupt coalescing (that is, this is set if and only if INTC counter &gt; 0).</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (INTC_ATLEAST1_COMP): At least one INT0 task completion has been counted (INTC counter &gt; 0).</li> <li>■ 0x0 (INTC_NO_TASK_COMP): INT0 Task completions have not occurred since last counter reset (INTC counter == 0).</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 19:17 | CQIC_RSVD2 | R      | <p>These bits (CQIC_RSVD2) of the CQIC register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bits  | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | INTC_RST    | W      | <p>Counter and Timer Reset</p> <p>When host driver writes 1, the interrupt coalescing timer and counter are reset.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (ASSERT_INTC_RESET): Interrupt coalescing timer and counter are reset.</li> <li>■ 0x0 (NO_EFFECT): No effect</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15    | INTC_TH_WEN | W      | <p>Interrupt Coalescing Counter Threshold Write Enable</p> <p>When software writes 1 to this bit, the value INTC_TH is updated with the contents written on the same cycle.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (WEN_SET): Sets INTC_TH_WEN.</li> <li>■ 0x0 (WEN_CLR): Clears INTC_TH_WEN.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14:13 | CQIC_RSVD1  | R      | <p>These bits (CQIC_RSVD1) of the CQIC register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12:8  | INTC_TH     | W      | <p>Interrupt Coalescing Counter Threshold field</p> <p>Software uses this field to configure the number of task completions (only tasks with INT=0 in the task descriptor), which are required in order to generate an interrupt.</p> <p>Counter Operation: As data transfer tasks with INT=0 complete, they are counted by CQE. The counter is reset by software during the interrupt service routine. The counter stops counting when it reaches the value configured in INTC_TH, and generates interrupt.</p> <ul style="list-style-type: none"> <li>■ 0x0: Interrupt coalescing feature disabled.</li> <li>■ 0x1: Interrupt coalescing interrupt generated after 1 task when INT=0 completes.</li> <li>■ 0x2: Interrupt coalescing interrupt generated after 2 tasks when INT=0 completes.</li> <li>■ .....</li> <li>■ 0x1f: Interrupt coalescing interrupt generated after</li> </ul> |

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>31 tasks when INT=0 completes.</p> <p>To write to this field, the INTC_TH_WEN bit must be set during the same write operation.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Testable: Untestable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7    | TOUT_VAL_WEN | W      | <p>When software writes 1 to this bit, the value TOUT_VAL is updated with the contents written on the same cycle.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (WEN_SET): Sets TOUT_VAL_WEN.</li> <li>■ 0x0 (WEN_CLR): Clears TOUT_VAL_WEN.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6:0  | TOUT_VAL     | R/W    | <p>Interrupt Coalescing Timeout Value</p> <p>Software uses this field to configure the maximum time allowed between the completion of a task on the bus and the generation of an interrupt.</p> <p>Timer Operation: The timer is reset by software during the interrupt service routine. It starts running when the first data transfer task with INT=0 is completed, after the timer was reset. When the timer reaches the value configured in ICTOVAL field, it generates an interrupt and stops.</p> <p>The timer's unit is equal to 1024 clock periods of the clock whose frequency is specified in the Internal Timer Clock Frequency field CQCAP register.</p> <ul style="list-style-type: none"> <li>■ 0x0: Timer is disabled. Timeout-based interrupt is not generated.</li> <li>■ 0x1: Timeout on 01x1024 cycles of timer clock frequency.</li> <li>■ 0x2: Timeout on 02x1024 cycles of timer clock frequency.</li> <li>■ .....</li> <li>■ 0x7f: Timeout on 127x1024 cycles of timer clock frequency.</li> </ul> <p>In order to write to this field, the TOUT_VAL_WEN bit must be set at the same write operation.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

| Bits | Name | Access | Description          |
|------|------|--------|----------------------|
|      |      |        | Testable: Untestable |

### 3.6.3.9 CQTDLBA

- Name: Command Queuing Task Descriptor List Base Address Register
- Description: This register is used for configuring the lower 32 bits of the byte address of the head of the task descriptor list in the host memory.
- Size: 32 bits
- Offset: 0x180 + 0x20

Figure & Table 3-101 Fields for register: CQTDLBA

| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TDLBA | R/W    | <p>This register stores the LSB bits (31:0) of the byte address of the head of the task descriptor list in system memory.</p> <p>The size of the task descriptor list is 32 * (Task Descriptor size + Transfer Descriptor size) as configured by the host driver. This address is set on 1KB boundary. The lower 10 bits of this register are set to 0 by the software and are ignored by CQE.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.3.10 CQTDLBAU

- Name: Command Queuing Task Descriptor List Base Address Upper Register
- Description: This register is used for configuring the upper 32 bits of the byte address of the head of the task descriptor list in the host memory.
- Size: 32 bits
- Offset: 0x180 + 0x24

Figure &amp; Table 3-102 Fields for register: CQTDLBAU

| Bits | Name   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TDLBAU | R/W    | <p>This register stores the MSB bits (63:32) of the byte address of the head of the task descriptor list in system memory.</p> <p>The size of the task descriptor list is 32 * (Task Descriptor size + Transfer Descriptor size) as configured by Host driver. This address is set on 1KB boundary. The lower 10 bits of this register are set to 0 by the software and are ignored by CQE. This register is reserved when using 32-bit addressing mode.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.3.11 CQTDBR

- Name: Command Queuing DoorBell Register
- Description: Using this register, software triggers CQE to process a new task.
- Size: 32 bits
- Offset: 0x180 + 0x28

Figure &amp; Table 3-103 Fields for register: CQTDBR

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DBR  | R/W    | <p>The software configures TDLBA and TDLBAU, and enable CQE in CQCFG before using this register.</p> <p>Writing 1 to bit n of this register triggers CQE to start processing the task encoded in slot n of the TDL. Writing 0 by the software does not have any impact on the hardware, and does not change the value of the register bit.</p> <p>CQE always processes tasks according to the order submitted to the list by CQTDBR write transactions. CQE processes data transfer tasks by reading the task descriptor and sending QUEUED_TASK_PARAMS (CMD44) and QUEUED_TASK_ADDRESS (CMD45) commands to the device. CQE processes DCMD tasks (in slot #31, when enabled) by reading the task descriptor, and generating the command encoded by its index and argument.</p> <p>The corresponding bit is cleared to 0 by CQE in one of the following events:</p> <ul style="list-style-type: none"> <li>■ A task execution is completed (with success or</li> </ul> |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>error).</p> <ul style="list-style-type: none"> <li>■ The task is cleared using CQTCLR register.</li> <li>■ All tasks are cleared using CQCTL register.</li> <li>■ CQE is disabled using CQCFG register.</li> </ul> <p>Software may initiate multiple tasks at the same time (batch submission) by writing 1 to multiple bits of this register in the same transaction. In the case of batch submission, CQE processes the tasks in order of the task index, starting with the lowest index. If one or more tasks in the batch are marked with QBR, the ordering of execution is based on said processing order.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.3.12 CQTCN

- Name: Command Queuing Task Clear Notification Register
- Description: This register is used by CQE to notify software about completed tasks.
- Size: 32 bits
- Offset: 0x180 + 0x2c

Figure & Table 3-104 Fields for register: CQTCN

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TCN  | R/W1C  | <p>Task Completion Notification</p> <p>Each of the 32 bits are bit mapped to the 32 tasks.</p> <ul style="list-style-type: none"> <li>■ Bit-N(1): Task-N has completed execution (with success or errors).</li> <li>■ Bit-N(0): Task-N has not completed, could be pending or not submitted.</li> </ul> <p>On task completion, software may read this register to know tasks that have completed. After reading this register, software may clear the relevant bit fields by writing 1 to the corresponding bits.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.3.13 CQDQS

- Name: Device Queue Status Register
- Description: This register stores the most recent value of the device's queue status.
- Size: 32 bits
- Offset: 0x180 + 0x30

Figure &amp; Table 3-105 Fields for register: CQDQS

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DQS  | R      | <p>Device Queue Status</p> <p>Each of the 32 bits are bit mapped to the 32 tasks.</p> <ul style="list-style-type: none"> <li>■ Bit-N (1): Device has marked task N as ready for execution.</li> <li>■ Bit-N (0): Task-N is not ready for execution. This task could be pending in device or not submitted.</li> </ul> <p>Host controller updates this register with response of the Device Queue Status command.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.3.14 CQDPT

- Name: Device Pending Tasks Register
- Description: This register maintains the list of tasks that are queued into device and are awaiting execution completion.
- Size: 32 bits
- Offset: 0x180 + 0x34

Figure &amp; Table 3-106 Fields for register: CQDPT

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DPT  | R      | <p>Device-Pending Tasks</p> <p>Each of the 32 bits are bit mapped to the 32 tasks.</p> <ul style="list-style-type: none"> <li>■ Bit-N (1): Task-N has been successfully queued into the device and is awaiting execution.</li> <li>■ Bit-N (0): Task-N is not yet queued.</li> </ul> <p>Bit n of this register is set if and only if <b>QUEUED_TASK_PARAMS</b> (CMD44) and <b>QUEUED_TASK_ADDRESS</b> (CMD45) were sent for this specific task and if this task has not been executed.</p> <p>The controller sets this bit after receiving a successful response for CMD45. CQE clears this bit after the task has completed execution.</p> |



| Bits | Name | Access | Description                                                                                                                                                             |
|------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>Software reads this register in the task-discard procedure to determine if the task is queued in the device.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.3.15 CQTCLR

- Name: Command Queuing DoorBell Register
- Description: This register is used for removing an outstanding task in the CQE. The register must be used only when CQE is in halt state.
- Size: 32 bits
- Offset: 0x180 + 0x38

Figure & Table 3-107 Fields for register: CQTCLR

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TCLR | R/W    | <p>Writing 1 to bit n of this register orders CQE to clear a task that the software has previously issued.</p> <p>This bit can only be written when CQE is in halt state as indicated in CQCFG register halt bit. When software writes 1 to a bit in this register, CQE updates the value to 1, and starts clearing the data structures related to the task. CQE clears the bit fields (sets a value of 0) in CQTCLR and in CQTDBR once the clear operation is complete. Software must poll on the CQTCLR until it is cleared to verify that a clear operation was done.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

### 3.6.3.16 CQSSC1

- Name: CQ Send Status Configuration 1 Register
- Description: This register is used for removing an outstanding task in the CQE. The register controls when SEND\_QUEUE\_STATUS commands are sent.
- Size: 32 bits
- Offset: 0x180 + 0x40

Figure & Table 3-108 Fields for register: CQSSC1

| Bits  | Name       | Access | Description                                                           |
|-------|------------|--------|-----------------------------------------------------------------------|
| 31:20 | RSVD_20_31 | R      | These bits of the CQSSC1 register are reserved. They always return 0. |



| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 19:16 | SQSCMD_BLK_CNT  | R/W    | <p>This field indicates when SQS CMD is sent while data transfer is in progress.</p> <p>A value of 'n' indicates that CQE sends status command on the CMD line, during the transfer of data block BLOCK_CNTn, on the data lines, where BLOCK_CNT is the number of blocks in the current transaction.</p> <ul style="list-style-type: none"><li>■ 0x0: SEND_QUEUE_STATUS (CMD13) command is not sent during the transaction. Instead, it is sent only when the data lines are idle.</li><li>■ 0x1: SEND_QUEUE_STATUS command is to be sent during the last block of the transaction.</li><li>■ 0x2: SEND_QUEUE_STATUS command when last 2 blocks are pending.</li><li>■ 0x3: SEND_QUEUE_STATUS command when last 3 blocks are pending.</li><li>■ .....</li><li>■ 0xf: SEND_QUEUE_STATUS command when last 15 blocks are pending.</li></ul> <p>Should be programmed only when CQCFG.CQ_EN is 0.</p> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> |
| 15:0  | SQSCMD_IDLE_TMR | R/W    | <p>This field configures the polling period to be used when using periodic SEND_QUEUE_STATUS (CMD13) polling.</p> <p>Periodic polling is used when tasks are pending in the device, but no data transfer is in progress. When a SEND_QUEUE_STATUS response indicates that no task is ready for execution, CQE counts the configured time until it issues the next SEND_QUEUE_STATUS.</p> <p>Timer units are clock periods of the clock whose frequency is specified in the Internal Timer Clock Frequency field CQCAP register. The minimum value is 0001h (1 clock period) and the maximum value is FFFFh (65535 clock periods).</p> <p>For example, a CQCAP field value of 0 indicates a 19.2MHz clock frequency (period = 52.08ns). If the setting in CQSS1.CIT is 1000h, the calculated polling period is <math>4096 \times 52.08\text{ns} = 213.33\text{ns}</math>.</p> <p>Should be programmed only when CQCFG.CQ_EN is 0.</p>                  |

| Bits | Name | Access | Description                                 |
|------|------|--------|---------------------------------------------|
|      |      |        | Value After Reset: 0x1000<br>Exists: Always |

### 3.6.3.17 CQSSC2

- Name: CQ Send Status Configuration 2 Register
- Description: The register is used for configuring the RCA field in SEND\_QUEUE\_STATUS command argument.
- Size: 32 bits
- Offset: 0x180 + 0x44

Figure &amp; Table 3-109 Fields for register: CQSSC2

| Bits  | Name       | Access | Description                                                                                                                                                                                                                                                               |
|-------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RSVD_16_31 | R      | These bits of the CQSSC2 register are reserved. They always return 0.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                         |
| 15:0  | SQSCMD_RCA | R/W    | This field provides CQE with the contents of the 16-bit RCA field in SEND_QUEUE_STATUS (CMD13) command argument.<br>CQE copies this field to bits[31:16] of the argument when transmitting SEND_QUEUE_STATUS (CMD13) command.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.3.18 CQCRDCT

- Name: Command Response for Direct Command Register
- Description: This register stores the response of last executed DCMD.
- Size: 32 bits
- Offset: 0x180 + 0x48

Figure &amp; Table 3-110 Fields for register: CQCRDCT

| Bits | Name      | Access | Description                                                                                                                                                                                                                                            |
|------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DCMD_RESP | R      | This register contains the response of the command generated by the last direct command (DCMD) task that was sent.<br>Contents of this register are valid only after bit 31 of CQTDBR register is cleared by the controller.<br>Value After Reset: 0x0 |

| Bits | Name | Access | Description    |
|------|------|--------|----------------|
|      |      |        | Exists: Always |

### 3.6.3.19 CQRMEM

- Name: Command Response Mode Error Mask Register
- Description: This register controls the generation of response error detect (RED) interrupt. Only the bits enabled here can contribute to RED.
- Size: 32 bits
- Offset: 0x180 + 0x50

Figure &amp; Table 3-111 Fields for register: CQRMEM

| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RESP_ERR_MASK | R/W    | <p>The bits of this field are bit mapped to the device response. This bit is used as an interrupt mask on the device status filed that is received in R1/R1b responses.</p> <ul style="list-style-type: none"> <li>■ 1: When a R1/R1b response is received, with a bit <i>i</i> in the device status set, a RED interrupt is generated.</li> <li>■ 0: When a R1/R1b response is received, bit <i>i</i> in the device status is ignored.</li> </ul> <p>The reset value of this register is set to trigger an interrupt on all "Error" type bits in the device status.</p> <p>Note: Responses to CMD13 (SQS) encode the QSR so that they are ignored by this logic.</p> <p>Value After Reset: 0xfd9a080</p> <p>Exists: Always</p> |

### 3.6.3.20 CQTERRI

- Name: CQ Task Error Information Register
- Description: This register is updated by CQE when an error occurs on data or command related to a task activity. When such an error is detected by CQE or indicated by the eMMC controller, CQE stores the following in the CQTERRI register: task IDs and indices of commands that were executed on the command line and data lines when the error occurred. Software must use this information in the error recovery procedure.
- Size: 32 bits
- Offset: 0x180 + 0x54

Figure &amp; Table 3-112 Fields for register: CQTERRI

| Bits | Name                   | Access | Description                                           |
|------|------------------------|--------|-------------------------------------------------------|
| 31   | TRANS_ERR_FIELDS_VALID | R      | This bit is updated when an error is detected while a |



| Bits  | Name                  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                       |        | <p>data transfer transaction was in progress.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (SET): Data transfer related error detected. Check contents of TRANS_ERR_TASKID and TRANS_ERR_CMD_INDX fields.</li><li>■ 0x0 (NOT_SET): Ignore contents of TRANS_ERR_TASKID and TRANS_ERR_CMD_INDX.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                           |
| 30:29 | RSVD_30_29            | R      | <p>These bits (RSVD_30_29) of the CQTERRI register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                           |
| 28:24 | TRANS_ERR_TASKID      | R      | <p>This field captures the ID of the task that was executed and whose data transfer has errors.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                  |
| 23:22 | RSVD_23_22            | R      | <p>These bits (RSVD_23_22) of the CQTERRI register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                           |
| 21:16 | TRANS_ERR_CMD_INDX    | R      | <p>This field captures the index of the command that was executed and whose data transfer has errors.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                            |
| 15    | RESP_ERR_FIELDS_VALID | R      | <p>This bit is updated when an error is detected while a command transaction was in progress.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (SET): Response-related error is detected. Check contents of RESP_ERR_TASKID and RESP_ERR_CMD_INDX fields.</li><li>■ 0x0 (NOT_SET): Ignore contents of RESP_ERR_TASKID and RESP_ERR_CMD_INDX.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 14:13 | RSVD_13_14            | R      | <p>These bits (RSVD_13_14) of the CQTERRI register are reserved. They always return 0.</p>                                                                                                                                                                                                                                                                                                                               |



| Bits | Name              | Access | Description                                                                                                                                             |
|------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                   |        | Value After Reset: 0x0<br>Exists: Always                                                                                                                |
| 12:8 | RESP_ERR_TASKID   | R      | This field captures the ID of the task which was executed on the command line when the error occurred.<br>Value After Reset: 0x0<br>Exists: Always      |
| 7:6  | RSVD_6_7          | R      | These bits (RSVD_6_7) of the CQTERRI register are reserved. They always return 0.<br>Value After Reset: 0x0<br>Exists: Always                           |
| 5:0  | RESP_ERR_CMD_INDX | R      | This field captures the index of the command that was executed on the command line when the error occurred.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.3.21 CQCRI

- Name: CQ Command Response Index
- Description: This register stores the index of the last received command response.
- Size: 32 bits
- Offset: 0x180 + 0x58

Figure & Table 3-113 Fields for register: CQCRI

| Bits | Name          | Access | Description                                                                                                                                                                                                           |
|------|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RSVD_31_6     | R      | These bits of the CQCRI register are reserved. They always return 0.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                      |
| 5:0  | CMD_RESP_INDX | R      | Last Command Response index<br>This field stores the index of the last received command response. Controller updates the value every time a command response is received.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.3.22 CQCRA

- Name: CQ Command Response Argument Register
- Description: This register stores the argument of the last received command response.
- Size: 32 bits
- Offset: 0x180 + 0x5c

Figure & Table 3-114 Fields for register: CQCRA

| Bits | Name         | Access | Description                                                                                                                                                                                                                                    |
|------|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | CMD_RESP_ARG | R      | <p>Last Command Response argument</p> <p>This field stores the argument of the last received command response. Controller updates the value every time a command response is received.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

## 3.6.4 DWC\_mshc\_map/DWC\_mshc\_phy\_block Registers

### 3.6.4.1 PHY\_CNFG

- Name: SD/eMMC PHY General Configuration
- Description: SD/eMMC PHY general configuration register
- Size: 32 bits
- Offset: 0x300 + 0x0

Figure & Table 3-115 Fields for register: PHY\_CNFG

| Bits  | Name        | Access | Description                                                                                                                           |
|-------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 |             |        | Reserved Field: Yes                                                                                                                   |
| 23:20 | PAD_SN      | R/W    | <p>NMOS TX drive strength control. Common configuration for all SD/eMMC PADs.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 19:16 | PAD_SP      | R/W    | <p>PMOS TX drive strength control. Common configuration for all SD/eMMC PADs.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 15:2  |             |        | Reserved Field: Yes                                                                                                                   |
| 1     | PHY_PWRGOOD | R      | <p>Phy's Power Good status is captured here. Ensure this is 1 before stating transactions.</p> <p>Value After Reset: 0x0</p>          |

| Bits | Name     | Access | Description                                                                                                                    |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------|
|      |          |        | Exists: Always<br>Reset Mask: 0x0                                                                                              |
| 0    | PHY_RSTN | R/W    | Active-Low reset control for PHY, write 0 to reset PHY, Write 1 to deassert reset.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.2 CMDPAD\_CNFG

- Name: SD/eMMC PHY CMD/RESP PAD Setting
- Description: SD/eMMC PHY's command/response PAD settings are controlled here.
- Size: 16 bits
- Offset: 0x300 + 0x4

Figure & Table 3-116 Fields for register: CMDPAD\_CNFG

| Bits  | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                   |
|-------|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13 |               |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                                                           |
| 12:9  | TXSLEW_CTRL_N | R/W    | Slew control for N-Type CMD PAD's TX<br>Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                                                                              |
| 8:5   | TXSLEW_CTRL_P | R/W    | Slew control for P-Type CMD PAD's TX<br>Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                                                                              |
| 4:3   | WEAKPULL_EN   | R/W    | Pull-up/Pull-down enable control for CMD PAD<br>Values: <ul style="list-style-type: none"><li>■ 0x0 (DISABLED): Pull-up and pull-down functionality disabled.</li><li>■ 0x1 (PULLUP): Weak pull up enabled.</li><li>■ 0x2 (PULLDOWN): Weak pull down enabled.</li><li>■ 0x3 (ILLEGAL): Should not be used.</li></ul> Value After Reset: 0x0<br>Exists: Always |
| 2:0   | RXSEL         | R/W    | Receiver type select for PAD. Controls the RXSEL value of SD/eMMC PHY CMD PAD.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                    |

### 3.6.4.3 DATPAD\_CNFG

- Name: SD/eMMC PHY Data PAD Setting
- Description: SD/eMMC PHY's data PAD settings are controlled here. Common settings for all data PADS
- Size: 16 bits
- Offset: 0x300 + 0x6

Figure & Table 3-117 Fields for register: DATPAD\_CNFG

| Bits  | Name          | Access | Description                                                                                                                                                                                                                                                                                            |
|-------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13 |               |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                    |
| 12:9  | TXSLEW_CTRL_N | R/W    | Slew control for N-Type DATA PAD's TX<br>Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                      |
| 8:5   | TXSLEW_CTRL_P | R/W    | Slew control for P-Type DATA PAD's TX<br>Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                      |
| 4:3   | WEAKPULL_EN   | R/W    | Pull-up/Pull-down enable control for DATA PADS<br>Values:<br>■ 0x0 (DISABLED): Pull-up and pull-down functionality disabled.<br>■ 0x1 (PULLUP): Weak pull up enabled.<br>■ 0x2 (PULLDOWN): Weak pull down enabled.<br>■ 0x3 (ILLEGAL): Should not be used.<br>Value After Reset: 0x0<br>Exists: Always |
| 2:0   | RXSEL         | R/W    | Receiver type select for PAD. Controls the RXSEL value of SD/eMMC PHY data PADS.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                           |

### 3.6.4.4 CLKPAD\_CNFG

- Name: SD/eMMC PHY Clock PAD Setting
- Description: SD/eMMC PHY's clock PAD settings are controlled here.
- Size: 16 bits
- Offset: 0x300 + 0x8

Figure &amp; Table 3-118 Fields for register: CLKPAD\_CNFG

| Bits  | Name          | Access | Description                                                                                                                                                                                                                                                                                            |
|-------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13 |               |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                    |
| 12:9  | TXSLEW_CTRL_N | R/W    | Slew control for N-Type CLK PAD's TX<br>Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                       |
| 8:5   | TXSLEW_CTRL_P | R/W    | Slew control for P-Type CLK PAD's TX<br>Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                       |
| 4:3   | WEAKPULL_EN   | R/W    | Pull-up/Pull-down enable control for clock PAD<br>Values:<br>■ 0x0 (DISABLED): Pull-up and pull-down functionality disabled.<br>■ 0x1 (PULLUP): Weak pull up enabled.<br>■ 0x2 (PULLDOWN): Weak pull down enabled.<br>■ 0x3 (ILLEGAL): Should not be used.<br>Value After Reset: 0x0<br>Exists: Always |
| 2:0   | RXSEL         | R/W    | Receiver type select for PAD. Controls the RXSEL value of SD/eMMC PHY clock PAD.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                           |

### 3.6.4.5 STB PAD CNFG

- Name: SD/eMMC PHY Strobe PAD Setting
- Description: SD/eMMC PHY's strobe PAD settings are controlled here.
- Size: 16 bits
- Offset: 0x300 + 0xA

Figure &amp; Table 3-119 Fields for register: STB PAD CNFG

| Bits  | Name          | Access | Description                                                                         |
|-------|---------------|--------|-------------------------------------------------------------------------------------|
| 15:13 |               |        | Reserved Field: Yes                                                                 |
| 12:9  | TXSLEW_CTRL_N | R/W    | Slew control for N-Type Strobe PAD's TX<br>Value After Reset: 0x2<br>Exists: Always |
| 8:5   | TXSLEW_CTRL_P | R/W    | Slew control for P-Type Strobe PAD's TX                                             |

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             |        | <p>Value After Reset: 0x2</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                         |
| 4:3  | WEAKPULL_EN | R/W    | <p>Pull-up/Pull-down enable control for strobe PAD</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (DISABLED): Pull-up and pull-down functionality disabled.</li> <li>■ 0x1 (PULLUP): Weak pull up enabled.</li> <li>■ 0x2 (PULLDOWN): Weak pull down enabled.</li> <li>■ 0x3 (ILLEGAL): Should not be used.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 2:0  | RXSEL       | R/W    | <p>Receiver type select for PAD. Controls the RXSEL value of SD/eMMC PHY strobe PAD.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                |

### 3.6.4.6 RSTNPAD\_CNFG

- Name: SD/eMMC PHY RSTN PAD Setting
- Description: SD/eMMC PHY's RSTN PAD settings are controlled here.
- Size: 16 bits
- Offset: 0x300 + 0xC

Figure & Table 3-120 Fields for register: RSTNPAD\_CNFG

| Bits  | Name          | Access | Description                                                                                                                                                                                                                              |
|-------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13 |               |        | Reserved Field: Yes                                                                                                                                                                                                                      |
| 12:9  | TXSLEW_CTRL_N | R/W    | <p>Slew control for N-Type RST_N PAD's TX</p> <p>Value After Reset: 0x2</p> <p>Exists: Always</p>                                                                                                                                        |
| 8:5   | TXSLEW_CTRL_P | R/W    | <p>Slew control for P-Type RST_N PAD's TX</p> <p>Value After Reset: 0x2</p> <p>Exists: Always</p>                                                                                                                                        |
| 4:3   | WEAKPULL_EN   | R/W    | <p>Pull-up/Pull-down enable control for RST_N PAD(s)</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (DISABLED): Pull-up and pull-down functionality disabled.</li> <li>■ 0x1 (PULLUP): Weak pull up enabled.</li> </ul> |

| Bits | Name  | Access | Description                                                                                                                                                                        |
|------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | <ul style="list-style-type: none"> <li>■ 0x2 (PULLDOWN): Weak pull down enabled.</li> <li>■ 0x3 (ILLEGAL): Should not be used.</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 2:0  | RXSEL | R/W    | Receiver type select for PAD. Controls the RXSEL value of SD/eMMC PHY RST_N PAD(s).<br>Value After Reset: 0x0<br>Exists: Always                                                    |

### 3.6.4.7 PADTEST\_CNFG

- Name: SD/eMMC PHY PAD Test Interface Setting
- Description: PAD test path and direction control
- Size: 16 bits
- Offset: 0x300 + 0xE

Figure & Table 3-121 Fields for register: PADTEST\_CNFG

| Bits  | Name        | Access | Description                                                                                                                                                                                                                                                                                                      |
|-------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:10 |             |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                              |
| 9:4   | TEST_OE     | R/W    | Test interface OE control. Drive's PHY's itest_oe inputs.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                            |
| 3:1   | RSVD_1      | R      | RSVD1 field is reserved.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                             |
| 0     | TESTMODE_EN | R/W    | Enables test mode interface for all PADS. Functional interface is disabled.<br>Values: <ul style="list-style-type: none"> <li>■ 0x0 (PAD_FUNCMODE): PAD's functional mode I/F is active.</li> <li>■ 0x1 (PAD_TESTMODE): PAD's test mode interface is active.</li> </ul> Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.8 PADTEST\_OUT

- Name: SD/eMMC PHY PAD Test Data out Value

- Description: PAD test path data out, drives itest\_a input of SD/eMMC PHY.
- Size: 16 bits
- Offset: 0x300 + 0x10

Figure &amp; Table 3-122 Fields for register: PADTEST\_OUT

| Bits | Name         | Access | Description                                                                                                                                                                                |
|------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:6 |              |        | Reserved Field: Yes                                                                                                                                                                        |
| 5:0  | TESTDATA_OUT | R/W    | <p>Data written here is reflected on corresponding itest_a. Individual bits are mapped to corresponding itest_a inputs of the PHY.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.4.9 PADTEST\_IN

- Name: SD/eMMC PHY PAD Test Data In Value
- Description: PAD test path data in, reflects value of otest\_y output of SD/eMMC PHY.
- Size: 16 bits
- Offset: 0x300 + 0x12

Figure &amp; Table 3-123 Fields for register: PADTEST\_IN

| Bits | Name        | Access | Description                                                                                                                                                                                         |
|------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:6 |             |        | Reserved Field: Yes                                                                                                                                                                                 |
| 5:0  | TESTDATA_IN | R      | <p>Individual bits here capture data available on corresponding otest_y output. Should be used for DC test and low frequency data patterns.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.4.10 PRBS\_CNFG

- Name: Controller PRBS Configuration Register
- Description: Register to configure PRBS engine
- Size: 16 bits
- Offset: 0x300 + 0x18

Figure &amp; Table 3-124 Fields for register: PRBS\_CNFG

| Bits | Name      | Access | Description                                                                                                          |
|------|-----------|--------|----------------------------------------------------------------------------------------------------------------------|
| 15:0 | INIT_SEED | R/W    | <p>Value programmed here is used as SEED for PRBS engine.</p> <p>Value After Reset: 0xffff</p> <p>Exists: Always</p> |



### 3.6.4.11 PHYLPBK\_CNFG

- Name: Loopback Configuration Register
- Description: Register to setup loopback mode
- Size: 8 bits
- Offset: 0x300 + 0x1A

Figure &amp; Table 3-125 Fields for register: PHYLPBK\_CNFG

| Bits | Name                | Access | Description                                                                                                                                                                                                                                                                                                                |
|------|---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:2  |                     |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                        |
| 1    | OUT_EN_PHYLPBK_MODE | R/W    | <p>CMD/DATA output enable in PHY loopback mode</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (OUTPUT_EN): CMD/DATA output is enabled in PHY loopback mode.</li> <li>■ 0x0 (OUTPUT_DIS): CMD/DATA output is disabled in PHY loopback mode.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 0    | PHYLPBK_EN          | R/W    | <p>PHY local loopback mode enable</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (PHYLPBK_MODE_EN): Controller is now in PHY loopback mode.</li> <li>■ 0x0 (PHYLPBK_MODE_DIS): Controller is not in PHY loopback mode.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                     |

### 3.6.4.12 COMMDL\_CNFG

- Name: Common DelayLine Configuration Settings Register
- Description: Configuration register to settings common to all DelayLines used in PHY
- Size: 8 bits
- Offset: 0x300 + 0x1C

Figure &amp; Table 3-126 Fields for register: COMMDL\_CNFG

| Bits | Name     | Access | Description                                                                                      |
|------|----------|--------|--------------------------------------------------------------------------------------------------|
| 7:2  |          |        | Reserved Field: Yes                                                                              |
| 1    | DLOUT_EN | R/W    | <p>When '1' DL outputs can be sampled on PADs. Drives idlout_en for all PADs.</p> <p>Values:</p> |

| Bits | Name       | Access | Description                                                                                                                                                                                                   |
|------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |        | <ul style="list-style-type: none"> <li>■ 0x1 (DL_OUTEN): DelayLine outputs on PAD enabled.</li> <li>■ 0x0 (DL_OUTDIS): DelayLine outputs on PAD disabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 0    | DLSTEP_SEL | R/W    | DelayLine's per step delay selection. Drives PHY's idl_step input.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                |

### 3.6.4.13 SDCLKDL\_CNFG

- Name: SD/eMMC DelayLine Settings
- Description: Settings for SD/eMMC clock DelayLine
- Size: 8 bits
- Offset: 0x300 + 0x1D

Figure & Table 3-127 Fields for register: SDCLKDL\_CNFG

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5  |             |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4    | UPDATE_DC   | R/W    | Prepares DelayLine for code update when '1'. It's recommended that this bit is 1 when SDCLKDL_DC is being written. Ensure this is '0' when not updating code.<br>Note:<br>Turn off card clock using CLK_CTRL_R.SD_CLK_EN before programming this field.<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x1 (BYPASSMODE): Output of DelayLine is DelayLine output active.</li> <li>■ 0x0 (DLMODE): DelayLine output is enabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 3:2  | INPSEL_CNFG | R/W    | Drives SD/eMMC clock DelayLine's configuration input.<br>Value here selects the input source to DelayLine.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                     |

| Bits | Name      | Access | Description                                                                                                                                                                                                                                                                                                      |
|------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | BYPASS_EN | R/W    | <p>Drives SD/eMMC clock DelayLine's bypassen input.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (BYPASSMODE): Delay line is bypass mode.</li> <li>■ 0x0 (DLMODE): Delay line active mode</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                      |
| 0    | EXTDLY_EN | R/W    | <p>Drives SD/eMMC clock DelayLine's extdlyen input.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (EXTDL_MODE): Delay line works with extended delay range setting.</li> <li>■ 0x0 (DEF_MODE): Delay line default range setting</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.4.14 SDCLKDL\_DC

- Name: SD/eMMC DelayLine Delay Code Setting
- Description: SD/eMMC clock DelayLine delay code value
- Size: 8 bits
- Offset: 0x300 + 0x1E

Figure & Table 3-128 Fields for Register: SDCLKDL\_DC

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                               |
|------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    |          |        | Reserved Field: Yes                                                                                                                                                                                                                                                                       |
| 6:0  | CCKDL_DC | R/W    | <p>Drives SD/eMMC CLK DelayLine's Delay Code input.</p> <p>Value here Selects the number of active stages in the card clock delay line.</p> <p>Note: Turn off card clock using CLK_CTRL_R.SD_CLK_EN before programing this field.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.4.15 SMPLDL\_CNFQ

- Name: SD/eMMC cclk\_rx DelayLine Settings
- Description: SD/eMMC cclk\_rx DelayLine configuration settings
- Size: 8 bits
- Offset: 0x300 + 0x20

Figure &amp; Table 3-129 Fields for register: SMPLDL\_CNFG

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5  |                 |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4    | INPSEL_OVERRIDE | R/W    | <p>PHY's Sampling delay line configuration is controlled by controller using sample_cclk_sel, this signal overrides sample_cclk_sel so that INPSEL_CFG field directly controls PHY's configuration input.</p> <ul style="list-style-type: none"> <li>■ 0x0: Controller logic drives sampling delay line configuration.</li> <li>■ 0x1: SMPLDL_CNFG.INPSEL_CNFG drives sampling delay line configuration.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 3:2  | INPSEL_CNFG     | R/W    | <p>Drives CCLK_RX DelayLine's configuration input. Value here selects the input source to DelayLine.</p> <p>Value After Reset: 0x3</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                            |
| 1    | BYPASS_EN       | R/W    | <p>Drives CCLK_RX DelayLine's bypassen input.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (BYPASSMODE): DelayLine is bypass mode.</li> <li>■ 0x0 (DLMODE): Delay line active mode</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p>                                                                                                                                                                                                    |
| 0    | EXTDLY_EN       | R/W    | <p>Drives CCLK_RX DelayLine's extdlyen input</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (EXTDL_MODE): DelayLine works with extended delay range setting.</li> <li>■ 0x0 (DEF_MODE): Delay line default range setting</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                |

### 3.6.4.16 ATDL\_CNFG

- Name: SD/eMMC drift\_cclk\_rx DelayLine Configuration Settings
- Description: SD/eMMC drift\_cclk\_rx DelayLine configuration settings
- Size: 8 bits
- Offset: 0x300 + 0x21

Figure &amp; Table 3-130 Fields for register: ATDL\_CNFG

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                             |
|------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4  |             |        | Reserved Field: Yes                                                                                                                                                                                                                                                                     |
| 3:2  | INPSEL_CNFG | R/W    | Drives drift_cclk_rx DelayLine's configuration input.<br>Value here selects the input source to DelayLine.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                  |
| 1    | BYPASS_EN   | R/W    | Drives drift_cclk_rx DelayLine's bypassen input.<br>Values: <ul style="list-style-type: none"><li>■ 0x1 (BYPASSMODE): Delay line is bypass mode.</li><li>■ 0x0 (DLMODE): Delay line active mode</li></ul> Value After Reset: 0x0<br>Exists: Always                                      |
| 0    | EXTDLY_EN   | R/W    | Drives drift_cclk_rx DelayLine's extdlyen input.<br>Values: <ul style="list-style-type: none"><li>■ 0x1 (EXTDL_MODE): Delay line works with extended delay range setting.</li><li>■ 0x0 (DEF_MODE): Delay line default range setting</li></ul> Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.17 DLL\_CTRL

- Name: SD/eMMC PHY DLL Control Setting
- Description: SD/eMMC PHY's DLL control settings register
- Size: 8 bits
- Offset: 0x300 + 0x24

Figure &amp; Table 3-131 Fields for register: DLL\_CTRL

| Bits | Name            | Access | Description                                                                                                                                                                          |
|------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3  | RSVD_3_7        | R      | These bits of the register are reserved.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                 |
| 2    | SLV_SWDC_UPDATE | R/W    | Corresponding output drives PHY's DLL slave's dc update input. This is used to turn off Slave Delay line's output when changing its delay code using DLL_OFFSET register.<br>Values: |

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                           |
|------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          |        | <ul style="list-style-type: none"> <li>■ 0x1 (DL_OUT_OFF): Update in progress.</li> <li>■ 0x0 (DL_OUT_ON): Update completed.</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                                                                                                                      |
| 1    | OFFST_EN | R/W    | Enables offset mode of PHY when DLL is enabled. When DLL is disabled, this allows direct control of delay generated by DLL's slave.<br>Values: <ul style="list-style-type: none"> <li>■ 0x1 (OFFSTEN): Offset value is valid.</li> <li>■ 0x0 (OFFSTDIS): offset value is invalid.</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 0    | DLL_EN   | R/W    | Enable's DLL when '1'.<br>Values: <ul style="list-style-type: none"> <li>■ 0x1 (DLLENABLE): PHY DLL is enabled.</li> <li>■ 0x0 (DLLDISABLE): PHY DLL is disabled.</li> </ul> Value After Reset: 0x0<br>Exists: Always                                                                                                                 |

### 3.6.4.18 DLL\_CNF1

- Name: DLL Configuration Register 1
- Description: SD/eMMC PHY DLL configuration register 1
- Size: 8 bits
- Offset: 0x300 + 0x25

Figure & Table 3-132 Fields for register: DLL\_CNF1

| Bits | Name      | Access | Description                                                                                                   |
|------|-----------|--------|---------------------------------------------------------------------------------------------------------------|
| 7:6  |           |        | Reserved Field: Yes                                                                                           |
| 5:4  | SLVDLY    | R/W    | Sets the value of DLL slave's update delay input islv_update_dly.<br>Value After Reset: 0x0<br>Exists: Always |
| 3    |           |        | Reserved Field: Yes                                                                                           |
| 2:0  | WAITCYCLE | R/W    | Sets the value of DLL's wait cycle input.<br>Value After Reset: 0x0<br>Exists: Always                         |

### 3.6.4.19 DLL\_CNFG2

- Name: DLL Configuration Register 2
- Description: SD/eMMC PHY DLL configuration register 2
- Size: 8 bits
- Offset: 0x300 + 0x26

Figure & Table 3-133 Fields for register: DLL\_CNFG2

| Bits | Name     | Access | Description                                                                          |
|------|----------|--------|--------------------------------------------------------------------------------------|
| 7    |          |        | Reserved Field: Yes                                                                  |
| 6:0  | JUMPSTEP | R/W    | Sets the value of DLL's jump step input.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.20 DLLDL\_CNFG

- Name: DLL Configuration Register 2
- Description: SD/eMMC PHY DLL master & slave DL configuration settings
- Size: 8 bits
- Offset: 0x300 + 0x28

Figure & Table 3-134 Fields for register: DLLDL\_CNFG

| Bits | Name         | Access | Description                                                                      |
|------|--------------|--------|----------------------------------------------------------------------------------|
| 7    | SLV_BYPASS   | R/W    | Bypass enable control for slave DL<br>Value After Reset: 0x0<br>Exists: Always   |
| 6:5  | SLV_INPSEL   | R/W    | Clock source select for slave DL<br>Value After Reset: 0x0<br>Exists: Always     |
| 4    | SLV_EXTDLYEN | R/W    | Enable extended delay mode for slave<br>Value After Reset: 0x0<br>Exists: Always |
| 3    | MST_BYPASS   | R/W    | Bypass enable control for master DL<br>Value After Reset: 0x0<br>Exists: Always  |
| 2:1  | MST_INPSEL   | R/W    | Clock source select for master DL<br>Value After Reset: 0x0<br>Exists: Always    |

| Bits | Name         | Access | Description                                                                       |
|------|--------------|--------|-----------------------------------------------------------------------------------|
| 0    | MST_EXTDLYEN | R/W    | Enable extended delay mode for master<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.21 DLL\_OFFSET

- Name: DLL Offset Setting Register
- Description: SD/eMMC PHY DLL offset value settings
- Size: 8 bits
- Offset: 0x300 + 0x29

Figure &amp; Table 3-135 Fields for register: DLL\_OFFSET

| Bits | Name   | Access | Description                                                                       |
|------|--------|--------|-----------------------------------------------------------------------------------|
| 7    |        |        | Reserved Field: Yes                                                               |
| 6:0  | OFFSET | R/W    | Sets the value of DLL's offset input.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.22 DLLMST\_TSTDC

- Name: DLL Master Test Code Setting Register
- Description: SD/eMMC PHY DLL master testing delay code register
- Size: 8 bits
- Offset: 0x300 + 0x2A

Figure &amp; Table 3-136 Fields for register: DLLMST\_TSTDC

| Bits | Name      | Access | Description                                                                                                      |
|------|-----------|--------|------------------------------------------------------------------------------------------------------------------|
| 7    |           |        | Reserved Field: Yes                                                                                              |
| 6:0  | MSTTST_DC | R/W    | Sets the value of DLL's master test code input when DLL is disabled.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.23 DLLLBTCNFG

- Name: DLL LBT Setting Register
- Description: SD/eMMC PHY DLL low bandwidth timer configuration register
- Size: 16 bits
- Offset: 0x300 + 0x2C

Figure &amp; Table 3-137 Fields for register: DLLLBT\_CNFG

| Bits | Name        | Access | Description                                                                                                                                                                           |
|------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | LBT_LOADVAL | R/W    | <p>Sets the value of DLL's olbt_loadval input. Controls the lbt timer's timeout value at which DLL runs a revalidation cycle.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

### 3.6.4.24 DLL\_STATUS

- Name: DLL Status Register
- Description: SD/eMMC PHY DLL status register
- Size: 8 bits
- Offset: 0x300 + 0x2E

Figure &amp; Table 3-138 Fields for register: DLL\_STATUS

| Bits | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:2  |           |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1    | ERROR_STS | R      | <p>Captures the value of DLL's lock error status information. Value is valid only when LOCK_STS is set.</p> <ul style="list-style-type: none"> <li>■ IF LOCK_STS =1 and ERR_STS = 0 then DLL is locked and no errors are generated.</li> <li>■ IF LOCK_STS =1 and ERR_STS = 1 then DLL is locked to default and has errors. Transactions at this phase can fail.</li> </ul> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (DLL_ERROR): DLL is locked and ready.</li> <li>■ 0x0 (DLL_LOCK_OKAY): DLL has not locked.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 0    | LOCK_STS  | R      | <p>Captures the value of DLL's lock status information.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (DLL_IS_LOCKED): DLL is locked and ready.</li> <li>■ 0x0 (DLL_NOT_LOCKED): DLL has not locked.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                            |

### 3.6.4.25 DLLDBG\_MLKDC

- Name: DLL Master Lock Code Debug Register



- Description: SD/eMMC PHY DLL's master lock code status
- Size: 8 bits
- Offset: 0x300 + 0x30

Figure &amp; Table 3-139 Fields for register: DLLDBG\_MLKDC

| Bits | Name    | Access | Description                                                                                                 |
|------|---------|--------|-------------------------------------------------------------------------------------------------------------|
| 7    |         |        | Reserved Field: Yes                                                                                         |
| 6:0  | MSTLKDC | R      | Captures the value Delay Code to which DLL's master has locked.<br>Value After Reset: 0x0<br>Exists: Always |

### 3.6.4.26 DLLDBG\_SLKDC

- Name: DLL Master Slave Code Debug Register
- Description: SD/eMMC PHY DLL's slave lock code status
- Size: 8 bits
- Offset: 0x300 + 0x32

Figure &amp; Table 3-140 Fields for register: DLLDBG\_SLKDC

| Bits | Name    | Access | Description                                                                                                |
|------|---------|--------|------------------------------------------------------------------------------------------------------------|
| 7    |         |        | Reserved Field: Yes                                                                                        |
| 6:0  | SLVLKDC | R      | Captures the value Delay Code to which DLL's slave has locked.<br>Value After Reset: 0x0<br>Exists: Always |

## 3.6.5 DWC\_mshc\_map/DWC\_mshc\_vendor1\_block Registers

### 3.6.5.1 MSHC\_VER\_ID\_R

- Name: MSHC Version
- Description: This register reflects the current release number of DWC\_mshc.
- Size: 32 bits
- Offset: 0x500

Figure &amp; Table 3-141 Fields for register: MSHC\_VER\_ID\_R

| Bits | Name        | Access | Description                                                                                                                                                |
|------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | MSHC_VER_ID | R      | Current release number<br>This field indicates the Synopsys DesignWare Cores DWC_mshc/DWC_mshc_lite current release number that is read by an application. |

| Bits | Name | Access | Description                                                                                                                                                                                              |
|------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>An application reading this register in conjunction with the MSHC_VER_TYPE_R register, gathers details of the current release.</p> <p>Value After Reset: "SNPS_RSVDPARAM_5"</p> <p>Exists: Always</p> |

### 3.6.5.2 MSHC\_VER\_TYPE\_R

- Name: MSHC Version Type
- Description: This register reflects the current release type of DWC\_mshc.
- Size: 32 bits
- Offset: 0x500 + 0x4

Figure &amp; Table 3-142 Fields for Register: MSHC\_VER\_TYPE\_R

| Bits | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                              |
|------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | MSHC_VER_TYPE | R      | <p>Current release type</p> <p>This field indicates the Synopsys DesignWare Cores DWC_mshc/DWC_mshc_lite current release type that is read by an application.</p> <p>An application reading this register in conjunction with the MSHC_VER_ID_R register, gathers details of the current release.</p> <p>Value After Reset: "SNPS_RSVDPARAM_6"</p> <p>Exists: Always</p> |

### 3.6.5.3 MSHC\_CTRL\_R

- Name: MSHC Control Register
- Description: This register is used to control the operation of MSHC host controller.
- Size: 8 bits
- Offset: 0x500 + 0x8

Figure &amp; Table 3-143 Fields for Register: MSHC\_CTRL\_R

| Bits | Name       | Access | Description                                                                                                                                                      |
|------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | Reserved   | R      |                                                                                                                                                                  |
| 6    | Reserved   | R      |                                                                                                                                                                  |
| 5    |            |        | Reserved Field: Yes                                                                                                                                              |
| 4    | SW(CG)_DIS | R/W    | <p>Internal clock gating disable control</p> <p>This bit must be used to disable module's internal clock gating when required. When disabled, clocks are not</p> |

| Bits | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|--------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |        | <p>gated. Clocks to the core (except hclk) must be stopped when programming this bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (ENABLE): Internal clock gates are active and clock gating is controlled internally.</li> <li>■ 0x1 (DISABLE): Internal clock gating is disabled, clocks are not gated internally.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3:1  | RSVD1              | R      | <p>These bits (RSVD1) of the MSHC_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0    | CMD_CONFLICT_CHECK | R/W    | <p>Command conflict check</p> <p>This bit enables command conflict check.</p> <p>Note: DWC_mshc controller monitors the CMD line whenever a command is issued and checks whether the value driven on sd_cmd_out matches the value on sd_cmd_in at next subsequent edge of cclk_tx to determine command conflict error. This bit is cleared only if the feedback delay (including IO PAD delay) is more than (t_card_clk_period - t_setup), where t_setup is the setup time of a flop in DWC_mshc. The I/O PAD delay is consistent across CMD and DATA lines, and it is within the value: (2*t_card_clk_period - t_setup).</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (DISABLE_CMD_CONFLICT_CHK): Disable command conflict check.</li> <li>■ 0x1 (CMD_CONFLICT_CHK_LAT1): Check for command conflict after 1 card clock cycle.</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Yes</p> |

### 3.6.5.4 MBIU\_CTRL\_R

- Name: MBIU Control Register
- Description: This register is used to select the valid burst types that the AHB master bus interface can generate. When more than one bit is set the master selects the burst it prefers among those that are enabled in this register.
- Size: 8 bits

- Offset: 0x500 + 0x10

Figure &amp; Table 3-144 Fields for register: MBIU\_CTRL\_R

| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                               |
|------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4  | RSVD            | R      | <p>Reserved field</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                 |
| 3    | BURST_INCR16_EN | R/W    | <p>INCR16 Burst</p> <p>Controls generation of INCR16 transfers on master interface.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): AHB INCR16 burst type is not generated on master I/F.</li> <li>■ 0x1 (TRUE): AHB INCR16 burst type can be generated on master I/F.</li> </ul> <p>Value After Reset: 1</p> <p>Exists: Yes</p> |
| 2    | BURST_INCR8_EN  | R/W    | <p>INCR8 Burst</p> <p>Controls generation of INCR8 transfers on master interface.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): AHB INCR8 burst type is not generated on master I/F.</li> <li>■ 0x1 (TRUE): AHB INCR8 burst type can be generated on master I/F.</li> </ul> <p>Value After Reset: 1</p> <p>Exists: Yes</p>     |
| 1    | BURST_INCR4_EN  | R/W    | <p>INCR4 Burst</p> <p>Controls generation of INCR4 transfers on master interface.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): AHB INCR4 burst type is not generated on master I/F.</li> <li>■ 0x1 (TRUE): AHB INCR4 burst type can be generated on master I/F.</li> </ul> <p>Value After Reset: 1</p> <p>Exists: Yes</p>     |
| 0    | UNDEFI_INCR_EN  | R/W    | <p>Undefined INCR Burst</p> <p>Controls generation of undefined length INCR transfer</p>                                                                                                                                                                                                                                                                  |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                           |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>on master interface.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (FALSE): Undefined INCR type burst is the least preferred burst on AHB master I/F.</li> <li>■ 0x1 (TRUE): Undefined INCR type burst is the most preferred burst on AHB master I/F.</li> </ul> <p>Value After Reset:</p> <p>DWC_MSHC_MBIU_UNDEFLBURSTEN</p> <p>Exists: Yes</p> |

### 3.6.5.5 EMMC\_CTRL\_R

- Name: eMMC Control Register
- Description: This register is used to control the eMMC operation.
- Size: 16 bits
- Offset: 0x500 + 0x2c

Figure & Table 3-145 Fields for register: EMMC\_CTRL\_R

| Bits  | Name                 | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:11 | RSVD                 | R      | <p>These bits (RSVD) of the EMMC_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                               |
| 10    | CQE_PREFETCH_DISABLE | R/W    | <p>Enable or Disable CQE's PREFETCH feature.</p> <p>This field allows software to disable CQE's data prefetch feature when set to 1.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (PREFETCH_ENABLE): CQE can prefetch data for successive WRITE transfers and pipeline successive READ transfers.</li> <li>■ 0x1 (PREFETCH_DISABLE): Prefetch for WRITE and Pipeline for READ are disabled.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> |
| 9     | CQE_ALGO_SEL         | R/W    | <p>Scheduler algorithm selected for execution</p> <p>This bit selects the algorithm used for selecting one of the many ready tasks for execution.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (PRI_REORDER_PLUS_FCFS): Priority based</li> </ul>                                                                                                                                                                                                       |

| Bits | Name                 | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                      |        | <p>reordering with FCFS to resolve equal priority tasks</p> <ul style="list-style-type: none"> <li>■ 0x1 (FCFS_ONLY): First come First serve, in the order of DBR rings</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p>                                                                                                                                                                           |
| 8    | ENH_STROBE_ENABLE    | R/W    | <p>Enhanced Strobe Enable</p> <p>This bit instructs DWC_mshc to sample the CMD line using data strobe for HS400 mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (ENH_STB_FOR_CMD): CMD line is sampled using data strobe for HS400 mode.</li> <li>■ 0x0 (NO_STB_FOR_CMD): CMD line is sampled using cclk_rx for HS400 mode.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> |
| 7:4  |                      |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                                                                                                           |
| 3    | EMMC_RST_N_OE        | R/W    | <p>Output Enable Control for eMMC Device Reset Signal PAD Control</p> <p>This field drives sd_rst_n_oe output of DWC_mshc.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (ENABLE): sd_rst_n_oe is 1.</li> <li>■ 0x0 (DISABLE): sd_rst_n_oe is 0.</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Yes</p>                                                                                |
| 2    | EMMC_RST_N           | R/W    | <p>eMMC Device Reset Signal Control</p> <p>This register field controls the sd_rst_n output of DWC_mshc.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (RST_DEASSERT): Reset to eMMC device is deasserted.</li> <li>■ 0x0 (RST_ASSERT): Reset to eMMC device is asserted (active low).</li> </ul> <p>Value After Reset: 0x1</p> <p>Exists: Yes</p>                                          |
| 1    | DISABLE_DATA_CRC_CHK | R/W    | <p>Disable Data CRC Check</p> <p>This bit controls masking of CRC16 error for Card Write in eMMC mode. This is useful in bus testing (CMD19) for</p>                                                                                                                                                                                                                                                          |

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>an eMMC device. In bus testing, an eMMC card does not send CRC status for a block, which may generate CRC error. This CRC error can be masked using this bit during bus testing.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (DISABLE): Data CRC check is disabled.</li> <li>■ 0x0 (ENABLE): Data CRC check is enabled.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p>    |
| 0    | CARD_IS_EMMC | R/W    | <p>eMMC Card Present</p> <p>This bit indicates the type of card connected. An application program this bit based on the card connected to MSHC.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ .0x1 (EMMC_CARD): Card connected to MSHC is an eMMC card.</li> <li>■ .0x0 (NON_EMMC_CARD): Card connected to MSHC is a non-eMMC card.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> |

### 3.6.5.6 BOOT\_CTRL\_R

- Name: eMMC Boot Control Register
- Description: This register is used to control the eMMC boot operation.
- Size: 16 bits
- Offset: 0x500 + 0x2e

Figure & Table 3-146 Fields for register: BOOT\_CTRL\_R

| Bits  | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                  |
|-------|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:12 | BOOT_TOUT_CNT | R/W    | <p>Boot Ack Timeout Counter Value</p> <p>This value determines the interval by which boot ack timeout (50 ms) is detected when boot ack is expected during boot operation.</p> <ul style="list-style-type: none"> <li>■ 0xF: Reserved</li> <li>■ 0xE: TMCLK x 2^27</li> <li>■ ... .....</li> <li>■ 0x1: TMCLK x 2^14</li> <li>■ 0x0: TMCLK x 2^13</li> </ul> |



| Bits | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:9 | RSVD_11_9       | R      | <p>These bits (RSVD_11_9) of the BOOT_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                  |
| 8    | BOOT_ACK_ENABLE | R/W    | <p>Boot Acknowledge Enable</p> <p>When this bit set, DWC_mshc checks for boot acknowledge start pattern of 0-1-0 during boot operation. This bit is applicable for both mandatory and alternate boot mode.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Boot Ack enable.</li><li>■ 0x0 (FALSE): Boot Ack disable.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                          |
| 7    | VALIDATE_BOOT   | W      | <p>Validate Mandatory Boot Enable</p> <p>This bit is used to validate the MAN_BOOT_EN bit.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TRUE): Validate Mandatory Boot Enable bit.</li><li>■ 0x0 (FALSE): Ignore Mandatory Boot Enable bit.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                       |
| 6:1  | RSVD_6_1        | R      | <p>These bits (RSVD_6_1) of the BOOT_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                   |
| 0    | MAN_BOOT_EN     | R/W    | <p>Mandatory Boot Enable</p> <p>This bit is used to initiate the mandatory boot operation. The application sets this bit along with VALIDATE_BOOT bit. Writing 0 is ignored. The DWC_mshc clears this bit after the boot transfer is completed or terminated.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (MAN_BOOT_EN): Mandatory boot enabled.</li><li>■ 0x0 (MAN_BOOT_DIS): Mandatory boot disabled.</li></ul> <p>Value After Reset: 0x0</p> |



| Bits | Name | Access | Description                           |
|------|------|--------|---------------------------------------|
|      |      |        | Exists: Always<br>Testable: Read-only |

### 3.6.5.7 AT\_CTRL\_R

- Name: Tuning and Auto-tuning Control Register
- Description: This register controls some aspects of tuning and auto-tuning features. Do not program this register when HOST\_CTRL2\_R.SAMPLE\_CLK\_SEL is 1.
- Size: 32 bits
- Offset: 0x500 + 0x40

Figure & Table 3-147 Fields for register: AT\_CTRL\_R

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:24 | SWIN_TH_VAL     | R/W    | <p>Sampling Window Threshold Value Setting<br/>The maximum value that can be set here depends on the length of delayline used for tuning. A delayLine with 128 taps can use values from 0x0 to 0x7F.<br/>This field is valid only when SWIN_TH_EN is 1. Should be programmed only when SAMPLE_CLK_SEL is 0.</p> <ul style="list-style-type: none"><li>■ 0x0: Threshold values is 0x1, windows of length 1 tap and above can be selected as sampling window.</li><li>■ 0x1: Threshold values is 0x1, windows of length 2 taps and above can be selected as sampling window.</li><li>■ 0x2: Threshold values is 0x1, windows of length 3 taps and above can be selected as sampling window.</li><li>■ .....</li><li>■ 0x7F: Threshold values is 0x1, windows of length 128 taps and above can be selected as sampling window.</li></ul> <p>Value After Reset: 3</p> |
| 23:21 |                 |        | Reserved Field: Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20:19 | POST_CHANGE_DLY | R/W    | <p>Time taken for phase switching and stable clock output<br/>Specifies the maximum time (in terms of cclk cycles) that the delay line can take to switch its output phase after a change in tuning_cclk_sel or autotuning_cclk_sel.</p> <p>Values:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



| Bits  | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                  |        | <ul style="list-style-type: none"><li>■ 0x0 (LATENCY_LT_1): Less than 1-cycle latency</li><li>■ 0x1 (LATENCY_LT_2): Less than 2-cycle latency</li><li>■ 0x2 (LATENCY_LT_3): Less than 3-cycle latency</li><li>■ 0x3 (LATENCY_LT_4): Less than 4-cycle latency</li></ul> <p>Value After Reset: 0x0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18:17 | PRE_CHANGE_DLY   | R/W    | <p>Maximum latency specification between cclk_tx and cclk_rx.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (LATENCY_LT_1): Less than 1-cycle latency</li><li>■ 0x1 (LATENCY_LT_2): Less than 2-cycle latency</li><li>■ 0x2 (LATENCY_LT_3): Less than 3-cycle latency</li><li>■ 0x3 (LATENCY_LT_4): Less than 4-cycle latency</li></ul> <p>Value After Reset: 0x0</p>                                                                                                                                                                                                                                                                                                                                                                      |
| 16    | TUNE_CLK_STOP_EN | R/W    | <p>Clock stopping control for tuning and auto-tuning circuit.</p> <p>When enabled, clock gate control output of DWC_mshc (clk2card_on) is pulled low before changing phase select codes on tuning_cclk_sel and autotuning_cclk_sel. This effectively stops the device/card clock, cclk_rx and also drift_cclk_rx. Changing phase code when clocks are stopped ensures glitch free phase switching. Set this bit to 0 if the PHY or delayline can guarantee glitch free switching.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (ENABLE_CLK_STOPPING): Clocks stopped during phase code change.</li><li>■ 0x0 (DISABLE_CLK_STOPPING): Clocks not stopped. PHY ensures glitch free phase switching.</li></ul> <p>Value After Reset: 0x0</p> |
| 15:12 | RSDV3            | R      | <p>These bits (RSDV3) of the AT_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11:8  | WIN_EDGE_SEL     | R/W    | <p>This field sets the phase for left and right edges for drift monitoring. [Left edge offset + Right edge offset] must not be less than total taps of delay line.</p> <ul style="list-style-type: none"><li>■ 0x0: User selection disabled. Tuning calculated</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              |        | <p>edges are used.</p> <ul style="list-style-type: none"><li>■ 0x1: Right edge phase is center + 2 stages, Left edge phase is center - 2 stages.</li><li>■ 0x2: Right edge phase is center + 3 stages, Left edge phase is center - 3 stages.</li><li>■ ...</li><li>■ 0xF: Right edge phase is center + 16 stages, Left edge phase is center - 16 stages.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> |
| 7:5  | RSDV2        | R      | <p>These bits (RSVD2) of the AT_CTRL_R register are reserved. They always return 0.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                         |
| 4    | SW_TUNE_EN   | R/W    | <p>This field enables software-managed tuning flow.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (SW_TUNING_ENABLE): Software-managed tuning enabled. AT_STAT_R. CENTER_PH_CODE Field is now writable.</li><li>■ 0x0 (SW_TUNING_DISABLE): Software-managed tuning disabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                         |
| 3    | RPT_TUNE_ERR | R/W    | <p>Framing errors are not generated when executing tuning. This debug bit allows users to report these errors.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (DEBUG_ERRORS): Debug mode for reporting framing errors</li><li>■ 0x0 (ERRORS_DISABLED): Default mode whereas per SD-HCI no errors are reported.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                        |
| 2    | SWIN_TH_EN   | R/W    | <p>Sampling window threshold enable</p> <p>Selects the tuning mode field should be programmed only when SAMPLE_CLK_SEL is 0.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (THRESHOLD_MODE): Tuning engine selects the</li></ul>                                                                                                                                                                   |

| Bits | Name   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |        |        | <p>first complete sampling window that meets the threshold set by SWIN_TH_VAL field.</p> <ul style="list-style-type: none"> <li>■ 0x0 (LARGEST_WIN_MODE): Tuning engine sweeps all taps and settles at the largest window.</li> </ul> <p>Value After Reset: 1</p>                                                                                                                                                                                                                                                                                       |
| 1    | CI_SEL | R/W    | <p>Selects the interval when the corrected center phase select code can be driven on tuning_cclk_sel output.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (WHEN_IN_BLK_GAP): Driven in block gap interval.</li> <li>■ 0x1 (WHEN_IN_IDLE): Driven at the end of the transfer.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p>                                                                                                                                                                                             |
| 0    | AT_EN  | R/W    | <p>Setting this bit enables auto-tuning engine. This bit is enabled by default when core is configured with mode3 retuning support. Clear this bit to 0 when core is configured to have mode3 re-tuning but software wishes to disable mode3 retuning.</p> <p>This field should be programmed only when CLK_CTRL_R.SD_CLK_EN is 0.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x1 (AT_ENABLE): Auto-tuning is enabled.</li> <li>■ 0x0 (AT_DISABLE): Auto-tuning is disabled.</li> </ul> <p>Value After Reset: 1</p> <p>Exists: Yes</p> |

### 3.6.5.8 AT\_STAT\_R

- Name: Tuning and Auto-tuning Status Register
- Description: Register to read the Center, Left and Right codes used by tuning and auto-tuning engines. Center code field is also used for software managed tuning.
- Size: 32 bits
- Offset: 0x500 + 0x44

Figure & Table 3-148 Fields for register: AT\_STAT\_R

| Bits  | Name  | Access | Description                                                              |
|-------|-------|--------|--------------------------------------------------------------------------|
| 31:24 | RSDV1 | R      | These bits of the AT_STAT_R register are reserved. They always return 0. |

| Bits  | Name           | Access | Description                                                                                                                                                                                                                                                                           |
|-------|----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                |        | Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                              |
| 23:16 | L_EDGE_PH_CODE | R      | Left Edge Phase code. Reading this field returns the phase code value used by Auto-tuning engine to sample data on Left edge of sampling window.<br>Value After Reset: 0x0<br>Exists: Always                                                                                          |
| 15:8  | R_EDGE_PH_CODE | R      | Right Edge Phase code. Reading this field returns the phase code value used by auto-tuning engine to sample data on Right edge of sampling window.<br>Value After Reset: 0x0<br>Exists: Always                                                                                        |
| 7:0   | CENTER_PH_CODE | R/W    | Centered Phase code. Reading this field returns the current value on tuning_cclk_sel output. Setting AT_CTRL_R.SW_TUNE_EN enables software to write to this field and its contents are reflected on tuning_cclk_sel.<br>Value After Reset: 6<br>Exists: Always<br>Testable: Read-only |

## 4 QSPI

### 4.1 Overview

The DW\_apb\_ssi is a configurable, synthesizable, and programmable component that is a full-duplex master serial interface. The host processor accesses data, control, and status information on the DW\_apb\_ssi through the APB interface. The DW\_apb\_ssi may also interface with a DMA controller using an optional set of DMA signals, which can be selected at configuration time. As described in more detail later, the DW\_apb\_ssi can be configured as a serial master. The DW\_apb\_ssi can connect to any serial-slave peripheral device using Motorola Serial Peripheral Interface (SPI).

### 4.2 Main Features

DW\_apb\_ssi has the following features:

- APB interface
- APB3 protocol support
- Scalable APB data bus width - Supports APB data bus widths of 32 bits.
- Serial-master - Enables serial communication serial-slave peripheral devices.
- Configurable and programmable Quad SPI (QSPI) support in master mode - Configure DW\_apb\_ssi to support QSPI mode, and then program DW\_apb\_ssi for QSPI transfers.
- Data mask support - Enables the DW\_apb\_ssi to selectively update the bytes in the device. This feature is applicable only in enhanced SPI modes.
- eXecute In Place (XIP) support - Enables the DW\_apb\_ssi master to behave as a memory mapped I/O and fetches the data from the device based on the APB read request. This feature is applicable only in enhanced SPI modes.
- DMA controller interface - Enables the DW\_apb\_ssi to interface to a DMA controller over the bus using a handshaking interface for transfer requests.
- Independent masking of interrupts - Master collision, transmit FIFO overflow, transmit FIFO empty, receive FIFO full, receive FIFO underflow, and receive FIFO overflow interrupts can all be masked independently.
- Multi-master contention detection - Informs the processor of multiple serial master accesses on the serial bus.
- Programmable delay on the sample time of the received serial data bit (rxn), when configured in master mode; enables programmable control of routing delays resulting in higher serial data-bit rates.
- Number of slave select outputs - When operating as a serial master, 4 serial slave-select output signals can be generated.
- Combined interrupt line - Bring one combined interrupt line from the DW\_apb\_ssi to the interrupt controller.



- Programmable features:
  - Serial interface operation - Choice of Motorola SPI.
  - Clock bit-rate - Dynamic control of the serial bit rate of the data transfer; used in only serial-master mode of operation.
  - Data item size (4 to 32 bits) - Item size of each data transfer under the control of the programmer.
- Configurable features:
  - Interrupt polarity - This configuration option selects the active level of the output interrupt line.
  - Serial clock polarity - This configuration option selects the serial-clock polarity of the SPI format directly after reset.
  - Serial clock phase - This configuration option selects the serial-clock phase of the SPI format directly after reset.

## 4.3 Interface

| Pin Name      | Direction | Width | Description                                                                                                                                                                                           |
|---------------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QSPI0_CS0     | O         | 1     | Slave select output of QSPI0. The active polarity is logic 0.                                                                                                                                         |
| QSPI0_CS1     | O         | 1     | Slave select output of QSPI0. The active polarity is logic 0.                                                                                                                                         |
| QSPI0_D0_MOSI | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.                                                                                                            |
| QSPI0_D1_MISO | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.                                                                                                            |
| QSPI0_D2_WP   | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.<br>The Write Protect (WP) pin can be used to prevent the Status Register of the device from being written. |
| QSPI0_D3_HOLD | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.<br>The HOLD pin allows the device to be paused while it is actively selected.                              |
| QSPI0_SCLK    | O         | 1     | The SPI Serial Clock Output pin provides the timing for serial input and output operations.                                                                                                           |
| QSPI1_CS0     | O         | 1     | Slave select output of QSPI1. The active polarity is logic 0.                                                                                                                                         |
| QSPI1_D0_MOSI | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.                                                                                                            |
| QSPI1_D1_MISO | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.                                                                                                            |



| Pin Name      | Direction | Width | Description                                                                                                                                                                           |
|---------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QSPI1_D2_WP   | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.<br>The WP pin can be used to prevent the Status Register of the device from being written. |
| QSPI1_D3_HOLD | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.<br>The HOLD pin allows the device to be paused while it is actively selected.              |
| QSPI1_SCLK    | O         | 1     | The SPI Serial Clock Output pin provides the timing for serial input and output operations.                                                                                           |
| SPI_CSN       | O         | 1     | Slave select output of SPI. The active polarity is logic 0.                                                                                                                           |
| SPI_MISO      | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.                                                                                            |
| SPI_MOSI      | IO        | 1     | The bidirectional IO pins to serially write instructions, addresses or data to the device.                                                                                            |
| SPI_SCLK      | O         | 1     | The SPI Serial Clock Output pin provides the timing for serial input and output operations.                                                                                           |

## 4.4 Function Description

### 4.4.1 Data Flow

In order for the DW\_apb\_ssi to connect to a serial-slave peripheral device, the peripheral must have a Motorola SPI. This is a four-wire, full-duplex serial protocol from Motorola. There are four possible combinations for the serial clock phase and polarity. The clock phase (SCPH) determines whether the serial transfer begins with the falling edge of the slave select signal or the first edge of the serial clock. The slave select line is held high when the DW\_apb\_ssi is idle or disabled.

You can program the FRF (frame format) bit field in the Control Register 0 (CTRLR0) to select which protocol is used.

The serial protocols supported by the DW\_apb\_ssi allow for serial slaves to be selected or addressed using either hardware or software. When implemented in hardware, serial slaves are selected under the control of dedicated hardware select lines. The number of select lines generated from the serial master is equal to the number of serial slaves present on the bus. The serial-master device asserts the select line of the target serial slave before data transfer begins. This architecture is illustrated in Figure & Table 4-1.



Figure &amp; Table 4-1 Slave selection

#### 4.4.2 Clock Ratios

When DW\_apb\_ssi is configured as a master device, the maximum frequency of the bit-rate clock (sclk\_out) is one-half the frequency of ssi\_clk. This allows the shift control logic to capture data on one clock edge of sclk\_out and propagate data on the opposite edge. The sclk\_out line toggles only when an active transfer is in progress. At all other times it is held in an inactive state.

The frequency of sclk\_out can be derived from the following equation:

$$Fsclk_{out} = Fssi_{clk}/SCKDV$$

SCKDV is a bit field in the programmable register BAUDR, holding any even value in the range 0 to 65,534. If SCKDV is 0, then sclk\_out is disabled.

#### 4.4.3 Transmit and Receive FIFO Buffers

The transmit and receive FIFO buffers are cleared when the DW\_apb\_ssi is disabled (SSI\_EN = 0) or when it is reset (presetn).

The transmit FIFO is loaded by APB write commands to the DW\_apb\_ssi data register (DR). Data are popped (removed) from the transmit FIFO by the shift control logic into the transmit shift register. The transmit FIFO generates a FIFO empty interrupt request (ssi\_txe\_intr) when the number of entries in the FIFO is less than or equal to the FIFO threshold value. The threshold value, set through the programmable register TXFTLR, determines the level of FIFO entries at which an interrupt is generated. The threshold value allows you to provide early indication to the processor that the transmit FIFO is nearly empty. A transmit FIFO overflow interrupt (ssi\_txo\_intr) is generated if you attempt to write data into an already full transmit FIFO.

Data are popped from the receive FIFO by APB read commands to the DW\_apb\_ssi DR. The receive FIFO is loaded from the receive shift register by the shift control logic. The receive FIFO generates a FIFO-full interrupt request (ssi\_rxf\_intr) when the number of entries in the FIFO is greater than or equal to the FIFO threshold value plus 1. The threshold value, set through programmable register

RXFTLR, determines the level of FIFO entries at which an interrupt is generated. The threshold value allows you to provide early indication to the processor that the receive FIFO is nearly full. A receive FIFO overrun interrupt (ssi\_rxo\_intr) is generated when the receive shift logic attempts to load data into a completely full receive FIFO. However, this newly received data are lost. A receive FIFO underflow interrupt (ssi\_rxu\_intr) is generated if you attempt to read from an empty receive FIFO. This alerts the processor that the read data are invalid.

Figure & Table 4-2 Transmit FIFO Threshold (TFT) decode values

| TFT Value (Bin) | Description                                                                          |
|-----------------|--------------------------------------------------------------------------------------|
| 0000_0000       | ssi_txe_intr is asserted when 0 data entries are present in transmit FIFO.           |
| 0000_0001       | ssi_txe_intr is asserted when 1 or less data entry is present in transmit FIFO.      |
| 0000_0010       | ssi_txe_intr is asserted when 2 or less data entries are present in transmit FIFO.   |
| 0000_0011       | ssi_txe_intr is asserted when 3 or less data entries are present in transmit FIFO.   |
| ...             | ...                                                                                  |
| ...             | ...                                                                                  |
| 1111_1100       | ssi_txe_intr is asserted when 252 or less data entries are present in transmit FIFO. |
| 1111_1101       | ssi_txe_intr is asserted when 253 or less data entries are present in transmit FIFO. |
| 1111_1110       | ssi_txe_intr is asserted when 254 or less data entries are present in transmit FIFO. |
| 1111_1111       | ssi_txe_intr is asserted when 255 or less data entries are present in transmit FIFO. |

Figure & Table 4-3 Receive FIFO Threshold (RFT) decode values

| RFT Value | Description                                                                         |
|-----------|-------------------------------------------------------------------------------------|
| 0000_0000 | ssi_rxf_intr is asserted when 1 or more data entry is present in receive FIFO.      |
| 0000_0001 | ssi_rxf_intr is asserted when 2 or more data entries are present in receive FIFO.   |
| 0000_0010 | ssi_rxf_intr is asserted when 3 or more data entries are present in receive FIFO.   |
| 0000_0011 | ssi_rxf_intr is asserted when 4 or more data entries are present in receive FIFO.   |
| ...       | ...                                                                                 |
| ...       | ...                                                                                 |
| 1111_1100 | ssi_rxf_intr is asserted when 253 or more data entries are present in receive FIFO. |
| 1111_1101 | ssi_rxf_intr is asserted when 254 or more data entries are present in receive FIFO. |
| 1111_1110 | ssi_rxf_intr is asserted when 255 or more data entries are present in receive FIFO. |
| 1111_1111 | ssi_rxf_intr is asserted when 256 data entries are present in receive FIFO.         |



#### 4.4.4 SSI Interrupts

The DW\_apb\_ssi interrupts are described as follows:

- Transmit FIFO Empty Interrupt (ssi\_txe\_intr) - Set when the transmit FIFO is equal to or below its threshold value and requires service to prevent an under-run. The threshold value, set through a software-programmable register, determines the level of transmit FIFO entries at which an interrupt is generated. This interrupt is cleared by hardware when data are written into the transmit FIFO buffer, bringing it over the threshold level.
- Transmit FIFO Overflow Interrupt (ssi\_txo\_intr) - Set when an APB access attempts to write into the transmit FIFO after it has been completely filled. When set, data written from the APB is discarded. This interrupt remains set until you read the transmit FIFO overflow interrupt clear register (TXOICR).
- Receive FIFO Full Interrupt (ssi\_rxf\_intr) - Set when the receive FIFO is equal to or above its threshold value plus 1 and requires service to prevent an overflow. The threshold value, set through a software-programmable register, determines the level of receive FIFO entries at which an interrupt is generated. This interrupt is cleared by hardware when data are read from the receive FIFO buffer, bringing it below the threshold level.
- Receive FIFO Overflow Interrupt (ssi\_rxo\_intr) - Set when the receive logic attempts to place data into the receive FIFO after it has been completely filled. When set, newly received data are discarded. This interrupt remains set until you read the receive FIFO overflow interrupt clear register (RXOICR).
- Receive FIFO Underflow Interrupt (ssi\_rxu\_intr) - Set when an APB access attempts to read from the receive FIFO when it is empty. When set, zeros are read back from the receive FIFO. This interrupt remains set until you read the receive FIFO underflow interrupt clear register (RXUICR).
- Multi-Master Contention Interrupt (ssi\_mst\_intr) - Present only when the DW\_apb\_ssi component is configured as a serial-master device. The interrupt is set when another serial master on the serial bus selects the DW\_apb\_ssi master as a serial-slave device and is actively transferring data. This informs the processor of possible contention on the serial bus. This interrupt remains set until you read the multi-master interrupt clear register (MSTICR).
- Combined Interrupt Request (ssi\_intr) - OR'ed result of all the above interrupt requests after masking. To mask this interrupt signal, you must mask all other DW\_apb\_ssi interrupt requests.

#### 4.4.5 Transfer Modes

- When TMOD = 2'b00, both transmit and receive logic are valid. The data transfer occurs as normal according to the selected frame format (serial protocol). Transmit data are popped from the transmit FIFO and sent through the txd line to the target device, which replies with data on the rxd line. The receive data from the target device is moved from the receive shift register into the receive FIFO at the end of each data frame.
- When TMOD = 2'b01, the receive data are invalid and should not be stored in the receive FIFO. The data transfer occurs as normal, according to the selected frame format (serial protocol). Transmit data are popped from the transmit FIFO and sent through the txd line to the target



device, which replies with data on the rxd line. At the end of the data frame, the receive shift register does not load its newly received data into the receive FIFO. The data in the receive shift register is overwritten by the next transfer. You should mask interrupts originating from the receive logic when this mode is entered.

- When TMOD = 2'b10, the transmit data are invalid. When configured as a slave, the transmit FIFO is never popped in Receive Only mode. The txd output remains at a constant logic level during the transmission. The data transfer occurs as normal according to the selected frame format (serial protocol). The receive data from the target device is moved from the receive shift register into the receive FIFO at the end of each data frame. You should mask interrupts originating from the transmit logic when this mode is entered.
- When TMOD = 2'b11, the transmit data is used to transmit an opcode and/or an address to the EEPROM device. Typically, this takes three data frames (8-bit opcode followed by 8-bit upper address and 8-bit lower address). During the transmission of the opcode and address, no data is captured by the receive logic (as long as the DW\_apb\_ssi master is transmitting data on its txd line, data on the rxd line is ignored). The DW\_apb\_ssi master continues to transmit data until the transmit FIFO is empty. Therefore, you should ONLY have enough data frames in the transmit FIFO to supply the opcode and address to the EEPROM. If more data frames are in the transmit FIFO than are needed, then read data is lost. When the transmit FIFO becomes empty (all control information has been sent), data on the receive line (rxd) is valid and is stored in the receive FIFO; the txd output is held at a constant logic level. The serial transfer continues until the number of data frames received by the DW\_apb\_ssi master matches the value of the NDF field in the CTRLR1 register + 1.

For transmit and receive transfers (transfer mode field [9:8] of the Control Register 0 = 2'b00), data transmitted from the DW\_apb\_ssi to the external serial device is written into the transmit FIFO. Data received from the external serial device into the DW\_apb\_ssi is pushed into the receive FIFO.



Figure & Table 4-4 FIFO status for transmit & receive SPI transfers

For transmit only transfers (transfer mode field [9:8] of the Control Register 0 = 2'b01), data transmitted from the DW\_apb\_ssi to the external serial device is written into the transmit FIFO. As the data received from the external serial device is deemed invalid, it is not stored in the DW\_apb\_ssi receive FIFO.



Figure & Table 4-5 FIFO status for transmit only SPI transfers

For receive only transfers (transfer mode field [9:8] of the Control Register 0 = 2'b10), data transmitted from the DW\_apb\_ssi to the external serial device is invalid, so a single dummy word is written into the transmit FIFO to begin the serial transfer. The txd output from the DW\_apb\_ssi is held at a constant logic level for the duration of the serial transfer. Data received from the external serial device into the DW\_apb\_ssi is pushed into the receive FIFO.



Figure & Table 4-6 FIFO status for receive only SPI transfers

For eeprom\_read transfers (transfer mode field [9:8] of the Control Register 0 = 2'b11), opcode and/or EEPROM address are written into the transmit FIFO. During transmission of these control frames, received data is not captured by the DW\_apb\_ssi master. After the control frames have been transmitted, receive data from the EEPROM is stored into the receive FIFO.



Figure & Table 4-7 FIFO status for EEPROM read transfer mode

#### 4.4.6 RXD Sample Delay

When the DW\_apb\_ssi is configured as a master, additional logic can be included in the design in order to delay the default sample time of the rxd signal. This additional logic can help to increase the maximum achievable frequency on the serial bus.

Round trip routing delays on the sclk\_out signal from the master and the rxd signal from the slave can mean that the timing of the rxd signal—as seen by the master—has moved away from the normal sampling time. Figure & Table 4-8 illustrates this situation.

The Slave uses the sclk\_out signal from the master as a strobe in order to drive rxd signal data onto the serial bus. Routing and sampling delays on the sclk\_out signal by the slave device can mean that the rxd bit has not stabilized to the correct value before the master samples the rxd signal. Figure & Table 4-8 shows an example of how a routing delay on the rxd signal can result in an incorrect rxd value at the default time when the master samples the port.

Without the RXD Sample Delay logic, you would have to increase the baud-rate for the transfer in order to ensure that the setup times on the rxd signal are within range; this results in reducing the frequency of the serial interface.

When the RXD Sample Delay logic is included, you can dynamically program a delay value in order to move the sampling time of the rxd signal equal to a number of ssi\_clk cycles from the default.



The sample delay logic has a resolution of one ssi\_clk cycle. Software can “train” the serial bus by coding a loop that continually reads from the slave and increments the master’s RXD Sample Delay value until the correct data is received by the master.



Figure & Table 4-8 Effects of round-trip routing delays on sclk\_out signal

#### 4.4.7 Data Transfer

Data transfers are started by the serial-master device. When the DW\_apb\_ssi is enabled (SSI\_EN=1), at least one valid data entry is present in the transmit FIFO and a serial-slave device is selected. When actively transferring data, the busy flag (BUSY) in the status register (SR) is set. You must wait until the busy flag is cleared before attempting a new serial transfer.

When the transfer mode is “transmit and receive” or “transmit only” (TMOD = 2'b00 or TMOD = 2'b01, respectively), transfers are terminated by the shift control logic when the transmit FIFO is empty. For continuous data transfers, you must ensure that the transmit FIFO buffer does not become empty before all the data have been transmitted. The transmit FIFO threshold level (TXFTLR) can be used to early interrupt (ssi\_txe\_intr) the processor indicating that the transmit FIFO buffer is nearly empty. When a DMA is used for APB accesses, the transmit data level (DMATDLR) can be used to early request (dma\_tx\_req) the DMA controller, indicating that the transmit FIFO is nearly empty. The FIFO can then be refilled with data to continue the serial transfer. You may also write a block of data (at least two FIFO entries) into the transmit FIFO before enabling a serial slave. This ensures that serial transmission does not begin until the number of data-frames that make up the continuous transfer are present in the transmit FIFO.

When the transfer mode is “receive only” (TMOD = 2'b10), a serial transfer is started by writing one “dummy” data word into the transmit FIFO when a serial slave is selected. The txd output from the DW\_apb\_ssi is held at a constant logic level for the duration of the serial transfer. The transmit FIFO is popped only once at the beginning and may remain empty for the duration of the serial transfer. The end of the serial transfer is controlled by the “number of data frames” (NDF) field in CTRLR1.

If, for example, you want to receive 24 data frames from a serial-slave peripheral, you should program the NDF field with the value 23; the receive logic terminates the serial transfer when the number of frames received is equal to the NDF value + 1. This transfer mode increases the bandwidth of the APB bus as the transmit FIFO never needs to be serviced during the transfer. The receive FIFO buffer should be read each time the receive FIFO generates a FIFO full interrupt request to prevent an overflow.

When the transfer mode is “eeprom\_read” (TMOD = 2'b11), a serial transfer is started by writing the opcode and/or address into the transmit FIFO when a serial slave (EEPROM) is selected. The opcode and address are transmitted to the EEPROM device, after which read data is received from the EEPROM device and stored in the receive FIFO. The end of the serial transfer is controlled by the NDF field in CTRLR1.

#### 4.4.8 XIP Mode Support in SPI Mode

The XIP mode enables transfer of SPI data directly through the APB interface without writing the data register of DW\_apb\_ssi. XIP mode can be enabled in DW\_apb\_ssi by selecting the SSI\_XIP\_EN configuration parameter, which includes an extra sideband signal xip\_en, on the APB interface. This signal indicates whether APB transfers are register read-write or XIP reads. If the xip\_en signal is driven to 1, DW\_apb\_ssi expects only read request on the APB interface. This request is translated to SPI read on the serial interface and soon after the data is received, the data is returned to the APB interface in the same transaction.

#### 4.4.9 DMA Controller Interface

The DW\_apb\_ssi has optional built-in DMA capability which can be selected at configuration time; it has a handshaking interface to a DMA controller to request and control transfers. The APB bus is used to perform the data transfer to or from the DMA. While the DW\_apb\_ssi DMA operation is designed in a generic way to fit any DMA controller as easily as possible, it is designed to work seamlessly, and best used, with the DesignWare DMA Controller, the DW\_axi\_dmac.

When the DW\_apb\_ssi interfaces to the DW\_axi\_dmac, the DW\_axi\_dmac is always a flow controller; that is, it controls the block size. This must be programmed by software in the DW\_axi\_dmac.

The DW\_apb\_ssi uses two DMA channels, one for the transmit data and one for the receive data.

The DW\_apb\_ssi has these DMA registers:

- DMACR - Control register to enable DMA operation.
- DMATDLR - Register to set the transmit FIFO level at which a DMA request is made.
- DMARDLR - Register to set the receive FIFO level at which a DMA request is made.

The DW\_apb\_ssi uses the following handshaking signals to interface with the DMA controller:

- dma\_tx\_req
- dma\_tx\_single
- dma\_tx\_ack
- dma\_rx\_req
- dma\_rx\_single

- `dma_rx_ack`

To enable the DMA controller interface on the DW\_apb\_ssi, you must write the DMA Control Register (DMACR). Writing a 1 into the TDMAE bit field of DMACR register enables the DW\_apb\_ssi transmit handshaking interface. Writing a 1 into the RDMAE bit field of the DMACR register enables the DW\_apb\_ssi receive handshaking interface.

Figure & Table 4-9 DMA Transmit Data Level (DMATDL) decode value

| DMATDL Value | Description                                                                            |
|--------------|----------------------------------------------------------------------------------------|
| 0000_0000    | dma_tx_req is asserted when 0 data entries are present in the transmit FIFO.           |
| 0000_0001    | dma_tx_req is asserted when 1 or less data entry is present in the transmit FIFO.      |
| 0000_0010    | dma_tx_req is asserted when 2 or less data entries are present in the transmit FIFO.   |
| 0000_0011    | dma_tx_req is asserted when 3 or less data entries are present in the transmit FIFO.   |
| ...          | ...                                                                                    |
| ...          | ...                                                                                    |
| 1111_1100    | dma_tx_req is asserted when 252 or less data entries are present in the transmit FIFO. |
| 1111_1101    | dma_tx_req is asserted when 253 or less data entries are present in the transmit FIFO. |
| 1111_1110    | dma_tx_req is asserted when 254 or less data entries are present in the transmit FIFO. |
| 1111_1111    | dma_tx_req is asserted when 255 or less data entries are present in the transmit FIFO  |

Figure & Table 4-10 DMA Receive Data Level (DMARDL) decode value

| DMARDL Value | Description                                                                               |
|--------------|-------------------------------------------------------------------------------------------|
| 0000_0000    | dma_rx_req is asserted when 1 or more data entries are present in the receive FIFO.       |
| 0000_0001    | dma_rx_req is asserted when 2 or more data entries are present in the receive FIFO.       |
| 0000_0010    | dma_rx_req is asserted when 3 or more data entries are present in the receive FIFO.       |
| 0000_0011    | dma_rx_req is asserted when 4 or more valid data entries are present in the receive FIFO. |
| ...          | ...                                                                                       |
| ...          | ...                                                                                       |
| 1111_1100    | dma_rx_req is asserted when 253 or more data entries are present in the receive FIFO.     |
| 1111_1101    | dma_rx_req is asserted when 254 or more data entries are present in the receive FIFO.     |
| 1111_1110    | dma_rx_req is asserted when 255 or more data entries are present in the receive FIFO.     |
| 1111_1111    | dma_rx_req is asserted when 256 data entries are present in the receive FIFO.             |



#### 4.4.9.1 Transmit Watermark Level and Transmit FIFO Underflow

During DW\_apb\_ssi serial transfers, transmit FIFO requests are made to the DW\_axi\_dmac whenever the number of entries in the transmit FIFO is less than or equal to the DMA Transmit Data Level Register (DMATDLR) value; this is known as the watermark level. The DW\_axi\_dmac responds by writing a burst of data to the transmit FIFO buffer, of length CTLx.DEST\_MSIZEx.

Data should be fetched from the DMA often enough for the transmit FIFO to perform serial transfers continuously; that is, when the FIFO begins to empty another DMA request should be triggered. Otherwise the FIFO runs out of data (underflow). To prevent this condition, you must set the watermark level correctly.

Consider the example where the assumption is made:

$$\text{DMA.CTLx.DEST_MSIZEx} = \text{FIFO_DEPTH} - \text{SSI.DMATDLR}$$

Here the number of data items to be transferred in a DMA burst is equal to the empty space in the Transmit FIFO. Consider two different watermark level settings.

##### Case 1: DMATDLR = 2

- Transmit FIFO watermark level = SSI.DMATDLR = 2
- DMA.CTLx.DEST\_MSIZEx = FIFO\_DEPTH - SSI.DMATDLR = 6
- SSI transmit FIFO\_DEPTH = 8
- DMA.CTLx.BLOCK\_TS = 30

Therefore, the number of burst transactions needed equals the block size divided by the number of data items per burst:

$$\text{DMA.CTLx.BLOCK_TS} / \text{DMA.CTLx.DEST_MSIZEx} = 30 / 6 = 5$$

The number of burst transactions in the DMA block transfer is 5. But the watermark level, SSI.DMATDLR, is quite low. Therefore, the probability of an SSI underflow is high where the SSI serial transmit line needs to transmit data, but where there is no data left in the transmit FIFO. This occurs because the DMA has no time to service the DMA request before the transmit FIFO becomes empty.

##### Case 2: DMATDLR = 6

- Transmit FIFO watermark level = SSI.DMATDLR = 6
- DMA.CTLx.DEST\_MSIZEx = FIFO\_DEPTH - SSI.DMATDLR = 2
- SSI transmit FIFO\_DEPTH = 8
- DMA.CTLx.BLOCK\_TS = 30

Number of burst transactions in Block:

$$\text{DMA.CTLx.BLOCK_TS} / \text{DMA.CTLx.DEST_MSIZEx} = 30 / 2 = 15$$

In this block transfer, there are 15 destination burst transactions in a DMA block transfer. But the watermark level, SSI.DMATDLR, is high. Therefore, the probability of an SSI underflow is low because the DMA controller has plenty of time to service the destination burst transaction request before the SSI transmit FIFO becomes empty.

Thus, the second case has a lower probability of underflow at the expense of more burst transactions per block. This provides a potentially greater amount of AMBA bursts per block and worse bus utilization than the former case.



Therefore, the goal in choosing a watermark level is to minimize the number of transactions per block, while at the same time keeping the probability of an underflow condition to an acceptable level. In practice, this is a function of the ratio of the rate at which the SSI transmits data to the rate at which the DMA can respond to destination burst requests.

For example, promoting the channel to the highest priority channel in the DMA, and promoting the DMA master interface to the highest priority master in the AMBA layer, increases the rate at which the DMA controller can respond to burst transaction requests. This in turn allows you to decrease the watermark level, which improves bus utilization without compromising the probability of an underflow occurring.

For optimal operation, DMA.CTLx.DEST\_MSIZEx should be set at the FIFO level that triggers a transmit DMA request; that is:

$$\text{DMA.CTLx.DEST_MSIZEx} = \text{SSI.FIFO_DEPTH} - \text{SSI.DMATDLR}$$

Adhering to this equation reduces the number of DMA bursts needed for a block transfer, and this in turn improves AMBA bus utilization.

#### 4.4.9.2 Receive Watermark Level and Receive FIFO Overflow

During DW\_apb\_ssi serial transfers, receive FIFO requests are made to the DW\_axi\_dmac whenever the number of entries in the receive FIFO is at or above the DMA Receive Data Level Register; that is, DMARDL+1. This is known as the watermark level. The DW\_axi\_dmac responds by fetching a burst of data from the receive FIFO buffer of length CTLx.SRC\_MSIZEx.

Data should be fetched by the DMA often enough for the receive FIFO to accept serial transfers continuously; that is, when the FIFO begins to fill, another DMA transfer is requested. Otherwise, the FIFO fills with data (overflow). To prevent this condition, you must correctly set the watermark level.

Similar to choosing the transmit watermark level described earlier, the receive watermark level, DMARDL+1, should be set to minimize the probability of overflow. It is a tradeoff between the number of DMA burst transactions required per block versus the probability of an overflow occurring.

For optimal operation, DMA.CTLx.SRC\_MSIZEx should be set at the watermark level; that is:

$$\text{DMA.CTLx.SRC_MSIZEx} = \text{SSI.DMARDL} + 1$$

Adhering to this equation reduces the number of DMA bursts in a block transfer, and this in turn can improve AMBA bus utilization.

#### 4.4.10 Reset Signals

The DW\_apb\_ssi includes the following reset signals, each dedicated to its own clock domain:

- presetn - Resets logic in the pclk clock domain.
- ssi\_rst\_n - Resets logic in ssi\_clk clock domain.

The recommended procedure for resetting the DW\_apb\_ssi is as follows:

1. Assert the ssi\_rst\_n and presetn signal. The sequence of asserting these two signals and their timing relationships with ssi\_clk and pclk are not important.

2. De-assert the `ssi_rst_n` signal synchronously with `ssi_clk`.
3. De-assert the `pclk` signal synchronously.

## 4.5 Usage

Figure & Table 4-11 shows a typical software flow for starting a DW\_apb\_ssi master SPI serial transfer. The diagram also shows the hardware flow inside the serial-master component.



Figure & Table 4-11 DW\_apb\_ssi master SPI transfer flow

## 4.6 Registers

Figure & Table 4-12 Possible read and write behaviors

| Read (or Write) Behavior | Description                        |
|--------------------------|------------------------------------|
| RC                       | A read clears this register field. |



| Read (or Write) Behavior    | Description                                          |
|-----------------------------|------------------------------------------------------|
| RS                          | A read sets this register field.                     |
| RM                          | A read modifies the contents of this register field. |
| Wo                          | You can only write to this register once.            |
| W1C                         | A write of 1 clears this register field.             |
| W1S                         | A write of 1 sets this register field.               |
| W1T                         | A write of 1 toggles this register field.            |
| W0C                         | A write of 0 clears this register field.             |
| W0S                         | A write of 0 sets this register field.               |
| W0T                         | A write of 0 toggles this register field.            |
| WC                          | Any write clears this register field.                |
| WS                          | Any write sets this register field.                  |
| WM                          | Any write toggles this register field.               |
| no Read Behavior attribute  | You cannot read this register. It is Write-Only.     |
| no Write Behavior attribute | You cannot write to this register. It is Read-Only.  |

Figure &amp; Table 4-13 Memory access examples

| Memory Access | Description                                                      |
|---------------|------------------------------------------------------------------|
| R             | Read-only register field                                         |
| W             | Write-only register field                                        |
| R/W           | Read/write register field                                        |
| R/W1C         | You can read this register field. Writing 1 clears it.           |
| RC/W1C        | Reading this register field clears it. Writing 1 clears it.      |
| R/Wo          | You can read this register field. You can only write to it once. |

## 4.6.1 ssi\_memory\_map/ssi\_address\_block Registers

### 4.6.1.1 CTRLR0

- Name: Control Register 0
- Description: This register controls the serial data transfer. It is impossible to write to this register when the DW\_apb\_ssi is enabled. The DW\_apb\_ssi is enabled and disabled by writing to the SSINR register.
- Size: 32 bits

- Offset: 0x0
- Exists: Always

Figure &amp; Table 4-14 Fields for register: CTRLR0

| Bits  | Name           | Access                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|----------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RSVD_CTRLR0    | R                        | SSTE Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 24    | SSTE           | R/W                      | Slave Select Toggle Enable<br>When operating in SPI mode with clock phase (SCPH) set to 0, this register controls the behavior of the slave select line (ss_*_n) between data frames. If this register field is set to 1, the ss_*_n line will toggle between consecutive data frames, with the serial clock (sclk) being held to its default value while ss_*_n is high; if this register field is set to 0, the ss_*_n will stay low and sclk will run continuously for the duration of the transfer.<br>Value After Reset: 1<br>Exists: Always                                                                                                               |
| 23    | RSVD_CTRLR0_23 | R                        | CTRLR0_23 Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 22:21 | SPI_FRF        | R(SPI);<br>R/W(QS<br>PI) | SPI Frame Format<br>Selects data frame format for Transmitting/Receiving the data Bits only valid when SSI_SPI_MODE is either set to "Dual" or "Quad" or "Octal" mode.<br>When SSI_SPI_MODE is configured for "Dual Mode", 10/11 combination is reserved.<br>When SSI_SPI_MODE is configured for "Quad Mode", 11 combination is reserved.<br>Values: <ul style="list-style-type: none"> <li>■ 0x0 (STD_SPI_FRF): Standard SPI frame format</li> <li>■ 0x1 (DUAL_SPI_FRF): Dual SPI frame format</li> <li>■ 0x2 (QUAD_SPI_FRF): Quad SPI frame format</li> <li>■ 0x3 (OCTAL_SPI_FRF): Octal SPI frame format</li> </ul> Value After Reset: 0x0<br>Exists: Always |
| 20:16 | DFS_32         | R/W                      | Data Frame Size in 32-bit transfer size mode. Used to select the data frame size in 32-bit transfer mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>These bits are only valid when SSI_MAX_XFER_SIZE is configured to 32. When the data frame size is programmed to be less than 32 bits, the receive data are automatically right-justified by the receive logic, with the upper bits of the receive FIFO zeropadded. You are responsible for making sure that transmit data is right-justified before writing into the transmit FIFO. The transmit logic ignores the upper unused bits when transmitting the data.</p> <p>Note: When SSI_SPI_MODE is either set to "Dual" or "Quad" or "Octal" mode and SPI_FRF is not set to 2'b00, DFS value should be multiple of 2 if SPI_FRF = 0x01, DFS value should be multiple of 4 if SPI_FRF = 0x10, DFS value should be multiple of 8 if SPI_FRF = 0x11.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x3 (FRAME_04BITS): 4-bit serial data transfer</li><li>■ 0x4 (FRAME_05BITS): 5-bit serial data transfer</li><li>■ 0x5 (FRAME_06BITS): 6-bit serial data transfer</li><li>■ 0x6 (FRAME_07BITS): 7-bit serial data transfer</li><li>■ 0x7 (FRAME_08BITS): 8-bit serial data transfer</li><li>■ 0x8 (FRAME_09BITS): 9-bit serial data transfer</li><li>■ 0x9 (FRAME_10BITS): 10-bit serial data transfer</li><li>■ 0xa (FRAME_11BITS): 11-bit serial data transfer</li><li>■ 0xb (FRAME_12BITS): 12-bit serial data transfer</li><li>■ 0xc (FRAME_13BITS): 13-bit serial data transfer</li><li>■ 0xd (FRAME_14BITS): 14-bit serial data transfer</li><li>■ 0xe (FRAME_15BITS): 15-bit serial data transfer</li><li>■ 0xf (FRAME_16BITS): 16-bit serial data transfer</li><li>■ 0x10 (FRAME_17BITS): 17-bit serial data transfer</li><li>■ 0x11 (FRAME_18BITS): 18-bit serial data transfer</li><li>■ 0x12 (FRAME_19BITS): 19-bit serial data transfer</li><li>■ 0x13 (FRAME_20BITS): 20-bit serial data transfer</li><li>■ 0x14 (FRAME_21BITS): 21-bit serial data transfer</li><li>■ 0x15 (FRAME_22BITS): 22-bit serial data transfer</li><li>■ 0x16 (FRAME_23BITS): 23-bit serial data transfer</li><li>■ 0x17 (FRAME_24BITS): 24-bit serial data transfer</li><li>■ 0x18 (FRAME_25BITS): 25-bit serial data transfer</li><li>■ 0x19 (FRAME_26BITS): 26-bit serial data transfer</li></ul> |

| Bits  | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |        | <ul style="list-style-type: none"> <li>■ 0x1a (FRAME_27BITS): 27-bit serial data transfer</li> <li>■ 0x1b (FRAME_28BITS): 28-bit serial data transfer</li> <li>■ 0x1c (FRAME_29BITS): 29-bit serial data transfer</li> <li>■ 0x1d (FRAME_30BITS): 30-bit serial data transfer</li> <li>■ 0x1e (FRAME_31BITS): 31-bit serial data transfer</li> <li>■ 0x1f (FRAME_32BITS): 32-bit serial data transfer</li> </ul> <p>Value After Reset: 0x7</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15:12 | CFS  | R/W    | <p>Control Frame Size. Selects the length of the control word for the Microwire frame format.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (SIZE_01_BIT): 1-bit control word</li> <li>■ 0x1 (SIZE_02_BIT): 2-bit control word</li> <li>■ 0x2 (SIZE_03_BIT): 3-bit control word</li> <li>■ 0x3 (SIZE_04_BIT): 4-bit control word</li> <li>■ 0x4 (SIZE_05_BIT): 5-bit control word</li> <li>■ 0x5 (SIZE_06_BIT): 6-bit control word</li> <li>■ 0x6 (SIZE_07_BIT): 7-bit control word</li> <li>■ 0x7 (SIZE_08_BIT): 8-bit control word</li> <li>■ 0x8 (SIZE_09_BIT): 9-bit control word</li> <li>■ 0x9 (SIZE_10_BIT): 10-bit control word</li> <li>■ 0xa (SIZE_11_BIT): 11-bit control word</li> <li>■ 0xb (SIZE_12_BIT): 12-bit control word</li> <li>■ 0xc (SIZE_13_BIT): 13-bit control word</li> <li>■ 0xd (SIZE_14_BIT): 14-bit control word</li> <li>■ 0xe (SIZE_15_BIT): 15-bit control word</li> <li>■ 0xf (SIZE_16_BIT): 16-bit control word</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 11    | SRL  | R/W    | <p>Shift Register Loop</p> <p>Used for testing purposes only. When internally active, connects the transmit shift register output to the receive shift register input.</p> <p>Can be used in both serial-slave and serial-master modes.</p> <p>When the DW_apb_ssi is configured as a slave in loopback mode, the ss_in_n and ssi_clk signals must be</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



| Bits | Name   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |        |        | <p>provided by an external source. In this mode, the slave cannot generate these signals because there is nothing to which to loop back.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (TESTING_MODE): Test mode: Tx &amp; Rx shift reg connected</li><li>■ 0x0 (NORMAL_MODE): Normal mode operation</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10   | SLV_OE | -      | <p>Slave Output Enable. Relevant only when the DW_apb_ssi is configured as a serial-slave device. When configured as a serial master, this bit field has no functionality. This bit enables or disables the setting of the ssi_oe_n output from the DW_apb_ssi serial slave. When SLV_OE = 1, the ssi_oe_n output can never be active. When the ssi_oe_n output controls the tri-state buffer on the txd output from the slave, a high impedance state is always present on the slave txd output when SLV_OE = 1.</p> <p>This is useful when the master transmits in broadcast mode (master transmits data to all slave devices). Only one slave may respond with data on the master rxd line. This bit is enabled after reset and must be disabled by software (when broadcast mode is used), if you do not want this device to respond with data.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (DISABLED): Slave Output is disabled.</li><li>■ 0x0 (ENABLED): Slave Output is enabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: No</p> |
| 9:8  | TMOD   | R/W    | <p>Transfer Mode</p> <p>Selects the mode of transfer for serial communication. This field does not affect the transfer duplicity. Only indicates whether the receive or transmit data are valid.</p> <p>In transmit-only mode, data received from the external device is not valid and is not stored in the receive FIFO memory; it is overwritten on the next transfer.</p> <p>In receive-only mode, transmitted data are not valid. After the first write to the transmit FIFO, the same word is retransmitted for the duration of the transfer.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | <p>In transmit-and-receive mode, both transmit and receive data are valid. The transfer continues until the transmit FIFO is empty. Data received from the external device are stored into the receive FIFO memory, where it can be accessed by the host processor.</p> <p>In eeprom-read mode, receive data is not valid while control data is being transmitted. When all control data is sent to the EEPROM, receive data becomes valid and transmit data becomes invalid. All data in the transmit FIFO is considered control data in this mode. This transfer mode is only valid when the DW_apb_ssi is configured as master device.</p> <p>00- Transmit &amp; Receive<br/>01- Transmit Only<br/>10- Receive Only<br/>11- EEPROM Read</p> <p>When SSI_SPI_MODE is either set to "Dual" or "Quad" or "Octal" mode and SPI_FRF is not set to 2'b00. There are only two valid combinations:</p> <p>10 - Read<br/>01 - Write</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (TX_AND_RX): Transmit &amp; Receive</li><li>■ 0x1 (TX_ONLY): Transmit Only or Write</li><li>■ 0x2 (RX_ONLY): Receive Only or Read</li><li>■ 0x3 (EEPROM_READ): EEPROM Read</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 7    | SCPOL | R/W    | <p>Serial Clock Polarity</p> <p>Valid when the frame format (FRF) is set to Motorola SPI. Used to select the polarity of the inactive serial clock, which is held inactive when the DW_apb_ssi master is not actively transferring data on the serial bus.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (SCLK_LOW): Inactive state of serial clock is low.</li><li>■ 0x1 (SCLK_HIGH): Inactive state of serial clock is high.</li></ul> <p>Value After Reset: 0x0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6    | SCPH | R/W    | <p>Serial Clock Phase</p> <p>Valid when the frame format (FRF) is set to Motorola SPI. The serial clock phase selects the relationship of the serial clock with the slave select signal.</p> <p>When SCPH = 0, data are captured on the first edge of the serial clock. When SCPH = 1, the serial clock starts toggling one cycle after the slave select line is activated, and data are captured on the second edge of the serial clock.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (SCPH_MIDDLE): Serial clock toggles in middle of first data bit.</li><li>■ 0x1 (SCPH_START): Serial clock toggles at start of first data bit.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |
| 5:4  | FRF  | R/W    | <p>Frame Format</p> <p>Selects which serial protocol transfers the data.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (MOTOROLA_SPI): Motorola SPI frame format</li><li>■ 0x1 (TEXAS_SSP): Texas Instruments SSP frame format</li><li>■ 0x2 (NS_MICROWIRE): National Microwire frame format</li><li>■ 0x3 (RESERVED): Reserved value</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                 |
| 3:0  | DFS  | R      | <p>Data Frame Size</p> <p>This register field is only valid when SSI_MAX_XFER_SIZE is configured to 16. If SSI_MAX_XFER_SIZE is configured to 32, then writing to this field will not have any effect.</p> <p>Selects the data frame length. When the data frame size is programmed to be less than 16 bits, the receive data are automatically right-justified by the receive logic, with the upper bits of the receive FIFO zero-padded.</p> <p>You must right-justify transmit data before writing into</p>                                                                                                                                                                                                       |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>the transmit FIFO. The transmit logic ignores the upper unused bits when transmitting the data.</p> <p>Note: When SSI_SPI_MODE is either set to "Dual" or "Quad" or "Octal" mode and SPI_FRF is not set to 2'b00. DFS value should be multiple of 2 if SPI_FRF = 01, DFS value should be multiple of 4 if SPI_FRF = 10, DFS value should be multiple of 8 if SPI_FRF = 11.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x3 (FRAME_04BITS): 4-bit serial data transfer</li> <li>■ 0x4 (FRAME_05BITS): 5-bit serial data transfer</li> <li>■ 0x5 (FRAME_06BITS): 6-bit serial data transfer</li> <li>■ 0x6 (FRAME_07BITS): 7-bit serial data transfer</li> <li>■ 0x7 (FRAME_08BITS): 8-bit serial data transfer</li> <li>■ 0x8 (FRAME_09BITS): 9-bit serial data transfer</li> <li>■ 0x9 (FRAME_10BITS): 10-bit serial data transfer</li> <li>■ 0xa (FRAME_11BITS): 11-bit serial data transfer</li> <li>■ 0xb (FRAME_12BITS): 12-bit serial data transfer</li> <li>■ 0xc (FRAME_13BITS): 13-bit serial data transfer</li> <li>■ 0xd (FRAME_14BITS): 14-bit serial data transfer</li> <li>■ 0xe (FRAME_15BITS): 15-bit serial data transfer</li> <li>■ 0xf (FRAME_16BITS): 16-bit serial data transfer</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.2 CTRLR1

- Name: Control Register 1
- Description: This register exists only when the DW\_apb\_ssi is configured as a master device. When the DW\_apb\_ssi is configured as a serial slave, writing to this location has no effect; reading from this location returns 0. Control register 1 controls the end of serial transfers when in receive-only mode. It is impossible to write to this register when the DW\_apb\_ssi is enabled. The DW\_apb\_ssi is enabled and disabled by writing to the SSIENR register.
- Size: 32 bits
- Offset: 0x4
- Exists: Yes

Figure &amp; Table 4-15 Fields for register: CTRLR1

| Bits  | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RSVD_CTRLR1 | R      | <p>CTRLR1 Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0  | NDF         | R/W    | <p>Number of Data Frames</p> <p>When TMOD = 10 or TMOD = 11, this register field sets the number of data frames to be continuously received by the DW_apb_ssi. The DW_apb_ssi continues to receive serial data until the number of data frames received is equal to this register value plus 1, which enables you to receive up to 64 KB of data in a continuous transfer.</p> <p>When the DW_apb_ssi is configured as a serial slave, the transfer continues for as long as the slave is selected. Therefore, this register serves no purpose and is not present when the DW_apb_ssi is configured as a serial slave.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.3 SSIENR

- Name: SSI Enable Register
- Description: This register enables and disables the DW\_apb\_ssi.
- Size: 32 bits
- Offset: 0x8
- Exists: Always

Figure &amp; Table 4-16 Fields for register: SSIENR

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RSVD_SSIENR | R      | <p>SSIENR Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                             |
| 0    | SSI_EN      | R/W    | <p>SSI Enable</p> <p>Enables and disables all DW_apb_ssi operations. When disabled, all serial transfers are halted immediately. Transmit and receive FIFO buffers are cleared when the device is disabled. It is impossible to program some of the DW_apb_ssi control registers when enabled. When disabled, the ssi_sleep output is set (after delay) to inform the system that it is safe to remove the ssi_clk,</p> |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                         |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>thus saving power consumption in the system.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLE): Disables serial transfer.</li><li>■ 0x1 (ENABLED): Enables serial transfer.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.4 SER

- Name: Slave Enable Register
- Description: This register is valid only when the DW\_apb\_ssi is configured as a master device. When the DW\_apb\_ssi is configured as a serial slave, writing to this location has no effect; reading from this location returns 0. The register enables the individual slave select output lines from the DW\_apb\_ssi master. Up to 16 slave-select output pins are available on the DW\_apb\_ssi master. Register bits can be set or cleared when SSI\_EN=0. If SSI\_EN=1, then register bits can be set (to delay the slave select assertion while TX FIFO is getting filled) but cannot be cleared.
- Size: 32 bits
- Offset: 0x10
- Exists: Yes

Figure & Table 4-17 Fields for register: SER

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RSVD_SER | R      | <p>SER Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3:0  | SER      | R/W    | <p>Slave Select Enable Flag</p> <p>Each bit in this register corresponds to a slave select line (ss_x_n) from the DW_apb_ssi master. When a bit in this register is set (1), the corresponding slave select line from the master is activated when a serial transfer begins. It should be noted that setting or clearing bits in this register have no effect on the corresponding slave select outputs until a transfer is started. Before beginning a transfer, you should enable the bit in this register that corresponds to the slave device with which the master wants to communicate. When not operating in broadcast mode, only one bit in this field should be set.</p> <p>Values:</p> |



| Bits | Name | Access | Description                                                                                                                                                                       |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <ul style="list-style-type: none"> <li>■ 0x0 (NOT_SELECTED): No slave selected.</li> <li>■ 0x1 (SELECTED): Slave is selected.</li> </ul> Value After Reset: 0x0<br>Exists: Always |

#### 4.6.1.5 BAUDR

- Name: Baud Rate Select
- Description: This register is valid only when the DW\_apb\_ssi is configured as a master device. When the DW\_apb\_ssi is configured as a serial slave, writing to this location has no effect; reading from this location returns 0. The register derives the frequency of the serial clock that regulates the data transfer. The 16-bit field in this register defines the ssi\_clk divider value. It is impossible to write to this register when the DW\_apb\_ssi is enabled. The DW\_apb\_ssi is enabled and disabled by writing to the SSIENR register.
- Size: 32 bits
- Offset: 0x14
- Exists: Yes

Figure & Table 4-18 Fields for register: BAUDR

| Bits  | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RSVD_BAUDR | R      | BAUDR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:0  | SCKDV      | R/W    | SSI Clock Divider<br>The LSB for this field is always set to 0 and is unaffected by a write operation, which ensures an even value is held in this register. If the value is 0, the serial output clock (sclk_out) is disabled. The frequency of the sclk_out is derived from the following equation:<br>$Fsclk_{out} = Fssi_{clk}/SCKDV$ where SCKDV is any even value between 2 and 65534.<br>For example:<br>for $Fssi_{clk} = 3.6864\text{MHz}$ and $SCKDV = 2$ ,<br>$Fsclk_{out} = 3.6864/2 = 1.8432\text{MHz}$<br>Value After Reset: 0x0<br>Exists: Always |

#### 4.6.1.6 TXFTLR

- Name: Transmit FIFO Threshold Level

- Description: This register controls the threshold value for the transmit FIFO memory. The DW\_apb\_ssi is enabled and disabled by writing to the SSIENR register.
- Size: 32 bits
- Offset: 0x18
- Exists: Always

Figure &amp; Table 4-19 Fields for register: TXFTLR

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RSVD_TXFTLR | R      | TXFTLR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7:0  | TFT         | R/W    | Transmit FIFO Threshold<br>Controls the level of entries (or below) at which the transmit FIFO controller triggers an interrupt. The FIFO depth is configurable in the range 2-256; this register is sized to the number of address bits needed to access the FIFO. If you attempt to set this value greater than or equal to the depth of the FIFO, this field is not written and retains its current value. When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt is triggered. For information on the Transmit FIFO Threshold values, see the "Master SPI and SSP Serial Transfers" in the DW_apb_ssi Databook.<br>ssi_txe_intr is asserted when TFT or less data entries are present in transmit FIFO.<br>Value After Reset: 0x0<br>Exists: Always |

#### 4.6.1.7 RXFTLR

- Name: Receive FIFO Threshold Level
- Description: This register controls the threshold value for the receive FIFO memory. The DW\_apb\_ssi is enabled and disabled by writing to the SSIENR register.
- Size: 32 bits
- Offset: 0x1c
- Exists: Always

Figure &amp; Table 4-20 Fields for register: RXFTLR

| Bits | Name        | Access | Description                                                |
|------|-------------|--------|------------------------------------------------------------|
| 31:8 | RSVD_RXFTLR | R      | RXFTLR Reserved bits - Read Only<br>Value After Reset: 0x0 |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:0  | RFT  | R/W    | <p>Receive FIFO Threshold</p> <p>Controls the level of entries (or above) at which the receive FIFO controller triggers an interrupt. The FIFO depth is configurable in the range 2-256. This register is sized to the number of address bits needed to access the FIFO. If you attempt to set this value greater than the depth of the FIFO, this field is not written and retains its current value. When the number of receive FIFO entries is greater than or equal to this value + 1, the receive FIFO full interrupt is triggered. For information on the Receive FIFO Threshold values, see the "Master SPI and SSP Serial Transfers" in the DW_apb_ssi Databook.</p> <p>ssi_rxf_intr is asserted when RFT or more data entries are present in receive FIFO.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.8 TXFLR

- Name: Transmit FIFO Level Register
- Description: This register contains the number of valid data entries in the transmit FIFO memory.
- Size: 32 bits
- Offset: 0x20
- Exists: Always

Figure & Table 4-21 Fields for register: TXFLR

| Bits | Name       | Access | Description                                                                                                                                                                 |
|------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RSVD_TXFLR | R      | <p>TXFLR Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: true</p>                                                            |
| 8:0  | TXTFL      | R      | <p>Transmit FIFO Level</p> <p>Contains the number of valid data entries in the transmit FIFO.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

#### 4.6.1.9 RXFLR

- Name: Receive FIFO Level Register
- Description: This register contains the number of valid data entries in the receive FIFO memory. This register can be ready at any time.
- Size: 32 bits
- Offset: 0x24
- Exists: Always

Figure &amp; Table 4-22 Fields for register: RXFLR

| Bits | Name       | Access | Description                                                                                                                                        |
|------|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RSVD_RXFLR | R      | RXFLR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True                                                      |
| 8:0  | RXTFL      | R      | Receive FIFO Level<br>Contains the number of valid data entries in the receive FIFO.<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True |

#### 4.6.1.10 SR

- Name: Status Register
- Description: This is a read-only register used to indicate the current transfer status, FIFO status, and any transmission/reception errors that may have occurred. The status register may be read at any time. None of the bits in this register request an interrupt.
- Size: 32 bits
- Offset: 0x28
- Exists: Always

Figure &amp; Table 4-23 Fields for register: SR

| Bits | Name    | Access | Description                                                                                |
|------|---------|--------|--------------------------------------------------------------------------------------------|
| 31:7 | RSVD_SR | R      | SR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True |
| 6    | DCOL    | R      | Data Collision Error<br>Relevant only when the DW_apb_ssi is configured as a               |

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>master device. This bit will be set if ss_in_n input is asserted by other master, when the DW_apb_ssi master is in the middle of the transfer. This informs the processor that the last data transfer was halted before completion. This bit is cleared when read.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (NO_ERROR_CONDITION): No error</li> <li>■ 0x1 (TX_COLLISION_ERROR): Transmit data collision error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> <p>Volatile: True</p> |
| 5    | TXE  | R      | <p>Transmission Error</p> <p>Set if the transmit FIFO is empty when a transfer is started. This bit can be set only when the DW_apb_ssi is configured as a slave device. Data from the previous transmission is resent on the txd line. This bit is cleared when read.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (NO_ERROR): No error</li> <li>■ 0x1 (TX_ERROR): Transmission error</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: No</p> <p>Volatile: True</p>                                |
| 4    | RFF  | R      | <p>Receive FIFO Full</p> <p>When the receive FIFO is completely full, this bit is set. When the receive FIFO contains one or more empty location, this bit is cleared.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (NOT_FULL): Receive FIFO is not full.</li> <li>■ 0x1 (FULL): Receive FIFO is full.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                            |
| 3    | RFNE | R      | <p>Receive FIFO Not Empty</p> <p>Set when the receive FIFO contains one or more entries and is cleared when the receive FIFO is empty. This bit can be polled by software to completely empty the</p>                                                                                                                                                                                                                                                                                                                     |



| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>receive FIFO.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (EMPTY): Receive FIFO is empty.</li><li>■ 0x1 (NOT_EMPTY): Receive FIFO is not empty.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                           |
| 2    | TFE  | R      | <p>Transmit FIFO Empty</p> <p>When the transmit FIFO is completely empty, this bit is set. When the transmit FIFO contains one or more valid entries, this bit is cleared. This bit field does not request an interrupt.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (NOT_EMPTY): Transmit FIFO is not empty.</li><li>■ 0x1 (EMPTY): Transmit FIFO is empty.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> <p>Volatile: True</p> |
| 1    | TFNF | R      | <p>Transmit FIFO Not Full</p> <p>Set when the transmit FIFO contains one or more empty locations, and is cleared when the FIFO is full.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (FULL): Transmit FIFO is full.</li><li>■ 0x1 (NOT_FULL): Transmit FIFO is not full.</li></ul> <p>Value After Reset: 0x1</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                      |
| 0    | BUSY | R      | <p>SSI Busy Flag</p> <p>When set, indicates that a serial transfer is in progress; when cleared indicates that the DW_apb_ssi is idle or disabled.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (INACTIVE): DW_apb_ssi is idle or disabled.</li><li>■ 0x1 (ACTIVE): DW_apb_ssi is actively transferring data.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                       |



| Bits | Name | Access | Description    |
|------|------|--------|----------------|
|      |      |        | Volatile: True |

#### 4.6.1.11 IMR

- Name: Interrupt Mask Register
- Description: This read/write register masks or enables all interrupts generated by the DW\_apb\_ssi. When the DW\_apb\_ssi is configured as a slave device, the MSTIM bit field is not present. This changes the reset value from 0x3F for serial-master configurations to 0x1F for serial-slave configurations.
- Size: 32 bits
- Offset: 0x2c
- Exists: Always

Figure & Table 4-24 Fields for register: IMR

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                      |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RSVD_IMR | R      | IMR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                        |
| 5    | MSTIM    | R/W    | Multi-Master Contention Interrupt Mask. This bit field is not present if the DW_apb_ssi is configured as a serial-slave device.<br>Values: <ul style="list-style-type: none"><li>■ 0x0 (MASKED): ssi_mst_intr interrupt is masked.</li><li>■ 0x1 (UNMASKED): ssi_mst_intr interrupt is not masked.</li></ul> Value After Reset: 1<br>Exists: Yes |
| 4    | RXFIM    | R/W    | Receive FIFO Full Interrupt Mask<br>Values: <ul style="list-style-type: none"><li>■ 0x0 (MASKED): ssi_rxf_intr interrupt is masked.</li><li>■ 0x1 (UNMASKED): ssi_rxf_intr interrupt is not masked.</li></ul> Value After Reset: 0x1<br>Exists: Always                                                                                           |
| 3    | RXOIM    | R/W    | Receive FIFO Overflow Interrupt Mask<br>Values: <ul style="list-style-type: none"><li>■ 0x0 (MASKED): ssi_rxo_intr interrupt is masked.</li><li>■ 0x1 (UNMASKED): ssi_rxo_intr interrupt is not masked.</li></ul>                                                                                                                                |

| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                    |
|------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | <p>masked.<br/>Value After Reset: 0x1<br/>Exists: Always</p>                                                                                                                                                                                                                   |
| 2    | RXUIM | R/W    | <p>Receive FIFO Underflow Interrupt Mask<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (MASKED): ssi_rxu_intr interrupt is masked.</li> <li>■ 0x1 (UNMASKED): ssi_rxu_intr interrupt is not masked.</li> </ul> <p>Value After Reset: 0x1<br/>Exists: Always</p> |
| 1    | TXOIM | R/W    | <p>Transmit FIFO Overflow Interrupt Mask<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (MASKED): ssi_txo_intr interrupt is masked.</li> <li>■ 0x1 (UNMASKED): ssi_txo_intr interrupt is not masked.</li> </ul> <p>Value After Reset: 0x1<br/>Exists: Always</p> |
| 0    | TXEIM | R/W    | <p>Transmit FIFO Empty Interrupt Mask<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (MASKED): ssi_txe_intr interrupt is masked.</li> <li>■ 0x1 (UNMASKED): ssi_txe_intr interrupt is not masked.</li> </ul> <p>Value After Reset: 0x1<br/>Exists: Always</p>    |

#### 4.6.1.12 ISR

- Name: Interrupt Status Register
- Description: This register reports the status of the DW\_apb\_ssi interrupts after they have been masked.
- Size: 32 bits
- Offset: 0x30
- Exists: Always

Figure & Table 4-25 Fields for register: ISR

| Bits | Name     | Access | Description                   |
|------|----------|--------|-------------------------------|
| 31:6 | RSVD_ISR | R      | ISR Reserved bits - Read Only |

| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                                                    |
| 5    | MSTIS | R      | <p>Multi-Master Contention Interrupt Status. This bit field is not present if the DW_apb_ssi is configured as a serial-slave device.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_mst_intr interrupt not active after masking.</li> <li>■ 0x1 (ACTIVE): ssi_mst_intr interrupt is active after masking.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> <p>Volatile: True</p> |
| 4    | RXFIS | R      | <p>Receive FIFO Full Interrupt Status</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_rxf_intr interrupt is not active after masking.</li> <li>■ 0x1 (ACTIVE): ssi_rxf_intr interrupt is full after masking.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                            |
| 3    | RXOIS | R      | <p>Receive FIFO Overflow Interrupt Status</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_rxo_intr interrupt is not active after masking.</li> <li>■ 0x1 (ACTIVE): ssi_rxo_intr interrupt is active after masking.</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                      |
| 2    | RXUIS | R      | <p>Receive FIFO Underflow Interrupt Status</p> <p>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_rxu_intr interrupt is not active after masking.</li> <li>■ 0x1 (ACTIVE): ssi_rxu_intr interrupt is active after masking.</li> </ul>                                                                                                                                                               |

| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                                                     |
|------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | <p>masking.<br/>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: True</p>                                                                                                                                                                                                                                                |
| 1    | TXOIS | R      | <p>Transmit FIFO Overflow Interrupt Status<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_txo_intr interrupt is not active after masking.</li> <li>■ 0x1 (ACTIVE): ssi_txo_intr interrupt is active after masking.</li> </ul> <p>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: True</p> |
| 0    | TXEIS | R      | <p>Transmit FIFO Empty Interrupt Status<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_txe_intr interrupt is not active after masking.</li> <li>■ 0x1 (ACTIVE): ssi_txe_intr interrupt is active after masking.</li> </ul> <p>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: True</p>    |

#### 4.6.1.13 RISR

- Name: Raw Interrupt Status Register
- Description: This read-only register reports the status of the DW\_apb\_ssi interrupts prior to masking.
- Size: 32 bits
- Offset: 0x34
- Exists: Always

Figure & Table 4-26 Fields for register: RISR

| Bits | Name      | Access | Description                                                                                            |
|------|-----------|--------|--------------------------------------------------------------------------------------------------------|
| 31:6 | RSVD_RISR | R      | <p>RISR Reserved bits - Read Only<br/>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: true</p> |



| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | MSTIR | R      | <p>Multi-Master Contention Raw Interrupt Status. This bit field is not present if the DW_apb_ssi is configured as a serial-slave device.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (INACTIVE): ssi_mst_intr interrupt is not active prior to masking.</li><li>■ 0x1 (ACTIVE): ssi_mst_intr interrupt is active prior to masking.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Yes</p> <p>Volatile: True</p> |
| 4    | RXFIR | R      | <p>Receive FIFO Full Raw Interrupt Status</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (INACTIVE): ssi_rxf_intr interrupt is not active prior to masking.</li><li>■ 0x1 (ACTIVE): ssi_rxf_intr interrupt is active prior to masking.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                             |
| 3    | RXOIR | R      | <p>Receive FIFO Overflow Raw Interrupt Status</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x1 (ACTIVE): ssi_rxo_intr interrupt is not active prior to masking.</li><li>■ 0x0 (INACTIVE): ssi_rxo_intr interrupt is active prior to masking.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                         |
| 2    | RXUIR | R      | <p>Receive FIFO Underflow Raw Interrupt Status</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (INACTIVE): ssi_rxu_intr interrupt is not active prior to masking.</li><li>■ 0x1 (ACTIVE): ssi_rxu_intr interrupt is active prior to masking.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                              |

| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                                                            |
|------|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | <p>Volatile: True</p>                                                                                                                                                                                                                                                                                                                  |
| 1    | TXOIR | R      | <p>Transmit FIFO Overflow Raw Interrupt Status<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_txo_intr interrupt is not active prior to masking.</li> <li>■ 0x1 (ACTIVE): ssi_txo_intr interrupt is active prior masking.</li> </ul> <p>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: True</p> |
| 0    | TXEIR | R      | <p>Transmit FIFO Empty Raw Interrupt Status<br/>Values:</p> <ul style="list-style-type: none"> <li>■ 0x0 (INACTIVE): ssi_txe_intr interrupt is not active prior to masking.</li> <li>■ 0x1 (ACTIVE): ssi_txe_intr interrupt is active prior masking.</li> </ul> <p>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: True</p>    |

#### 4.6.1.14 TXOICR

- Name: Transmit FIFO Overflow Interrupt Clear Registers
- Description: Transmit FIFO Overflow Interrupt Clear Register
- Size: 32 bits
- Offset: 0x38
- Exists: Always

Figure & Table 4-27 Fields for register: TXOICR

| Bits | Name        | Access | Description                                                                                                                                                                               |
|------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RSVD_TXOICR | R      | <p>TXOICR Reserved bits - Read Only<br/>Value After Reset: 0x0<br/>Exists: Always<br/>Volatile: True</p>                                                                                  |
| 0    | TXOICR      | R      | <p>Clear Transmit FIFO Overflow Interrupt<br/>This register reflects the status of the interrupt. A read from this register clears the ssi_txo_intr interrupt; writing has no effect.</p> |

| Bits | Name | Access | Description                                                |
|------|------|--------|------------------------------------------------------------|
|      |      |        | Value After Reset: 0x0<br>Exists: Always<br>Volatile: True |

#### 4.6.1.15 RXOICR

- Name: Receive FIFO Overflow Interrupt Clear Register
- Description: Receive FIFO Overflow Interrupt Clear Register
- Size: 32 bits
- Offset: 0x3c
- Exists: Always

Figure &amp; Table 4-28 Fields for register: RXOICR

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                 |
|------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RSVD_RXOICR | R      | RXOICR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True                                                                                                                                                              |
| 0    | RXOICR      | R      | Clear Receive FIFO Overflow Interrupt<br>This register reflects the status of the interrupt. A read from this register clears the <code>ssi_rxo_intr</code> interrupt; writing has no effect.<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True |

#### 4.6.1.16 RXUICR

- Name: Receive FIFO Underflow Interrupt Clear Register
- Description: Receive FIFO Underflow Interrupt Clear Register
- Size: 32 bits
- Offset: 0x40
- Exists: Always

Figure &amp; Table 4-29 Fields for register: RXUICR

| Bits | Name        | Access | Description                                                                  |
|------|-------------|--------|------------------------------------------------------------------------------|
| 31:1 | RSVD_RXUICR | R      | RXUICR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always |

| Bits | Name   | Access | Description                                                                                                                                                                                                                                                                         |
|------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |        |        | Volatile: true                                                                                                                                                                                                                                                                      |
| 0    | RXUICR | R      | <p>Clear Receive FIFO Underflow Interrupt</p> <p>This register reflects the status of the interrupt. A read from this register clears the <code>ssi_rxu_intr</code> interrupt; writing has no effect.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

#### 4.6.1.17 MSTICR

- Name: Multi-Master Interrupt Clear Register
- Description: Multi-Master Interrupt Clear Register
- Size: 32 bits
- Offset: 0x44
- Exists: Always

Figure & Table 4-30 Fields for register: MSTICR

| Bits | Name        | Access | Description                                                                                                                                                                                                                                                                          |
|------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RSVD_MSTICR | R      | <p>MSTICR Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p>                                                                                                                                                                    |
| 0    | MSTICR      | R      | <p>Clear Multi-Master Contention Interrupt</p> <p>This register reflects the status of the interrupt. A read from this register clears the <code>ssi_mst_intr</code> interrupt; writing has no effect.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

#### 4.6.1.18 ICR

- Name: Interrupt Clear Register
- Description: Interrupt Clear Register
- Size: 32 bits
- Offset: 0x48
- Exists: Always

Figure &amp; Table 4-31 Fields for register: ICR

| Bits | Name     | Access | Description                                                                                                                                                                                                                                                                             |
|------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RSVD_ICR | R      | ICR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True                                                                                                                                                                                             |
| 0    | ICR      | R      | Clear Interrupts.<br>This register is set if any of the interrupts below are active. A read clears the ssi_txo_intr, ssi_rxu_intr, ssi_rxo_intr, and the ssi_mst_intr interrupts. Writing to this register has no effect.<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: True |

#### 4.6.1.19 DMACR

- Name: DMA Control Register
- Description: This register is only valid when DW\_apb\_ssi is configured with a set of DMA Controller interface signals (SSI\_HAS\_DMA = 1). When DW\_apb\_ssi is not configured for DMA operation, this register will not exist and writing to the register's address will have no effect; reading from this register address will return zero. The register is used to enable the DMA Controller interface operation.
- Size: 32 bits
- Offset: 0x4c
- Exists: Yes

Figure &amp; Table 4-32 Fields for register: DMACR

| Bits | Name       | Access | Description                                                                                                                                                                                                                                              |
|------|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RSVD_DMACR | R      | DMACR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                              |
| 1    | TDMAE      | R/W    | Transmit DMA Enable<br>This bit enables/disables the transmit FIFO DMA channel.<br>Values: <ul style="list-style-type: none"><li>■ 0x0 (DISABLE): Transmit DMA disabled.</li><li>■ 0x1 (ENABLED): Transmit DMA enabled.</li></ul> Value After Reset: 0x0 |



| Bits | Name  | Access | Description                                                                                                                                                                                                                                                                                      |
|------|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |        | Exists: Always                                                                                                                                                                                                                                                                                   |
| 0    | RDMAE | R/W    | <p>Receive DMA Enable</p> <p>This bit enables/disables the receive FIFO DMA channel.</p> <p>Values:</p> <ul style="list-style-type: none"><li>■ 0x0 (DISABLE): Receive DMA disabled.</li><li>■ 0x1 (ENABLED): Receive DMA enabled.</li></ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.20 DMATDLR

- Name: DMA Transmit Data Level
- Description: This register is only valid when the DW\_apb\_ssi is configured with a set of DMA interface signals (SSI\_HAS\_DMA = 1). When DW\_apb\_ssi is not configured for DMA operation, this register will not exist and writing to its address will have no effect; reading from its address will return zero.
- Size: 32 bits
- Offset: 0x50
- Exists: Yes

Figure & Table 4-33 Fields for register: DMATDLR

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RSVD_DMATDLR | R      | <p>DMATDLR Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:0  | DMATDL       | R/W    | <p>Transmit Data Level</p> <p>This bit field controls the level at which a DMA request is made by the transmit logic. It is equal to the watermark level; that is, the <code>dma_tx_req</code> signal is generated when the number of valid data entries in the transmit FIFO is equal to or below this field value, and <code>TDMAE</code> = 1. For information on the DMATDL decode values, see the "Slave SPI and SSP Serial Transfers" section in the DW_apb_ssi Databook. <code>dma_tx_req</code> is asserted when DMATDL or less data entries are present in the transmit FIFO</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.21 DMARDLR

- Name: DMA Receive Data Level
- Description: This register is only valid when DW\_apb\_ssi is configured with a set of DMA interface signals (SSI\_HAS\_DMA = 1). When DW\_apb\_ssi is not configured for DMA operation, this register will not exist and writing to its address will have no effect; reading from its address will return zero.
- Size: 32 bits
- Offset: 0x54
- Exists: Yes

Figure &amp; Table 4-34 Fields for register: DMARDLR

| Bits | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RSVD_DMARDLR | R      | DMARDLR Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:0  | DMARDL       | R/W    | Receive Data Level<br>This bit field controls the level at which a DMA request is made by the receive logic. The watermark level = DMARDL+1; that is, dma_rx_req is generated when the number of valid data entries in the receive FIFO is equal to or above this field value + 1, and RDMAE=1. For information on the DMARDL decode values, see the "Slave SPI and SSP Serial Transfers" section in the DW_apb_ssi Databook.<br>dma_rx_req is asserted when DMARDL or more valid data entries are present in the receive FIFO.<br>Value After Reset: 0x0<br>Exists: Always |

#### 4.6.1.22 IDR

- Name: Identification Register
- Description: This register contains the peripherals identification code, which is written into the register at configuration time using CoreConsultant.
- Size: 32 bits
- Offset: 0x58
- Exists: Always

Figure &amp; Table 4-35 Fields for register: IDR

| Bits | Name   | Access | Description         |
|------|--------|--------|---------------------|
| 31:0 | IDCODE | R      | Identification code |

| Bits | Name | Access | Description                                                                                                                                                                                                   |
|------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |        | <p>The register contains the peripheral's identification code, which is written into the register at configuration time using CoreConsultant.</p> <p>Value After Reset: 0xffff_ffff</p> <p>Exists: Always</p> |

#### 4.6.1.23 SSI\_VERSION\_ID

- Name: coreKit version ID Register
- Description: This read-only register stores the specific DW\_apb\_ssi component version.
- Size: 32 bits
- Offset: 0x5c
- Exists: Always

Figure & Table 4-36 Fields for register: SSI\_VERSION\_ID

| Bits | Name             | Access | Description                                                                                                                                                                                                                                                         |
|------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | SSI_COMP_VERSION | R      | <p>Contains the hex representation of the Synopsys component version. Consists of ASCII value for each number in the version, followed by *. For example, 32_30_31_2A represents the version 2.01*.</p> <p>Value After Reset: 0x3430_322a</p> <p>Exists: Always</p> |

#### 4.6.1.24 DRx (for x = 0; x <= 35)

- Name: Data Register x
- Description: The DW\_apb\_ssi data register is a 16/32-bit (depending on SSI\_MAX\_XFER\_SIZE) read/write buffer for the transmit/receive FIFOs. If the configuration parameter SSI\_MAX\_XFER\_SIZE is set to 32, then all 32 bits are valid, otherwise, only 16 bits ([15:0]) of the register are valid. When the register is read, data in the receive FIFO buffer is accessed. When it is written to, data are moved into the transmit FIFO buffer; a write can occur only when SSI\_EN = 1. FIFOs are reset when SSI\_EN = 0. NOTE: The DR register in the DW\_apb\_ssi occupies thirty-six 32-bit address locations of the memory map to facilitate AHB burst transfers. Writing to any of these address locations has the same effect as pushing the data from the pldata bus into the transmit FIFO. Reading from any of these locations has the same effect as popping data from the receive FIFO onto the pldata bus. The FIFO buffers on the DW\_apb\_ssi are not addressable.
- Size: 32 bits
- Offset: 0x60
- Exists: Always

Figure &amp; Table 4-37 Fields for register: DRx (for x = 0; x &lt;= 35)

| Bits | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DR   | R/W    | <p>Data Register. When writing to this register, you must right-justify the data. Read data are automatically right-justified. If <code>SSI_MAX_XFER_SIZE</code> configuration parameter is set to 32, all 32 bits are valid. Otherwise, only 16 bits ([15:0]) of the register are valid. Read = Receive FIFO buffer Write = Transmit FIFO buffer.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> <p>Volatile: True</p> |

#### 4.6.1.25 RX\_SAMPLE\_DLY

- Name: RX Sample Delay Register
- Description: This register is only valid when the DW\_apb\_ssi is configured with rxd sample delay logic (`SSI_HAS_RX_SAMPLE_DELAY==1`). When the DW\_apb\_ssi is not configured with rxd sample delay logic, this register will not exist and writing to its address location will have no effect; reading from its address will return zero. This register controls the number of `ssi_clk` cycles that are delayed (from the default sample time) before the actual sample of the rxd input occurs. It is impossible to write to this register when the DW\_apb\_ssi is enabled. The DW\_apb\_ssi is enabled and disabled by writing to the `SSIENR` register.
- Size: 32 bits
- Offset: 0xf0
- Exists: Yes

Figure &amp; Table 4-38 Fields for register: RX\_SAMPLE\_DLY

| Bits | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|--------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RSVD_RX_SAMPLE_DLY | R      | <p>SAMPLE_DLY Reserved bits - Read Only</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                                                                                                                                       |
| 7:0  | RSD                | R/W    | <p>Rxd Sample Delay</p> <p>This register is used to delay the sample of the rxd input port. Each value represents a single <code>ssi_clk</code> delay on the sample of rxd.</p> <p>Note: If this register is programmed with a value that exceeds the depth of the internal shift registers (<code>SSI_RX_DLY_SR_DEPTH</code>), zero delay will be applied to the rxd sample.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |

#### 4.6.1.26 SPI\_CTRLR0

- Name: SPI Control Register
- Description: This register is valid only when SSI\_SPI\_MODE is either set to "Dual" or "Quad" or "Octal" mode. This register is used to control the serial data transfer in SPI mode of operation. The register is only relevant when SPI\_FRF is set to either 01 or 10 or 11. It is not possible to write to this register when the DW\_apb\_ssi is enabled (SSI\_EN=1). The DW\_apb\_ssi is enabled and disabled by writing to the SSIENR register.
- Size: 32 bits
- Offset: 0xf4
- Exists: QSPI Only

Figure &amp; Table 4-39 Fields for register: SPI\_CTRLR0

| Bits  | Name            | Access | Description                                                                                                                                                                                                                                                                                                |
|-------|-----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RSVD_SPI_CTRLR0 | R      | SPI_CTRLR0 Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                           |
| 18    | SPI_RXDS_EN     | R      | Read data strobe enable bit<br>Once this bit is set to 1, DW_apb_ssi will use Read data strobe (rxds) to capture read data in DDR mode.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                        |
| 17    | INST_DDR_EN     | R      | Instruction DDR enable bit<br>This will enable Dual-data rate transfer for Instruction phase.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                  |
| 16    | SPI_DDR_EN      | R      | SPI DDR enable bit<br>This will enable Dual-data rate transfers in Dual/Quad/Octal frame formats of SPI.<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                       |
| 15:11 | WAIT_CYCLES     | R/W    | Wait cycles<br>Number of wait cycles in Dual/Quad/Octal mode between control frames transmit and data reception.<br>This value is specified as number of SPI clock cycles. For information on the WAIT_CYCLES decode value, see "Read Operation in Enhanced SPI Modes" section in the DW_apb_ssi Databook. |

| Bits | Name                | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     |        | Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10   | RSVD_SPI_CTRLR0_10  | R      | CTRLR0_10 Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9:8  | INST_L              | R/W    | Instruction Length<br>Dual/Quad/Octal mode instruction length in bits.<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (INST_L_0): 0-bit (No Instruction)</li> <li>■ 0x1 (INST_L_1): 4-bit instruction</li> <li>■ 0x2 (INST_L_2): 8-bit instruction</li> <li>■ 0x3 (INST_L_3): 16-bit instruction</li> </ul> Value After Reset: 0x2<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:6  | RSVD_SPI_CTRLR0_6_7 | R      | CTRLR0_6_7 Reserved bits - Read Only<br>Value After Reset: 0x0<br>Exists: Always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5:2  | ADDR_L              | R/W    | Address Length<br>This bit defines Length of Address to be transmitted. Only after this much bits are programmed into the FIFO, the transfer can begin. For information on the ADDR_Ldecode value, see "Read Operation in Enhanced SPI Modes" section in the DW_apb_ssi Databook.<br>Values:<br><ul style="list-style-type: none"> <li>■ 0x0 (ADDR_L_0): 0-bit address width</li> <li>■ 0x1 (ADDR_L_1): 4-bit address width</li> <li>■ 0x2 (ADDR_L_2): 8-bit address width</li> <li>■ 0x3 (ADDR_L_3): 12-bit address width</li> <li>■ 0x4 (ADDR_L_4): 16-bit address width</li> <li>■ 0x5 (ADDR_L_5): 20-bit address width</li> <li>■ 0x6 (ADDR_L_6): 24-bit address width</li> <li>■ 0x7 (ADDR_L_7): 28-bit address width</li> <li>■ 0x8 (ADDR_L_8): 32-bit address width</li> <li>■ 0x9 (ADDR_L_9): 36-bit address width</li> <li>■ 0xa (ADDR_L_10): 40-bit address width</li> </ul> |

| Bits | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |        | <ul style="list-style-type: none"> <li>■ 0xb (ADDR_L_11): 44-bit address width</li> <li>■ 0xc (ADDR_L_12): 48-bit address width</li> <li>■ 0xd (ADDR_L_13): 52-bit address width</li> <li>■ 0xe (ADDR_L_14): 56-bit address width</li> <li>■ 0xf (ADDR_L_15): 60-bit address width</li> </ul> <p>Value After Reset: 0x0</p> <p>Exists: Always</p>                                                                                                                                                                                                                 |
| 1:0  | TRANS_TYPE | R/W    | <p>Address and instruction transfer format</p> <p>Selects whether DW_apb_ssi will transmit instruction/address either in Standard SPI mode or the SPI mode selected in CTRLR0.SPI_FRF field.</p> <p>00: Instruction and address will be sent in Standard SPI Mode.</p> <p>01: Instruction will be sent in Standard SPI Mode and address will be sent in the mode specified by CTRLR0.SPI_FRF.</p> <p>10: Both instruction and address will be sent in the mode specified by SPI_FRF.</p> <p>11: Reserved.</p> <p>Value After Reset: 0x0</p> <p>Exists: Always</p> |