# **SK hynix e-NAND Product Family eMMC5.1 Compatible** ## **Revision History** | Revision No. | History | Date | Remark | |--------------|--------------------|---------------|--------| | 0.1 | - Preliminary | May. 29, 2017 | | | 1.0 | - Official release | Sep. 07, 2017 | | ## **Table of Contents** | 1. Introduction | 4 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | 1.1 General Description | | | 1.2 Product Line-up | | | 1.3 Key Features | 4 | | 2. Package Configurations | 5 | | 2.1 Pin connection | 5 | | 2.2 Package Mechanical Drawing | | | 3. e-NAND Characteristics | 9 | | 3.1 Performance | | | 4 a NAND now fortures (aMMCE 0 and aMMCE 1) | 12 | | 4. e-NAND new features (eMMC5.0 and eMMC5.1) | | | <b>4.1 eMMC5.0 New features</b> | | | 4.1.1 ris400 mode | | | 4.1.3 Health Report | | | 4.1.4 Sleep Notification | | | 4.1.5 Secure Removal type | | | 4.2 eMMC5.1 New features | | | 4.2.1 Command queuing | | | 4.2.2 Cache Barrier | | | 4.2.3 Cache Flushing report | | | 4.2.4 Background operation(BKOP) control | | | 4.2.5 Secure Write Protection | 32 | | 4.2.6 Enhanced strobe | | | 4.2.7 RPMB throughput improvement | | | 4.3 Enhanced features from eMMC4.5 to eMMC5.1 | 42 | | 5. e-NAND general parameters | | | 5.1 Timing | | | 5.2 Bus signal | | | 5.3 Power mode | | | 5.4 Connection guide | 55 | | 6. e-NAND basic operations | | | 6.1 Partitioning | | | 6.2 Boot operation | | | 7. Timeout | 60 | | 8. Register | | | 8.1 Operation conditions register (OCR) | | | 8.2 Card identification (CID) register | | | 8.3 Card specific data register(CSD) | | | 8.4 Extended CSD register | | | 8.6 DSR (Driver Stage Register) | | | or sort (since stage register) information and the stage register of | / 2 | #### 1. Introduction #### 1.1 General Description SK Hynix e-NAND is compatible with JEDEC standard eMMC5.1 specifications. e-NAND has the built-in intelligent controller which manages interface protocols, wear leveling, bad block management, garbage collection, and ECC. e-NAND protects the data contents from the host sudden power off failure. #### 1.2 Product Line-up | Density | Part Number | NAND Stack | PKG Size (mm) | Package Type | |---------|--------------|------------|---------------|--------------| | 16GB | H26M51002KPR | 128Gb x 1 | 11.5x13x0.8 | | | 32GB | H26M62002JPR | 128Gb x 2 | 11.5x13x0.8 | 153FBGA | | 64GB | H26M74002HMR | 128Gb x 4 | 11.5x13x1.0 | | #### 1.3 Key Features #### • eMMC5.1 compatible (Backward compatible to eMMC4.5&eMMC5.0) #### • Bus mode Data bus width: 1bit(default), 4bits, 8bits Data transfer rate: up to 400MB/s (HS400) MMC I/F Clock frequency: 0~200MHz MMC I/F Boot frequency: 0~52MHz #### Operating Voltage Range - V<sub>cc</sub> (NAND) : 2.7V - 3.6V - V<sub>cca</sub> (Controller) : 1.7V - 1.95V #### • Temperature - Operation (-25°C ~ +85°C) - Storage without operation (-40 $^{\circ}$ ~ +85 $^{\circ}$ ) #### Others - This product is compliance with the RoHS directive #### Supported Features - HS400, HS200 - HPI, BKOPS, BKOP operation control - Packed CMD, CMD queuing - Cache, Cache barrier, Cache flushing report - Partitioning, RPMB, RPMB throughput improve - Discard, Trim, Erase, Sanitize - Write protect, Secure write protection - Lock/Unlock - PON, Sleep/Awake - Reliable Write - Boot feature, Boot partition - HW/SW Reset - Field Firmware Update - Configurable driver strength - Health(Smart) report - Production state awareness - Secure removal type - Data Strobe pin, Enhanced data strobe ## 2. Package Configurations #### 2.1 Pin connection [Figure 1] 153 FBGA Ball Assignment | Pin number | Name | Pin number | Name | Pin number | Name | Pin number | Name | |------------|----------|------------|-----------------|------------|------------------|------------|---------------| | А3 | DAT0 | C4 | $V_{\rm ssq}$ | G10 | VSF | M5 | CMD | | A4 | DAT1 | C6 | $V_{ccq}$ | Н5 | DS | M6 | CLK | | <b>A5</b> | DAT2 | <b>E</b> 6 | V <sub>cc</sub> | H10 | V <sub>ss</sub> | N2 | $V_{\rm ssq}$ | | A6 | $V_{SS}$ | E7 | $V_{SS}$ | J5 | V <sub>ss</sub> | N4 | $V_{ccq}$ | | В2 | DAT3 | E8 | VSF | J10 | V <sub>cc</sub> | N5 | $V_{ssq}$ | | В3 | DAT4 | <b>E9</b> | VSF | K5 | RSTN | Р3 | $V_{ccq}$ | | В4 | DAT5 | E10 | VSF | K8 | V <sub>ss</sub> | P4 | $V_{\rm ssq}$ | | В5 | DAT6 | F5 | $V_{cc}$ | К9 | V <sub>cc</sub> | P5 | $V_{ccq}$ | | В6 | DAT7 | F10 | VSF | K10 | VSF | Р6 | $V_{\rm ssq}$ | | C2 | VDDi | G5 | $V_{SS}$ | M4 | V <sub>ccq</sub> | P10 | VSF | | Name | Туре | Ball No. | Description | | |------------------|---------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | CLK | Input | M6 | Clock: Each cycle directs a 1-bit transfer on the command and DAT lines. | | | CMD | Input | M5 | Command: A bidirectional channel used for device initialization and command transfers. Command has two operating modes: 1) Open-drain for initialization. 2) Push-pull for fast command transfer. | | | DAT0 | I/O | A3 | Data I/O0: Bidirectional channel used for data transfer. | | | DAT1 | I/O | A4 | Data I/O1: Bidirectional channel used for data transfer. | | | DAT2 | I/O | A5 | Data I/O2: Bidirectional channel used for data transfer. | | | DAT3 | I/O | B2 | Data I/O3: Bidirectional channel used for data transfer. | | | DAT4 | I/O | В3 | Data I/O4: Bidirectional channel used for data transfer. | | | DAT5 | I/O | B4 | Data I/O5: Bidirectional channel used for data transfer. | | | DAT6 | I/O | B5 | Data I/O6: Bidirectional channel used for data transfer. | | | DAT7 | I/O | В6 | Data I/O7: Bidirectional channel used for data transfer. | | | RSTN | Input | K5 | Reset signal pin | | | V <sub>cc</sub> | Supply | E6,F5,J10,K9 | V <sub>cc</sub> : Flash memory I/F and Flash memory power supply. | | | V <sub>ccq</sub> | Supply | C6,M4,N4,P3,P5 | V <sub>ccq</sub> : Memory controller core and MMC interface I/O power supply. | | | Vss | Supply | A6,E7,G5,H10,J5,K8 | V <sub>ss</sub> : Flash memory I/F and Flash memory ground connection. | | | Vssq | Supply | C4,N2,N5,P4,P6 | V <sub>ssq</sub> : Memory controller core and MMC I/F ground connection | | | VDDi | | C2 | VDDi: Connect 0.1µF capacitor from VDDi to ground. | | | DS | Out put | H5 | DS: Data Strobe | | | VSF | Supply | E8,E9,E10,F10,<br>G10, K10, P10 | VSF: Vendor Specific Function<br>SK hynix use E9, E10 Pin as VSF Pin | | | RFU | | | Reserved for future use | | [Table 1] 153 FBGA Ball Description ## 2.2 Package Mechanical Drawing #### 2.2.1 11.5mm x13.0mm x0.8mm #### Top view #### **Bottom view** [Figure 2] 11.5mm x 13.0mm x 0.8mm Package dimension #### 2.2.2 11.5mm x13.0mm x1.0mm [Figure 3] 11.5mm x13.0mm x 1.0mm Package dimension ## 3. e-NAND Characteristics ## 3.1 Performance | Density | Sequential Write<br>(MB/s) | Sequential Read<br>(MB/s) | |---------------|----------------------------|---------------------------| | 16GB<br>(SDP) | | | | 32GB<br>(DDP) | 90 | 280 | | 64GB<br>(QDP) | 170 | 280 | Tool : Device level eMMC I/F speed : HS400 Seq. chunk size : 512KB Adapted feature : Cache on • Not 100% tested #### 3.2 Power #### **3.2.1 Active Power Consumption During Operation** | De | nsity | I <sub>cc</sub> | I <sub>ccq</sub> | |-------|-----------|-----------------|------------------| | 16GB | Avg. (mA) | 50 | 200 | | (SDP) | Peak (mA) | 150 | 250 | | 32GB | Avg. (mA) | 80 | 200 | | (DDP) | Peak (mA) | 150 | 250 | | 64GB | Avg. (mA) | 140 | 200 | | (QDP) | Peak (mA) | 250 | 250 | $\bullet$ Temperature : 25 $^\circ\! {\mathbb C}$ Average current consumption : over a period of 100ms Peak current consumption : averaged over a period of 20us Vcc : 3.3V Vccq : 1.8V Not 100% tested #### 3.2.2 Low Power Mode (Idle) | Density Room Temper | | Room Temperature (25℃) | | ature (85℃) | |---------------------|------------|------------------------|-----------------|------------------| | | | I <sub>ccq</sub> | I <sub>cc</sub> | I <sub>ccq</sub> | | 16GB (SDP) | Typ. 30uA | | Max. 50uA | | | 32GB (DDP) | Typ. 60uA | Typ. 120uA | Max. 100uA | Max. 500uA | | 64GB (QDP) | Typ. 120uA | | Max. 200uA | | - $\bullet$ In Standby Power mode, CTRL $V_{ccq}$ & NAND $V_{cc}$ power supply is switched on - No data transaction period before entering sleep status - Not 100% tested. #### 3.2.3 Low Power Mode (CMD5 Sleep) | Density | Room Tempe | rature (25℃) | Hot Temperature (85℃) | | |------------|-----------------|------------------|-----------------------|------------------| | Delisity | I <sub>cc</sub> | I <sub>ccq</sub> | I <sub>cc</sub> | I <sub>ccq</sub> | | 16GB (SDP) | | | | | | 32GB (DDP) | 0 | Typ. 120uA | 0 | Max. 500uA | | 64GB (QDP) | | | | | ullet In Sleep state, triggered by CMD5, NAND $V_{CC}$ power supply is switched off (CTRL $V_{CCQ}$ on) • Not 100% tested. ## 4. e-NAND New features (eMMC5.0 and eMMC5.1) #### 4.1 eMMC5.0 New features #### 4.1.1 HS400 mode e-NAND supports HS400 signaling to achieve a bus speed of 400MB/s via a 200MHz DDR clock frequency. HS400 mode supports only 8-bit bus width and the 1.8V $V_{ccq}$ . Due to the speed, the host may need to have an adjustable sampling point to reliably receive the incoming data (Read Data and CRC Response) with DS pin. e-NAND supports up to 5 Driver Strength. | Driver type values | Support | Nominal<br>Impedance | Approximated driving<br>capability compared to<br>Type_0 | Remark | |--------------------|-----------|----------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------| | 0 | Mandatory | 50 <b>Ω</b> | x 1 | Default Driver Type. Supports up to 200MHz operation. | | 1 | | 33 <b>Ω</b> | x 1.5 | Supports up to 200MHz operation. | | 2 | Optional | 66Ω | x 0.75 | The weakest driver that supports up to 200MHz operation. | | 3 | Ориона | 100 <b>Ω</b> | x 0.5 | For low noise and low EMI systems. Maximal operating frequency is decided by host design. | | 4 | | 40 <b>Ω</b> | x 1.2 | | #### [Table 2] I/O Driver strength types Selecting **HS\_Timing** depends on Host I/F speed, default is 0, but all of value can be selected by host. | Value | Timing | Supportability for e-NAND | |-------|---------------------------------------------------|---------------------------| | 0x00 | Selecting backward compatibility interface timing | Support | | 0x01 | High speed | Support | | 0x02 | HS200 | Support | | 0x03 | HS400 | Support | [Table 3] HS\_Timing values #### 4.1.1.1 Bus timing specification in HS400 mode #### **■ HS400 Device input timing** The CMD input timing for HS400 mode is the same as CMD input timing for HS200 mode. [Figure 4] HS400 Device input timing | Parameter | Symbol | Min | Max | Unit | Remark | |-------------------------------|---------------------|-------|-----|----------|-----------------------------------------------------------------------------------------------------------------| | Data Strobe | | | | <u> </u> | | | Cycle time data transfer mode | t <sub>PERIOD</sub> | 5 | | | 200MHz(Max), between rising edges with respect to $V_{\text{T}}$ | | Slew rate | SR | 1.125 | | V/ns | With respect to $V_{IH}/V_{IL}$ | | Duty cycle<br>distortion | t <sub>CKDCD</sub> | 0.0 | 0.3 | ns | Allowable deviation from an ideal 50% duty cycle. With respect to $V_{\text{T}}$ . Includes jitter, phase noise | | Minimum pulse width | t <sub>CKMPW</sub> | 2.2 | | ns | With respect to V <sub>T</sub> | | Input DAT (reference | ced to CLK) | | | | | | Input set-up time | t <sub>ISUddr</sub> | 0.4 | | ns | $C_{DEVICE} \le 6pF$<br>With respect to $V_{IH}/V_{IL}$ | | Input hold time | t <sub>IHddr</sub> | 0.4 | | ns | $C_{DEVICE} \le 6pF$<br>With respect to $V_{IH}/V_{IL}$ | | Slew rate | SR | 1.125 | | V/ns | With respect to V <sub>IH</sub> /V <sub>IL</sub> | [Table 4] HS400 Device input timing #### **■** HS400 Device output timing Data strobe is for reading data in HS400 mode. Data strobe is toggled only during data read or CRC status response. [Figure 5] HS400 Device output timing | Parameter | Symbol | Min | Max | Unit | Remark | |-------------------------------|---------------------|--------|---------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------| | Data Strobe | | | | | , | | Cycle time data transfer mode | t <sub>PERIOD</sub> | 5 | | | 200MHz(Max), between rising edges with respect to $V_{\text{T}}$ | | Slew rate | SR | 1.125 | | V/ns | With respect to V <sub>OH</sub> /V <sub>OL</sub> and HS400 reference load | | Duty cycle<br>distortion | t <sub>DSDCD</sub> | 0.0 | 0.2 | ns | Allowable deviation from the input CLK duty cycle distortion( $t_{CKDCD}$ ) With respect to $V_{T}$ Includes jitter, phase noise | | Minimum pulse width | t <sub>DSMPW</sub> | 2.0 | | ns | With respect to V <sub>T</sub> | | Read pre-amble | t <sub>RPRE</sub> | 0.4 | 5 (One<br>Clock Cycle) | t <sub>PERIOD</sub> | Max value is specified by manufacturer. value up to infinite is valid. | | Read post-amble | t <sub>RPST</sub> | 0.4 | 2.5 (Half<br>Clock Cycle) | t <sub>PERIOD</sub> | Max value is specified by manufacturer. value up to infinite is valid. | | Output DAT (refere | nced to Data s | trobe) | | | | | Output skew | t <sub>RQ</sub> | | 0.4 | ns | With respect to $V_{OH}/V_{OL}$ and HS400 reference load | | Output hold skew | t <sub>RQH</sub> | | 0.4 | ns | With respect to $V_{OH}/V_{OL}$ and HS400 reference load | | Slew rate | SR | 1.125 | | V/ns | With respect to V <sub>OH</sub> /V <sub>OL</sub> and HS400 reference load | [Table 5] HS400 Device output timing | Parameter | Symbol | Min | Туре | Max | Unit | Remark | |---------------------------------------|---------------------|-----|------|-----|------|--------| | Pull-up resistance for CMD | $R_{CMD}$ | 4.7 | | 100 | Kohm | | | Pull-up resistance for DAT0-7 | R <sub>DAT</sub> | 10 | | 100 | Kohm | | | Pull-down resistance for Data strobe | R <sub>DS</sub> | 10 | | 100 | Kohm | | | Internal pull up resistance DAT1-DAT7 | R <sub>int</sub> | 10 | | 150 | Kohm | | | Bus signal line capacitance | C <sub>L</sub> | | | 13 | pF | | | Single Device capacitance | C <sub>Device</sub> | | | 6 | pF | | [Table 6] HS400 Device input timing\* <sup>\*</sup> For connection guide, see Table 20. #### ■ Data Strobe for HS400 Data strobe is Return Clock signal used in HS400 mode. This signal is generated by the device and used for data output and CRC status response output in HS400 mode. The frequency of this signal follows the frequency of CLK. For data output each cycle of this signal directs two bits transfer(2x) on the data - one bit for positive edge and the other bit for negative edge. For CRC status response output, the CRC status is latched on the positive edge only, and don't care on the negative edge. Data strobe signal is toggled only for Data out and CRC response (Align CMD response as well as CRC response to the DS in eMMC5.1) [Figure 6] HS400 Host and Device block diagram #### 4.1.1.2 HS400 Mode selection Following JEDEC standard for eMMC5.0, changing bus mode directly from HS200 to HS400 is not allowed. It has a rule for changing bus width from SDR mode to DDR mode that HS\_TIMING must be set to "0x01"(HS mode: 52MHz) before setting BUS\_WIDTH for DDR operation. We recommend the HS400 bus mode selection sequence as following. (eMMC5.1 has basically same flow, but 'enhanced strobe feature' is added. Please refer to 4.2.6 Enhanced strobe) [Figure 7] HS400 Bus mode selection sequence #### **■ EXT\_CSD** register for Data strobe #### • Enhanced Strobe field in BUS\_WIDTH [183] | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-----------------|----------|-------|--------------------|-------|-------|-------|-------| | Enhanced Strobe | Reserved | | Bus Mode Selection | | | | | BIT[7]: 0: Strobe is provided only during data out and CTC response [Default] The support of STROBE\_ENHANCED mode is optional for devices. STROBE\_SUPPORT[184] register of EXT\_CSD indicates whether a device supports that mode. <sup>1:</sup> Strobe is provided during data out, CRC response and CMD response #### 4.1.2 Field firmware update (FFU) To download a new firmware, the e-NAND requires instruction sequence following JEDEC standard. SK hynix e-NAND only supports Manual mode (MODE\_OPERATION\_CODES is not supported). For more details, see as the following chart and register table given below. [Figure 8] FFU flow chart #### 4.1.2.1 Field F/W update flow - CMD sequence | Operation | CMD | Remark | |------------------------------|------------------------|-------------------------------------------------------------------------------------------------| | Set bus width (1bit or 4bit) | | Bus width should be 1bit or 4bit | | Set block length 512B | CMD16, arg: 0x00000200 | | | Enter FFU mode | CMD6, arg: 0x031E0100 | | | Send FW to device(Download) | CMD25, arg: 0xFFFAFFF0 | Sending CMD25 is followed by sending FW data | | CMD12 : Stop | CMD12, arg: 0x00000000 | | | CMD6 : Exit FFU mode | CMD6, arg : 0x031E0000 | | | CMD0/HW Reset/Power cycle | | | | Re-Init to trans state | CMD0, CMD1 | | | Check if FFU is succeeded | CMD8, arg : 0x00000000 | Check EXT_CSD[26] : FFU_SUCCESS If FFU_SUCCESS is 0, FFU is succeeded, otherwise FFU is failed. | #### 4.1.2.2 EXT\_CSD Register for FFU #### ■ SUPPORTED\_MODE[493] (Read Only) BIT[0]: '0' FFU is not supported by the device. '1' FFU is supported by the device. BIT[1]: '0' Vendor specific mode (VSM) is not supported by the device. '1' Vendor specific mode is supported by the device. | Bit | Field | Supportability | |----------|----------|----------------| | Bit[7:2] | Reserved | | | Bit[1] | VSM | Not support | | Bit[0] | FFU | Supported | #### ■ FFU\_FEATURE[492] (Read Only) BIT[0]: '0' Device does not support MODE\_OPERATION\_CODES field (Manual mode) '1' Device supports MODE\_OPERATION\_CODES field (Auto mode) | Bit | Field | Supportability | |----------|--------------------------------|----------------| | Bit[7:1] | Reserved | | | Bit[0] | SUPPORTED_MODE_OPERATION_CODES | Not support | #### **■** FF\_ARG[490-487] (Read Only) Using this field the device reports to the host which value the host should set as an argument for read and write commands is FFU mode. #### **■** FF\_CONFIG[169] (R/W) BIT[0]: Update disable 0x0 : FW updates enabled. / 0x01 : FW update disabled permanently | Bit | Field | Supportability | |----------|----------------|--------------------------| | Bit[7:1] | Reserved | | | Bit[0] | Update disable | FW updates enabled (0x0) | #### ■ FFU\_STATUS[26] (R/W/E\_P) Using this field the device reports to the host the state of FFU process. | Value | Description | |-------------|-------------------------------| | 0x13 ~ 0xFF | Reserved | | 0x12 | Error in downloading Firmware | | 0x11 | Firmware install error | | 0x10 | General error | | 0x01 ~ 0x0F | Reserved | | 0x00 | Success | #### ■ OPERATION\_CODES\_TIMEOUT[491](Read Only) Maximum timeout for the SWITCH command when setting a value to the MODE\_OPERATION\_CODES field The register is set to '0', because the e-NAND doesn't support MODE\_OPERATION\_CODES. | Value | Description | Timeout value | |-------------|-----------------------------------------------------------------------------|-----------------| | 0x01 ~ 0x17 | MODE_OPERATION_CODES_TIMEOUT = 100us x 2 <sup>OPERATION_CODES_TIMEOUT</sup> | 0 (Not defined) | | 0x18 ~ 0xFF | Reserved | | #### ■ MODE\_OPERATION\_CODES[29] (W/E\_P) The host sets the operation to be performed at the selected modes, in case MODE\_CONFIGS is set to FFU\_MODE, MODE\_OPERATION\_CODES could have the following values : | Bit | Description | |--------------|-------------| | 0x01 | FFU_INSTALL | | 0x02 | FFU_ABOUT | | 0x00, others | Reserved | #### 4.1.3 Health Report Using this feature is for monitoring device status and preventing the error and failure in advance. Host can check device information with EXT\_CSD as the register table given below. | Field | CSD slice | Description | |----------------------------------|-----------|---------------------------------------------------------------------------------------------------------------| | VENDOR_PROPRIETARY_HEALTH_REPORT | [301:270] | Reserved for vendor proprietary health report. (NONE) | | DEVICE_LIFE_TIME_EST_TYPE_ A/B | [269:268] | Current average P/E cycle of memory of Type A(SLC) / Type B(MLC) relative to its maximum estimated capability | | PRE_EOL_INFO | [267] | Consumed reserved blocks to notify before reaching the EOL (End of life) status | | OPTIMAL_TRIM/WRITE_READ_SIZE | [266:264] | Minimum optimal (for the device) Erase / Write / Read unit size for the different partitions | | DEVICE_VERSION | [263:262] | Device version | | FIRMWARE_VERSION | [261:254] | Device FW version | [Table 7] Using EXT\_CSD for health report (Read only) #### 4.1.4 Sleep Notification Host may use to a power off notification when it intends to turn-off $V_{cc}$ After moving the device to sleep state. Some features are added to clarify the spec for entering sleep mode when power off notification is enabled. #### ■ Add the SLEEP\_NOTIFICATION on the interruptible Command List | CMD | Description | Is interruptible? | |------|---------------------------------------------------------------------------------|-------------------| | CMD6 | SWITCH, Byte POWER_OFF_NOTIFICATION, Value POWER_OFF_LONG or SLEEP_NOTIFICATION | Yes | #### ■ SLEEP\_NOTIFICATION\_TIME[216](Read Only) Maximum timeout for the SWITCH command when notifying the device that it is about to move to sleep state by writing SLEEP\_NOTIFICATION to POWER\_OFF\_NOTIFICATION[34]byte. (unit : 10us) | Value | Description | Timeout value | |-------------|---------------------------------------------------------------|----------------| | 0x01 ~ 0x17 | Sleep Notification Timeout = 10us x 2 SLEEP_NOTIFICATION_TIME | 0x0E(163.84ms) | | 0x18 ~ 0xFF | Reserved | | #### **■ POWER\_OFF\_NOTIFICATION**[34] Add Ox04h for the SLEEP\_NOTIFICATION as a valid value | Value | Field | Description | |-------|--------------------|----------------------------------------------------------------------------------------------------| | : | : | : | | 0x03 | POWER_OFF_LONG | Host is going to power off the device. The device shall respond within POWER_OFF_LONG_TIME | | 0x04 | SLEEP_NOTIFICATION | Host is going to put device in sleep mode. The device shall respond within SLEEP_NOTIFICATION_TIME | #### 4.1.5 Secure Removal type This feature is used for how information is removed from the physical memory during a purge operation. #### ■ Secure Removal Type[16] Among four options for secure removal type, e-NAND supports 0x3, 0x1 and 0x0 (0x2 option is not supported) e-NAND recommends using a vendor defined removal type(type 3). If host want to erase the device physically using removal type0. Secure erase & Secure trim time is longer than using removal type3 | BIT | Description of Secure<br>Removal Type | Description | | Supportability | |----------|---------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | | IT[5:4] Configure Secure Removal Type (R/W) | 0x3 | Information removed using a vendor defined | - | | BIT[5:4] | | 0x2 | Information removed by an overwriting the addressed locations with a character, its complement, then a random character | - | | | | 0x1 | Information removed by an overwriting the addressed locations with a character followed by an erase | - | | | | 0x0 | Information removed by an erase of the physical memory | - | | | | BIT[3] | Information removed using a vendor defined | Supported | | | Supported Secure Removal | BIT[2] | Information removed by an overwriting the addressed locations with a character, its complement, then a random character | Not supported | | BIT[3:0] | Type (R) | BIT[1] | Information removed by an overwriting the addressed locations with a character followed by an erase | Supported<br>(but, same operating<br>to type 0) | | | | BIT[0] | Information removed by an erase of the physical memory | Supported | #### 4.2 eMMC5.1 New features #### 4.2.1 Command queuing e-NAND manages an internal task queue to which the host can queue data transfer tasks to efficient operate. ## 4.2.1.1 CMD list for Command queuing | Index | Abbreviation | Argument | Remark | |-------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CMD44 | Queued_Task_parameter | [31] Reliable Write Request [30] Data Direction (Read=1, Write=0) [29] Tag Request [28:25] context ID [24]Forced Programming [23] Priority ( simple =0, high=1) [20:16] Task ID(31~0) [15:0] # of BLK | Encodes parameter which are necessary for queuing the task and executing the transfer | | CMD45 | Queued_Task_Address | [31:0] Block address for the transaction | The host instructs the device to queue a data transfer task | | CMD46 | Execute_Read_Task | [20:16] Task ID of the | In order to execute a data read task | | CMD47 | Execute_Write_Task | requested task which is must marked as<br>"ready for execution" in the Queue Status<br>Register | (CMD46) or write task(CMD47) which is already queued | | CMD48 | CMDQ_TASK_MGMT | [31:21] reserved<br>[20:16]: TaskID<br>[15:4]: reserved<br>[3:0] TM op-code | Device shall discard a specific task or entire queue (all tasks in the queue) [20:16] when TM op-code = 2h these bits represent TaskID. When TM op-code=1h these bits are reserved. | | Index | Abbreviation | Argument | Remark | |-------|--------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | CMD13 | SEND_STATUS | [31:16] RCA<br>[15] <b>SQS</b><br>[14] Stuff bits<br>[0] HPI | In case SQS bit = 1: indicate that this is CMD13 of CMD Queue. In response device shall send the QSR. In this case HPI bit muse be set to '0'. | #### 4.2.1.2 EXT\_CSD Register for Command queuing #### **■** CMDQ\_SUPPORT[308](Read only) This field indicates whether command queuing is supported by the device. BIT[0]: 0: Command queuing is not supported 1: Command queuing is supported | Bit | Field | Supportability | |----------|--------------|-----------------| | Bit[7:1] | Reserved | - | | Bit[0] | CMDQ Support | Supported (0x1) | #### ■ CMDQ\_DEPTH[307](Read only) This field is used to calculate the depth of the queue supported by the device. The maximum depth allowed by the standard is 32. The range of allowed Task IDs is 0 through N. BIT[4:0]: N, a parameter used to calculate the Queue Depth of task queue in the device. Queue Depth = N+1. | Bit | Field | CMD queue depth value | |----------|----------|-----------------------| | Bit[7:5] | Reserved | - | | Bit[4:0] | N | N=31 (0x1F) | #### ■ CMDQ\_MODE\_EN[15](R/W) This field is used by the host enable command queuing mechanism if supported by the device. BIT[0]: 0: Command queuing is disabled. Host should clear the queue empty using CMD48 prior disabling the queue. 1: Command queuing is enabled | Bit | Field | Supportability | |----------|-------------|----------------| | Bit[7:1] | Reserved | - | | Bit[0] | CMDQ enable | - | To maintain backward compatibility with hosts, which do not support command queuing, when the command queuing is disabled other functionality of the device is as if the device does not support command queuing. #### 4.2.1.3 New register for Command queuing #### ■ QSR (Queue Status Register) The 32bit QSR carries the state of tasks in the queue at a specific point in time. The host has read access to this register through device response to SEND\_STATUS command(CMD13 with bit[15]="1"), R1's argument will be the QSR. Every bit in the QSR represents the task who's ID corresponds to the bit index. If bit QSR[i]='0', the queued task with a Task ID i is not ready for execution. The task may be queued and pending, or the Task ID is unused. If bit QSR[i]='1', the queued task with Task ID i is ready for execution. #### 4.2.1.4 Command queuing Flows ## For enter the CMD Queuing Mode, CMD\_Q\_EN(bit[0] of EXT\_CSD[15]) is set to '1' ## Checking the Queue Status (SEND\_STATUS: CMD13) HOST set the SQS bit = 1, for read the QSR. The device responds with an R1 with the QSR in its argument. ## Execution of a Queued Task (CMD46/ CMD47) Task #1 ready ## For end the CMD Queuing Mode, HOST should clear the Queue Task to be empty, using CMD48 before disabling the Queue. #### 4.2.2 Cache Barrier There are cases where the host is not interested in flushing the data right away, however it would like to keep an order between different cached data. The flushing can be delayed by the device to some later idle time. Barrier commands avoid the long delay by flush commands. Arrival sequence • Flush sequence $R_3$ $R_1$ $R_2$ $R_0$ $R_6$ $R_5$ $R_4$ $R_7$ #### 4.2.2.1 EXT\_CSD Register for Cache Barrier #### ■ BARRIER\_SUPPORT[488](Read only) This field indicates whether the device supports the barrier command. BIT[7:0]: 0: Barrier command is not supported 1: Barrier command is supported | Bit | Field | Supportability | |----------|-----------------|-----------------| | Bit[7:0] | BARRIER_SUPPORT | Supported (0x1) | #### ■ FLUSH\_CACHE[32](W/E\_P) A barrier command is issued by setting BARRIER bit. All data cached before the barrier shall be flushed to the non-volatile memory before any request after the barrier command. Data in the cache shall be flushed to the non-volatile storage by setting the FLUSH bit. BIT[1]: 0: Reset value 1: Set barrier BIT[0]: 0: Reset value 1: Triggers the flush | Bit | Field | Supportability | |----------|----------|----------------| | Bit[7:2] | Reserved | - | | Bit[1] | BARRIER | - | | Bit[0] | FLUSH | - | #### ■ BARRIER\_CTRL[31](R/W) This field is used by the host enable barrier command mechanism if supported by the device. BIT[0]: 0: Barrier feature is OFF 1: Barrier feature is ON | Bit | Field | Supportability | |----------|------------|----------------| | Bit[7:1] | Reserved | - | | Bit[0] | BARRIER_EN | - | #### 4.2.2.2 Cache barrier Flows #### 1. Support Barrier command - The device exposes its barrier support capability via the BARRIER\_SUPPORT (EXT\_CSD byte [486]) #### 2. Enable Barrier command - The host shall set bit 0 of BARRIER\_EN (EXT\_CSD byte [31]) - 3. Cache on - 4. Send data #### 5. Set Barrier - The host shall set both BARRIER bit and FLUSH bit of the FLUSH\_CACHE (EXT\_CSD byte [32]) #### 4.2.3 Cache Flushing Report For devices which flush cached data in an in-order manner, cache barrier commands are redundant and impose a needless overhead to the device and host. #### 4.2.3.1 EXT\_CSD Register for Cache Flushing Report #### ■ CACHE\_FLUSH\_POLICY[240](Read only) BIT[0]: 0: Device flushing policy is not provided by the device. 1: Device is using a FIFO policy for cache flushing | Bit | Field | Supportability | |----------|----------|------------------| | Bit[7:1] | Reserved | - | | Bit[0] | FIFO | Supported (0x01) | #### 4.2.4 BKOP Control This feature allows the host to indicate to the device if it is expected to periodically manually start background operations by writing to the BKOPS\_START field. #### 4.2.4.1 EXT\_CSD Register for BKOP Control #### **■** BKOP\_EN[163](R/W/E, R/W) BIT[1](R/W/E): 0: Device shall not perform background operations while not servicing the host. 1: Device may perform background operations while not servicing the host. BIT[0] (R/W): 0: Host does not support background operations handling and is not expected to write to BKOPS\_START field. 1: Host is indicating that it shall periodically write to BKOPS\_START field to manually start background operations. | Bit | Field | Supportability | |----------|-----------|----------------| | Bit[7:2] | Reserved | - | | Bit[1] | AUTO_EN | - | | Bit[0] | MANUAL_EN | - | #### 4.2.5 Secure Write Protection Any application running on the host may issue write protection by updating fields of write protection related EXT\_CSD, like USER\_WP[171], BOOT\_WP[173], by issuing CMD6, CMD8, CMD28 and CMD29 (Legacy mode). However there are weak points in the legacy mode. To prevent un-authorized changes, host should enter the secure write protect mode - In Secure WP Mode, WP related EXT\_CSDs (EXT\_CSD[171],[173]) can be updated only if SECURE\_WP\_MASK fields is 0x1. - Secureness is provided by allowing only RPMB method to update the register for SECURE\_WP\_MASK. - Automatic Write protection mode is added to prevent security hole by power-control security attack. All legacy WP related commands works when SECURE\_WP\_MASK is 0x1. #### 4.2.5.1 EXT\_CSD Register for Secure Write Protection #### ■ SECURE\_WP\_INFO[211](Read Only) The SECURE\_WP\_SUPPORT field indicates whether the device is supporting secure write protection mode. The SECURE\_WP\_EN\_STATUS is showing the value of SECURE\_WP\_EN defined in Authenticated Device Configuration Area. BIT[1] 0: Legacy Write Protection mode 1: Secure Write Protection mode BIT[0] 0: Secure Write Protection is NOT supported by this device 1: Secure Write Protection is supported by this device | Bit | Field | Supportability | |----------|---------------------|------------------| | Bit[7:2] | Reserved | - | | Bit[1] | SECURE_WP_EN_STATUS | - | | Bit[0] | SECURE_WP_SUPPROT | Supported (0x01) | #### 4.2.5.2 New register for Secure Write Protection #### ■ Authenticated Device Configuration Area - Hidden register instead of EXT\_CSD register for SECURE\_WP\_MODE\_CONFIG, ENABLE. - Those two SECURE\_WP\_MODE\_CONFIG and SECURE\_WP\_MODE\_ENABLE registers are defined in Device Configuration area, and those register should be updated only by Authenticated Device Configuration write request. (RPMB) | Name | Field | Size (Bytes) | Cell Type | Address | |------------------------------------|-----------------------|--------------|-----------|---------| | Reserved | Reserved | 253 | - | [255:3] | | Secure Write Protect Configuration | SECURE_WP_MODE_CONFIG | 1 | R/W/E_P | [2] | | Secure Write Protect Enable | SECURE_WP_MODE_ENABLE | 1 | R/W/E | [1] | | Reserved | | 1 | | [0] | #### ■ Authenticated Device Configuration Area (1): SECURE\_WP\_MODE\_ENABLE (R/W/E) The byte is to enter/exit the secure write protection mode. If host want a device to enter the secure Write Protection mode, host set the SECURE\_WP\_EN bit as '0x1' in this register using Authenticated Device Configuration Write request. This register can be read using Authenticated Device Configuration Read request. If there are already write protected groups or write protected boot partitions, those will be preserved when entering or exiting secure Write protected mode. Bit [0] 0: Legacy Write Protection mode. (TMP\_WRITE\_PROTECT[12], PERM\_WRITE\_PROTECT[13] is updated by CMD27. USER\_WP[171], BOOT\_WP[173] and BOOT\_WP\_STATUS[174] are updated by CMD6.) 1: Secure Write Protection mode. (The access to the write protection related EXT\_CSD and CSD fields depends on the value of SECURE\_WP\_MASK bit in SECURE\_WP\_MODE\_CONFIG field.) The default value of this field is 0x0. | Bit | Field | Supportability | |----------|-----------------------|----------------| | Bit[7:1] | Reserved | - | | Bit[0] | SECURE_WP_MODE_ENABLE | - | #### ■ Authenticated Device Configuration Area (2): SECURE \_WP\_MODE\_CONFIG (R/W/E\_P) In secure write protected mode, the updatability of USER\_WP[171], BOOT\_WP[173], TMP\_WRITE\_PROTECT[12] and PERM\_WRITE\_PROTECT[13] are controlled by this mask value. - Bit [0] 0: Disabling updating WP related EXT\_CSD and CSD fields. CMD27 (Program CSD) will generate generic error for setting TMP\_WRITE\_PROTECT[12], PERM\_WRITE\_PROTECT[13]. CMD6 for updating USER\_WP[171], BOOT\_WP[173] and BOOT\_WP\_STATUS[174] generates SWITCH\_ERROR. If a force erase command is issued, the command will fail (Device stays locked) and the LOCK\_UNLOCK\_FAILED error bit will be set in the status register. If CMD28 or CMD29 is issued, then generic error will be occurred. Power-on Write Protected boot partitions will keep protected mode after power failure, H/W reset assertion and any CMD0 reset. The device keeps the current value of BOOT\_WP in the EXT\_CSD register to be same after power cycle, H/W reset assertion, and any CMD0 reset. - 1: Enabling updating WP related EXT\_CSD and CSD fields. (TMP\_WRITE\_PROTECT[12], PERM\_WRITE\_PROTECT[13], USER\_WP[171], BOOT\_WP[173] and BOOT\_WP\_STATUS[174] are accessed using CMD6, CMD8 and CMD27. If a force erase command is issued and accepted, then ALL THE DEVICE CONTENT WILL BE ERASED including the PWD and PWD\_LEN register content and the locked Device will get unlocked. If a force erase command is issued and power-on protected or a permanently-write-protected write protect groups exist on the device, the command will fail (Device stays locked) and the LOCK\_UNLOCK\_FAILED error bit will be set in the status register. An attempt to force erase on an unlocked Device will fail and LOCK\_UNLOCK\_FAILED error bit will be set in the status register. Write Protection is applied to the WPG indicated by CMD28 with the WP type indicated by the bit[2] and bit[0] of USER\_WP[171]. All temporary WP Groups and power-on Write Protected boot partitions become writable/erasable temporarily which means write protect type is not changed. All power-on and permanent WP Groups in user area will not become writable/erasable temporarily. Those temporarily writable/erasable area will become write protected when this bit is cleared to 0x0 by the host or when there is power failure, H/W reset assertion and any CMD0 reset. The device keeps the current value of BOOT\_WP CSD register to be same after power cycle, H/W reset assertion, and any CMD0 reset.) The default value of this field is 0x0. | Bit | Field | Supportability | |----------|-----------------------|----------------| | Bit[7:1] | Reserved | - | | Bit[0] | SECURE_WP_MODE_CONFIG | - | ## 4.2.5.3 RPMB Types for accessing Authenticated Device Configuration Area Secure WP Enable & Configuration registers are defined in Authenticated Device Configuration Area which only can be accessible by new RPMB operations. | Request Message Types | | |------------------------|---------------------------------------------------| | 0x0001 | Authentication key programming request | | 0x0002 | Reading of the Write Counter value –request | | 0x0003 | Authenticated data write request | | 0x0004 | Authenticated data read request | | 0x0005 | Result read request | | 0x0006 | Authenticated Device Configuration Write request | | 0x0007 | Authenticated Device Configuration Read request | | Response Message Types | | | 0x0100 | Authentication key programming response | | 0x0200 | Reading of the Write Counter value –response | | 0x0300 | Authenticated data write response | | 0x0400 | Authenticated data read response | | 0x0600 | Authenticated Device Configuration Write response | | 0x0700 | Authenticated Device Configuration Read response | #### 4.2.6 Enhanced strobe In Enhanced Strobe mode DATA OUT, CRC Response and CMD Response are all synched to STROBE clocks. The timing relation between CMD Response output signals and STROBE clocks is the same as defined for DATA Out to STROBE clocks. [Figure 9] HS400 Host and Device block diagram (when Enhanced Strobe is enabled) [Figure 10] Enhanced Strobe signals for CMD Response and Data Out (Read operation) [Figure 11] Enhanced Strobe signals for CMD Response and Data Out (Write operation) [Figure 12] HS400 mode change with Enhanced Strobe ## 4.2.6.1 EXT\_CSD Register for Enhanced Strobe ## ■ STROBE\_SUPPORT[184](Read only) This register indicates whether a device supports Enhanced Strobe mode for operation modes that STROBE is used for HS400. BIT[7:0]: 0: Indicates No support of Enhanced Strobe mode 1: Indicates the device supports Enhanced Strobe mode | Bit | Field | Supportability | |----------|----------------|------------------| | Bit[7:0] | STROBE_SUPPORT | Supported (0x01) | #### 4.2.6.2 HS400 mode (Enhanced Strobe) selection This selection flow describes how to initialize the eMMC device in HS400 mode while enabling Enhanced Strobe without the need for tuning procedure. After the host initializes the device, host check whether the device supports the HS400 mode and Enhanced Strobe by reading the DEVICE\_TYPE and STROBE\_SUPPORT fields in the Extended CSD register. After power-on or software reset (CMD0), the interface timing of the device is set as the default 'Backward Compatible Timing'. In order to switch to HS400 mode with Enhanced Strobe, host should perform the following steps. [Figure 13] HS400 Bus mode (Enhanced Strobe) selection flow diagram #### 4.2.7 RPMB throughput improvement This feature is proposed for RPMB write data size to improve the RPMB throughput in eMMC5.1 spec. In the eMMC5.0 spec, REL\_WR\_SEC\_C[222] register shall be set to 1 (hence the granularity is always 512B.) - For reliable write to RPMB partition, there is limitation that block count can not exceed the size of REL\_WR\_SEC\_C x 512B. In eMMC5.1, the supported RPMB write access size is 256B, 512B, and 8KB. #### ■ WRITE\_REL\_PARAM (EXT\_CSD[166]): Read only #### When $EXT_CSD[166][4](R) = 0$ - Device does not support large RPMB wirte transfer - The behavior is same as eMMC v5.0 or earlier #### When $EXT_CSD[166][4](R) = 1$ - Device supports large RPMB wirte transfer - Host transfers small RPMB write with block count = 1 or 2 (256/512B) - Host transfers large RPMB write with block count = 32 (8KB) - \* the start address should be 8KB aligned, and the transferred data (8KB) is all-new or all-old | Bit | Field | Supportability | |--------|----------------|------------------| | Bit[4] | EN_RPMB_REL_WR | Supported (0x01) | ## 4.3 Enhanced features from eMMC4.5 to eMMC5.1 Several e-NAND features are changed from eMMC4.5 to eMMC5.1 enhance the e-NAND performance. | Parameter | eMMC4.5 | eMMC5.0 | eMMC5.1 | Description | |-----------------------------|------------------|---------------------|---------------------|-------------------------------------------------------------------------------------------------| | HPI Features | CMD12 | CMD13 | CMD13 | Following industry wise common configuration. | | Max.<br>Packed CMD<br>count | 8ea | 63ea | 63ea | Expended the packed CMD size for optimized device performance. | | Max.<br>CMD Queue<br>depth | Not<br>Support | Not<br>Support | 32ea | CMD queue is added in eMMC5.1 | | Cache size | < | < | < | Cache size is increasing for optimized device performance with 4-way interleave implementation. | | I/O Driver<br>Strength | Support<br>Type0 | Support<br>all type | Support<br>all type | e-NAND supports all of driver strength types for eMMC5.0 | [Table 8] Enhanced features from eMMC4.5 to eMMC5.1 # 5. e-NAND general parameters # **5.1 Timing** #### 5.1.1 Bus timing Data must always be sampled on the rising edge of the clock. [Figure 14] Timing diagram: data input/output | Parameter | Symbol | Min | Max | Unit | Remark | |------------------------------------------|-------------------|-----|------|------|---------------------------------------------| | Clock CLK | <del>-1</del> | | -1 | • | • | | Clock frequency data transfer mode (PP) | f <sub>PP</sub> | 0 | 52 | MHz | C <sub>L</sub> ≤30 pF<br>Tolerance: +100KHz | | Clock frequency identification mode (OD) | f <sub>OD</sub> | 0 | 400 | KHz | Tolerance: +20KHz | | Clock high time | t <sub>WH</sub> | 6.5 | | ns | C <sub>L</sub> ≤ 30 pF | | Clock low time | $t_WL$ | 6.5 | | ns | C <sub>L</sub> ≤ 30 pF | | Clock rise time | t <sub>TLH</sub> | | 3 | ns | C <sub>L</sub> ≤ 30 pF | | Clock fall time | t <sub>THL</sub> | | 3 | ns | C <sub>L</sub> ≤ 30 pF | | Inputs CMD, DAT (referenced to CLK) | l l | | | | 1 | | Input set-up time | $t_{ISU}$ | 3 | | ns | C <sub>L</sub> ≤ 30 pF | | Input hold time | t <sub>IH</sub> | 3 | | ns | C <sub>L</sub> ≤ 30 pF | | Outputs CMD, DAT (referenced to CLK) | l l | | - | | 1 | | Output delay time during data transfer | t <sub>ODLY</sub> | | 13.7 | ns | C <sub>L</sub> ≤ 30 pF | | Output hold time | t <sub>OH</sub> | 2.5 | | ns | C <sub>L</sub> ≤ 30 pF | | Signal rise time | t <sub>RISE</sub> | | 3 | ns | C <sub>L</sub> ≤ 30 pF | | Signal fall time | t <sub>FALL</sub> | | 3 | ns | C <sub>L</sub> ≤ 30 pF | [Table 9] High-speed e-NAND interface timing - CLK timing is measured at 50% of VDD. - e-NAND shall support the full frequency range from 0-26Mhz, or 0-52MHz - $\bullet$ CLK rising and falling times are measured by min (V $_{IH})$ and max (V $_{IL}).$ - Input CMD, DAT rising and falling times are measured by min $(V_{IH})$ and max $(V_{IL})$ , and output CMD, DAT rising and falling times are measured by min $(V_{OH})$ and max $(V_{OL})$ . | Parameter | Symbol | Min | Max | Unit | Remark | | | |------------------------------------------|------------------|------|-----|------|------------------------|--|--| | Clock CLK | | | | | | | | | Clock frequency data transfer mode (PP) | f <sub>PP</sub> | 0 | 26 | MHz | C <sub>L</sub> ≤30 pF | | | | Clock frequency identification mode (OD) | f <sub>OD</sub> | 0 | 400 | KHz | | | | | Clock high time | t <sub>WH</sub> | 10 | | ns | C <sub>L</sub> ≤ 30 pF | | | | Clock low time | t <sub>WL</sub> | 10 | | ns | CL ≤ 30 pF | | | | Clock rise time | t <sub>TLH</sub> | | 10 | ns | CL ≤ 30 pF | | | | Clock fall time | t <sub>THL</sub> | | 10 | ns | CL ≤ 30 pF | | | | Inputs CMD, DAT (referenced to CLK) | | • | | | • | | | | Input set-up time | t <sub>ISU</sub> | 3 | | ns | CL ≤ 30 pF | | | | Input hold time | t <sub>IH</sub> | 3 | | ns | CL ≤ 30 pF | | | | Outputs CMD, DAT (referenced to CLK) | | | | | | | | | Output set-up time | t <sub>OSU</sub> | 11.7 | | ns | CL ≤ 30 pF | | | | Output hold time | t <sub>OH</sub> | 8.3 | | ns | CL ≤ 30 pF | | | #### [Table 10] Backward-compatible e-NAND interface timing - e-NAND must always start with the backward-compatible interface timing. The timing mode can be switched to high-speed timing by the host sending the switch command (CMD6) with the argument for high speed interface select. - CLK timing is measured at 50% of VDD. - ullet CLK rising and falling times are measured by min (V<sub>IH</sub>) and max (V<sub>IL</sub>). - t<sub>OSU</sub> and t<sub>OH</sub> are defined as values from clock rising edge. However, there may be cards or devices which utilize clock falling edge to output data in backward compatibility mode. Therefore, it is recommended for hosts either to set $t_{WL}$ value as long as possible within the range which should not go over $t_{CK}$ - $t_{OH}$ (min) in the system or to use slow clock frequency, so that host could have data set up margin for those devices. In this case, each device which utilizes clock falling edge might show the correlation either between $t_{WL}$ and $t_{OSU}$ or between $t_{CK}$ and $t_{OSU}$ for the device. #### 5.1.2 Bus timing for DAT Signals During 2x Data Rate Operation These timings apply to the DAT[7:0] signals only when the device is configured for dual data mode operation. In dual data mode, the DAT signals operate synchronously of both the rising and the falling edges of CLK. [Figure 15] Timing diagram: data input/output in dual data rate mode | Parameter | Symbol | Min. | Max. | Unit | Remark | |-----------------------------------------|----------------------|------|------|------|------------------------------| | Input CLK <sup>(1)</sup> | | | | | | | Clock duty cycle | | 45 | 55 | % | Includes jitter, phase noise | | Clock rise time | t <sub>TLH</sub> | | 3 | ns | CL≤30 pF | | Clock fail time | t <sub>THL</sub> | | 3 | ns | CL≤30 pF | | Input CMD (referenced to CLK-SDR mod | e) | | | | | | Input set-up time | t <sub>ISUddr</sub> | 3 | | ns | CL≤20 pF | | Input hold time | t <sub>IHddr</sub> | 3 | | ns | CL≤20 pF | | Output CMD (referenced to CLK-SDR mo | de) | | | | | | Output delay time during data transfer | t <sub>ODLY</sub> | | 13.7 | ns | CL≤20 pF | | Output hold time | t <sub>OH</sub> | 2.5 | | ns | CL≤20 pF | | Signal rise time | t <sub>RISE</sub> | | 3 | ns | CL≤20 pF | | Signal fall time | t <sub>FALL</sub> | | 3 | ns | CL≤20 pF | | Input DAT (referenced to CLK-DDR mode | e) | | -1 | | | | Input set-up time | t <sub>ISUddr</sub> | 2.5 | | ns | CL≤20 pF | | Input hold time | t <sub>IHddr</sub> | 2.5 | | ns | CL≤20 pF | | Outputs DAT (referenced to CLK-DDR mo | ode) | | -1 | | | | Output delay time during data transfer | t <sub>ODLYddr</sub> | 1.5 | 7 | ns | CL≤20 pF | | Signal rise time(DAT0-7) <sup>(2)</sup> | t <sub>RISE</sub> | | 2 | ns | CL≤20 pF | | Signal fall time (DAT0-7) | t <sub>FALL</sub> | | 2 | ns | CL≤20 pF | ## [Table 11] Dual data rate interface timings - NOTE 1. CLK timing is measured at 50% of VDD. - ullet NOTE 2. Inputs DAT rising and falling times are measured by min (V<sub>IH</sub>) and max (V<sub>IL</sub>), and outputs CMD, DAT rising and falling times are measured by min (V<sub>OH</sub>) and max (V<sub>OL</sub>) # 5.2 Bus signal #### 5.2.1 Bus signal line load The total capacitance $C_L$ of each line of e-MMC bus is the sum of the bus master capacitance $C_{HOST}$ , the bus capacitance $C_{BUS}$ itself, and the capacitance $C_{DEVICE}$ of the eMMC connected to this line, and requiring the sum of the host and bus capacitances not to exceed 20 pF. $$C_L = C_{HOST} + C_{BUS} + C_{DEVICE}$$ | Parameter | Symbol | Min | Тур | Max | Unit | Remark | |--------------------------------------------|---------------------|-----|-----|-----|------|------------------------------------------------------------------------------------------------------------------------------------------| | Pull-up resistance for CMD | R <sub>CMD</sub> | 4.7 | | 100 | Kohm | to prevent bus floating | | Pull-up resistance for DAT0-7 | R <sub>DAT</sub> | 10 | | 100 | Kohm | to prevent bus floating | | Internal pull up resistance<br>DAT1 - DAT7 | R <sub>INT</sub> | 10 | | 150 | Kohm | | | Bus signal line capacitance | C <sub>L</sub> | | | 30 | pF | Single Device | | Single Device capacitance | C <sub>DEVICE</sub> | | | 6 | pF | | | Maximum signal line inductance | | | | 16 | nH | f <sub>pp</sub> ≤ 52 MHz | | VDDi capacitor value | $C_REG$ | 0.1 | | | μF | To stabilize regulator output when target device bus speed mode is either backward-compatible, high speed SDR, high speed DDR, or HS200. | | | | 1 | | | μF | To stabilize regulator output when target device bus speed mode is HS400 | | V <sub>ccq</sub> decoupling capacitor | C <sub>H1</sub> | 1 | | | μF | | [Table 12] e-NAND capacitance #### 5.2.2 Overshoot / Undershoot specification | Specification | | V <sub>ccq</sub><br>1.70V - 1.95V | Unit | |-----------------------------------------------------|-----|-----------------------------------|------| | Maximum peak amplitude allowed for overshoot area. | Max | 0.9 | V | | Maximum peak amplitude allowed for undershoot area. | Max | 0.9 | V | | Maximum area above $V_{\rm ccq}$ | Max | 1.5 | V-ns | | Maximum area below V <sub>ssq</sub> | Max | 1.5 | V-ns | [Table 13] Overshoot / Undershoot specification [Figure 16] Overshoot / Undershoot definition #### 5.2.3 Bus Signal levels As the bus can be supplied with a variable supply voltage, all signal levels are related to the supply voltage. [Figure 17] e-NAND bus signal level #### • Open-Drain mode bus signal level | Parameter | Symbol | Min. | Max. | Unit | Conditions | |---------------------|-----------------|-----------------------|------|------|-----------------------| | Output high voltage | V <sub>OH</sub> | V <sub>DD</sub> - 0.2 | | ٧ | Note <sup>1)</sup> | | Output low voltage | V <sub>OL</sub> | | 0.3 | ٧ | I <sub>OL</sub> = 2mA | [Table 14] Open-Drain signal level • <u>NOTE 1</u>. Because V<sub>OH</sub> depends on external resistance value (including outside the package), this value does not apply as device specification. Host is responsible to choose the external pull-up and open drain resistance value to meet V<sub>OH</sub> minimum value. #### • Push-Pull mode bus signal level The device input and output voltages shall be within the following specified ranges for any $V_{DD}$ of the allowed voltage range | Parameter | Symbol | Min. | Max. | Unit | Conditions | |---------------------|-----------------|--------------------------|--------------------------|------|-----------------------------------------| | Output HIGH voltage | V <sub>OH</sub> | 0.75 * V <sub>ccq</sub> | | V | $I_{OH}$ = -100 $\mu$ A @ $V_{ccq}$ min | | Output LOW voltage | V <sub>OL</sub> | | 0.125 * V <sub>ccq</sub> | V | $I_{OL}$ = -100 $\mu$ A @ $V_{ccq}$ min | | Input HIGH voltage | V <sub>IH</sub> | 0.625 * V <sub>ccq</sub> | V <sub>ccq</sub> + 0.3 | V | | | Input LOW voltage | V <sub>IL</sub> | V <sub>SS</sub> - 0.3 | 0.25 * V <sub>ccq</sub> | V | | [Table 15] Push-Pull signal level 2.7V-3.6V $\,\mathrm{V_{ccq}}$ range | Parameter | Symbol | Min. | Max. | Unit | Conditions | |---------------------|-----------------|-------------------------|-------------------------|------|------------------------| | Output HIGH voltage | V <sub>OH</sub> | Vccq - 0.45V | | V | $I_{OH} = -2mA$ | | Output LOW voltage | V <sub>OL</sub> | | 0.45V | V | I <sub>OL</sub> = -2mA | | Input HIGH voltage | V <sub>IH</sub> | 0.65 * V <sub>ccq</sub> | V <sub>ccq</sub> + 0.3 | V | | | Input LOW voltage | V <sub>IL</sub> | V <sub>SS</sub> - 0.3 | 0.35 * V <sub>ccq</sub> | V | | [Table 16] Push-pull signal level 1.65V-1.95V $V_{\rm ccq}$ range #### 5.3 Power mode #### 5.3.1 e-NAND power-up guidelines e-NAND power-up must adhere to the following guidelines: - When power-up is initiated, either V<sub>CC</sub> or V<sub>CCQ</sub> can be ramped up first, or both can be ramped up simultaneously. - After power up, e-NAND enters the pre-idle state. The power up time of each supply voltage should be less than the specified tPRU (tPRUH, tPRUL or tPRUV) for the appropriate voltage range. - If e-NAND does not support boot mode or its BOOT\_PARTITION\_ENABLE bit is cleared, e-NAND moves immediately to the idle state. While in the idle state, e-NAND ignores all bus transactions until receiving CMD1. - e-NAND begins boot operation with the argument of 0xFFFFFFA. If boot acknowledge is finished, e-NAND shall send acknowledge pattern "010" to the host within the specified time. After boot operation is terminated, e-NAND enters the idle state and shall be ready for CMD1 operation. If e-NAND receives CMD1 in the pre-boot state, it begins to respond to the command and moves to the card identification mode. - When e-NAND is initiated by alternative boot command(CMD0 with arg=0xFFFFFFA), all the data will be read from the boot partition and then e-NAND automatically goes to idle state, but hosts are still required to issue CMD0 with arg=0x0000000000 in order to complete a boot mode properly and move to the idle state. While in the idle state, e-NAND ignores all bus transactions until it receives CMD1. - CMD1 is a special synchronization command which is used to negotiate the operating voltage range and poll the device until it is out of its power-up sequence. In addition to the operating voltage profile of the device, the response to CMD1 contains a busy flag indicating that the device is still working on its power-up procedure and is not ready for identification. This bit informs the host that the device is not ready, and the host must wait until this bit is cleared. The device must complete its initialization within 1 second of the first CMD1 issued with a valid OCR range. - If the e-NAND device was successfully partitioned during the previous power up session (bit 0 of EXT\_CSD byte [155] PARTITION\_SETTING\_COMPLETE successfully set) then the initialization delay is (instead of 1s) calculated from INI\_TIMEOUT\_PA (EXT\_CSD byte [241]). This timeout applies only for the very first initialization after successful partitioning. For all the consecutive initialization 1sec time out will be applied. - The bus master moves the device out of the idle state. Because the power-up time and the supply ramp-up time depend on the application parameters such as the bus length and the power supply unit, the host must ensure that power is built up to the operating level (the same level that will be specified in CMD1) before CMD1 is transmitted. - After power-up, the host starts the clock and sends the initializing sequence on the CMD line. The sequence length is the longest of: 1ms, 74 clocks, the supply ramp-up time, or the boot operation period. An additional 10 clocks (beyond the 64 clocks of the power-up sequence) are provided to eliminate power-up synchronization problems. - Every bus master must implement CMD1. #### 5.3.2 e-NAND Power Cycling The master can execute any sequence of $V_{cc}$ and $V_{ccq}$ power-up/power-down. However, the master must not issue any commands until $V_{cc}$ and $V_{ccq}$ are stable within each operating voltage range. After the slave enters sleep mode, the master can power-down $V_{cc}$ to reduce power consumption. It is necessary for the slave to be ramped up to $V_{cc}$ before the host issues CMD5 (SLEEP\_AWAKE) to wake the slave unit. [Figure 18] e-NAND power cycle If $V_{cc}$ or $V_{ccq}$ is below 0.5 V for longer than 1 ms, the slave shall always return to the pre-idle state, and perform the appropriate boot behavior. The slave will behave as in a standard power up condition once the voltages have returned to their functional ranges. An exception to this behavior is if the device is in sleep state, in which the voltage on $V_{cc}$ is not monitored. #### 5.3.3 Leakage | Parameter | Symbol | Min | Max. | Unit | Remark | |------------------------------------------------------------------------------------------------------|--------|------|-----------------------|------|--------| | | BGA | -0.5 | V <sub>ccq</sub> +0.5 | V | | | All inputs | | | | | | | Input leakage current (before initialization sequenceand/or the internalpull up resistors connected) | | -100 | 100 | μА | | | All outputs | | | | | | | Output leakage current (before initialization sequence) | | -100 | 100 | μΑ | | | Output leakage current (after initialization sequence) | | -2 | 2 | μΑ | | [Table 17] General operation conditions #### 5.3.4 Power Supply e-NAND supports one or more combinations of Vcc and Vccq as shown in Table 18. The available voltage configuration is shown in Table 19. | Parameter | Symbol | Min | Max. | Unit | Remark | |--------------------------|-------------------|-----|------|------|--------| | Supply voltage (NAND) | V <sub>cc</sub> | 2.7 | 3.6 | V | | | Supply voltage (I/O) | V <sub>ccq</sub> | 1.7 | 1.95 | V | | | Supply power-up for 3.3V | t <sub>PRUH</sub> | | 35 | ms | | | Supply power-up for 1.8V | t <sub>PRUL</sub> | | 25 | ms | | #### [Table 18] e-NAND power supply voltage | Parameter | | V <sub>ccq</sub> | |-----------------|--------------|------------------| | T di di | | 1.7V - 1.95V | | V <sub>cc</sub> | 2.7V - 3.6V | Valid | | - cc | 1.7V - 1.95V | Not Valid | ## [Table 19] e-NAND voltage combinations $\bullet$ NOTE 1. Vccq(I/O) 3.3 volt range is not supported in either HS200 or HS400 devices ## **5.4 Connection Guide** [Figure 19] Connection guide drawing | Parameter | Symbol | Min | Max | Recommend | Unit | Remark | |------------------------------------------|---------|----------|-----|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pull-up resistance for CMD | R_CMD | 4.7 | 100 | 10 | kohm | Pull-up resistance should be put on CMD line to prevent bus floating. | | Pull-up resistance for DAT0~7 | R_DAT | 10 | 100 | 50 | kohm | Pull-up resistance should be put on DAT line to prevent bus floating. | | Data strobe(DS) | R_DS | NC | NC | NC | - | It is not necessary to put pull-up/pull-down resistance on DS line since DS is internally pulled down. Direct connection to host is required and please float this pin if it is not used | | Pull-up resistance for<br>RSTn | R_RSTn | 10 | 100 | 50 | kohm | It is not necessary to put pull-up resistance on RSTn line if host does not use H/W reset. (Extended CSD register [162] = 0b) | | Serial resistance on CLK | R_CLK | 0 | 30 | 27 | ohm | To reduce overshooting/undershooting Note: If the host uses HS200, we recommend to remove this resister for better CLK signal | | V <sub>ccq</sub> capacitor value | C1 & C2 | 2±0.22 | 4.7 | 2±0.22 | μF | Coupling cap should be connected with $V_{\text{ccq}}$ closely. | | V <sub>cc</sub> capacitor<br>value(≤8GB) | 62.0.64 | 470.400/ | 10 | 470.1400/ | | Coupling cap should be connected with V <sub>cc</sub> closely. | | V <sub>cc</sub> capacitor<br>value(>8GB) | C3 & C4 | 4.72±10% | 10 | 4.72±10% | μF | $V_{\rm cc}$ / $V_{\rm ccq}$ cap. value would be up to Host requirement and the application system characteristics. | | VDDi capacitor value | C5 & C6 | 0 | 2.2 | 0.1 | μF | Coupling cap should be connected with VDDi and Vssq as closely possible. (Internal Cap: 1µF) | [Table 20] Connection guide specification # 6. e-NAND basic operations # **6.1 Partitioning** #### 6.1.1 User density [Figure 20] Partition diagram #### **■** Boot and RPMB partition size | Density | Boot 1,2 partition size | RPMB partition size | |---------|-------------------------|---------------------| | 16GB | | | | 32GB | 4096KB (4MB) | 16384KB (16MB) | | 64GB | | | ## ■ Boot and RPMB partition size | Capacity | SEC_COUNT | Capacity | Percentile | |----------|----------------------------|-----------------------------------|------------| | 16GB | 30,777,344<br>(0x1D5A000) | 15,758,000,128 Bytes<br>(14.68GB) | 91.72% | | 32GB | 61,071,360<br>(0x3A3E000) | 31,268,536,320 Bytes<br>(29.12GB) | 91.00% | | 64GB | 122,142,720<br>(0x747C000) | 62,537,072,640 Bytes<br>(58.24GB) | 91.00% | <sup>• 1</sup>sector=512 bytes. #### ■ Maximum enhanced partition size Enhanced user data area can be configured to store read-centric data such as sensitive data or for other host usage models. SK hynix e-NAND supports Enhanced User Data Area as SLC Mode. When customer adopts some portion as enhanced user data area in User Data Area, that area occupies double the size of the original set-up size. | Capacity | MAX_ENH_SIZE_MULT | HC_ERASE_GRP_SIZE | HC_WP_GRP_SIZE | |----------|-------------------|-------------------|----------------| | 16GB | 0x0003AB | 1h | 10h | | 32GB | 0x000747 | 1h | 10h | | 64GB | 0x000E8F | 1h | 10h | • Max Enhanced Partition Size is defined as MAX\_ENH\_SIZE\_MULT x HC\_WP\_GRP\_SIZE x HC\_ERASE\_GRP\_SIZE x 512KByte. | Capacity | Capacity (KB) | |----------|---------------| | 16GB | 7,692,288 | | 32GB | 15,261,696 | | 64GB | 30,531,584 | <sup>•</sup> The total usable capacity of the e-NAND may be less than total physical capacity because a small portion of the capacity is used for NAND flash management and maintenance purpose. ## 6.1.2 Erase / Write protect group size | | Erase gro | | | |---------|-------------------|-------------------|--------------------------| | Density | ERASE_GROUP_DEF=0 | ERASE_GROUP_DEF=1 | Write protect group size | | 16GB | 512KB | 512KB | 8MB | | 32GB | 512KB | 512KB | 8MB | | 64GB | 512KB | 512KB | 8MB | [Table 21] Erase/Write protect Group size #### 6.2 Boot operation e-NAND supports boot mode and alternative boot mode. e-NAND also, supports high speed timing and dual data rate during boot. [Figure 21] e-NAND state diagram (Boot mode) [Figure 22] e-NAND state diagram (Alternative boot mode) | Timing Factor | Value | |-------------------------|---------| | (1) Boot ACK Time | < 50 ms | | (2) Boot Data Time | < 1 sec | | (3) Initialization Time | < 1 sec | - Initialization time includes partition setting, Please refer to INI\_TIMEOUT\_AP in 7.4 Extended CSD Register. Initialization time is completed within 1sec from issuing CMD1 until receiving response. - The device has to send the acknowledge pattern "010" to the master within 50ms after the CMD0 with the argument of 0xFFFFFFFA is received. # 7. Time out | Latency Item | Value | Remark | |----------------------------------------------|--------------------------------------|--------| | Write Time out<br>(CMD To 512KB Write Done) | Max 1.2s<br>Median 30ms<br>99th 50ms | | | Write Time out<br>(Data To Data) | Max 500ms | | | Read Time Out<br>(CMD To the first data out) | Max 50ms | | | Initialization Time | Max 1s | | | Initialization Time<br>(After Partitioning) | Max 1s | | | Initialization after PON<br>(Short/long) | Max 180ms | | | Pre-Boot to ACK | Max 50ms | | | Pre-Boot to Boot Data | Max 60ms | | | Partition Switch | Max 10ms | | | CMD6 Switch | Max 100ms | | | CMD8 time out | Max 5ms | | | Erase<br>(Erase Group) | Max 600ms | | | Trim<br>(512B~512KB) | Max 600ms | | | Discard<br>(512B~512KB) | Max 600ms | | [Table 22] Time out value | Latency Item | V | alue | Remark | |-------------------------------------------------|-----------|------------|--------------------------------------------------------| | Secure Trim1<br>Type 0, 1<br>(512B~512KB) | Max 600s | | Type 0 : information removed by an erase of | | Secure Trim1<br>Type 3<br>(512B~512KB) | Max | 600ms | the physical memory Type 1 : Same operation to type 0 | | Secure Erase<br>Type 0,1<br>(Write Block 512KB) | Max 600s | | Type 2 : Not support Type 3 : information unmapped | | Secure Erase<br>Type 3<br>(Write Block 512KB) | Max 600ms | | | | | 16GB | Max 80min | | | Sanitize<br>(UDA Area) | 32GB | Max 80min | | | | 64GB | Max 80min | | | Force Erase<br>(UDA Area) | Max 3min | | | | HPI | Max 100ms | | | | PON Busy Time<br>(Short/Long) | Max 50n | ns / 600ms | PON long includes GC<br>PON short not include GC | # [Table 22] Time out value (Continue) • Be advised timeout values specified in table above are for testing purpose under SK hynix test pattern only and actual timeout situations may vary # 8. Device registers There are six different registers within the device interface: - Operation conditions register (OCR) - Card identification register (CID) - Card specific data register (CSD) - Relative card address register (RCA) - DSR (Driver Stage Register) - Extended card specific data register (EXT\_CSD). These registers are used for the serial data communication and can be accessed only using the corresponding commands. e-NAND has a status register to provide information about the current device state and completion codes for the last host command. ### 8.1 Operation conditions register (OCR) The 32-bit operation conditions register (OCR) stores the VDD voltage profile of e-NAND and the access mode indication. In addition, this register includes a status information bit. This status bit is set if e-NAND power up procedure has been finished. | OCR bit | Description | SK hynix e-NAND | | |---------|--------------------------------------------------|-------------------|--| | [6:0] | Reserved | 000 0000Ь | | | [7] | 1.70 - 1.95V | 1b | | | [14:8] | 2.0 - 2.6 | 000 0000Ь | | | [23:15] | 2.7 - 3.6 (High V <sub>ccq</sub> range) | 1111 1111 1b | | | [28:24] | Reserved | 0 0000b | | | [30:29] | Access mode | 10b (sector mode) | | | [31] | (card power up status bit (busy)) <sup>(1)</sup> | | | #### [Table 23] OCR register definition • NOTE 1. This bit is set to LOW if the card has not finished the power up routine # 8.2 Card identification (CID) register The card identification (CID) register is 128 bits wide. It contains e-NAND identification information used during e-NAND identification phase (e-NAND protocol). Every individual e-NAND has a unique identification number. The structure of the CID register is defined in the following sections. | Name | Field | Width | CID slice | CID value | Remark | |-----------------------|-------|-------|-----------|----------------------------------------------------------------------|-----------| | Manufacturer ID | MID | 8 | [127:120] | 0X90 | | | Reserved | | 6 | [119:114] | | | | Card/BGA | CBX | 2 | [113:112] | 0X1 | BGA | | OEM/application ID | OID | 8 | [111:104] | 0X4A | | | Product name | PNM | 48 | [103:56] | 16GB: 0X68413861503E<br>32GB: 0X68423861503E<br>64GB: 0X68433861503E | | | Product revision | PRV | 8 | [55:48] | - | Not fixed | | Product serial number | PSN | 32 | [47:16] | - | 1) | | Manufacturing date | MDT | 8 | [15:8] | - | | | CRC7 checksum | CRC | 7 | [7:1] | - | | | Not used, always '1' | | 1 | [0:0] | 0X1 | | <sup>1)</sup> If PSN is to be used as a Unique ID, a composition PSN and MDT should be used. Whole CID can also be used to generate a unique ID [Table 24] Card identification (CID) fields ## 8.3 Card specific data register (CSD) The card specific data (CSD) register provides information on how to access e-NAND contents. The CSD defines the data format, error correction type, maximum data access time, data transfer speed and so on. The programmable part of the register (entries marked by W or E, see below) can be changed by CMD27. The type of the CSD Registry entries in the Table 25 below is coded as follows: - R: Read only. - W: One time programmable and not readable. - R/W: One time programmable and readable. - W/E: Multiple writable with value kept after power failure, H/W reset assertion and any CMD0 reset and not readable. - R/W/E: Multiple writable with value kept after power failure, H/W reset assertion and any CMD0 reset and readable. - R/W/C P: Writable after value cleared by power failure and HW/rest assertion (the value not cleared by CMD0 reset) and readable. - R/W/E\_P: Multiple writable with value reset after power failure, H/W reset assertion and any CMD0 reset and readable. - W/E\_P: Multiple writable with value reset after power failure, H/W reset assertion and any CMD0 reset and not readable. | Name | Field | Width | Cell type | CSD slice | CSD value | Remark | |--------------------------------------------------|--------------------|-------|-----------|-----------|-----------|--------| | CSD structure | CSD_STRUCTURE | 2 | R | [127:126] | 0X03 | | | System specification version | SPEC_VERS | 4 | R | [125:122] | 0X04 | | | Reserved | | 2 | R | [121:120] | | | | Data read access-time 1 | TAAC | 8 | R | [119:112] | 0X5E | | | Data read access-time 2 in CLK cycles (NSAC*100) | NSAC | 8 | R | [111:104] | 0X00 | | | Max. bus clock frequency | TRAN_SPEED | 8 | R | [103:96] | 0X32 | | | Card command classes | CCC | 12 | R | [95:84] | 0X8F5 | | | Max. read data block length | READ_BL_LEN | 4 | R | [83:80] | 0X09 | | | Partial blocks for read allowed | READ_BL_PARTIAL | 1 | R | [79:79] | 0X00 | | | Write block misalignment | WRITE_BLK_MISALIGN | 1 | R | [78:78] | 0X00 | | | Read block misalignment | READ_BLK_MISALIGN | 1 | R | [77:77] | 0X00 | | | DSR implemented | DSR_IMP | 1 | R | [76:76] | 0X00 | | | Reserved | | 2 | R | [75:74] | | | | Device size | C_SIZE | 12 | R | [73:62] | 0XFFF | | | Max. read current @ VDD min | VDD_R_CURR_MIN | 3 | R | [61:59] | 0X07 | | | Max. read current @ VDD max | VDD_R_CURR_MAX | 3 | R | [58:56] | 0X07 | | | Max. write current @ VDD min | VDD_W_CURR_MIN | 3 | R | [55:53] | 0X07 | | | Max. write current @ VDD max | VDD_W_CURR_MAX | 3 | R | [52:50] | 0X07 | | | Device size multiplier | C_SIZE_MULT | 3 | R | [49:47] | 0X07 | | | Erase group size | ERASE_GRP_SIZE | 5 | R | [46:42] | 0X1F | | | Erase group size multiplier | ERASE_GRP_MULT | 5 | R | [41:37] | 0X1F | | [Table 25] CSD fields | Name | Field | Width | Cell type | CSD slice | CSD value | Remark | |----------------------------------|------------------------|-------|-----------|-----------|-----------|-----------| | Write protect group size | WP_GRP_SIZE | 5 | R | [36:32] | 0x0F | | | Write protect group enable | WP_GRP_ENABLE | 1 | R | [31:31] | 0X01 | | | Manufacturer default ECC | DEFAULT_ECC | 2 | R | [30:29] | 0X00 | | | Write speed factor | R2W_FACTOR | 3 | R | [28:26] | 0X03 | | | Max. write data block length | WRITE_BL_LEN | 4 | R | [25:22] | 0X09 | | | Partial blocks for write allowed | WRITE_BL_PARTIAL | 1 | R | [21:21] | 0X00 | | | Reserved | | 4 | R | [20:17] | | | | Content protection application | CONTENT_PROT_APP | 1 | R | [16:16] | 0X00 | | | File format group | FILE_FORMAT_GRP | 1 | R/W | [15:15] | 0X00 | | | Copy flag (OTP) | COPY | 1 | R/W | [14:14] | 0X00 | | | Permanent write protection | PERM_WRITE_PROTEC<br>T | 1 | R/W | [13:13] | 0X00 | | | Temporary write protection | TMP_WRITE_PROTECT | 1 | R/W/E | [12:12] | 0X00 | | | File format | FILE_FORMAT | 2 | R/W | [11:10] | 0X00 | | | ECC code | ECC | 2 | R/W/E | [9:8] | 0X00 | | | CRC | CRC | 7 | R/W/E | [7:1] | - | Not fixed | | Not used, always '1' | | 1 | | [0:0] | 0X01 | | # [Table 25] CSD fields (Continued) The following sections describe the CSD fields and the relevant data types. If not explicitly defined otherwise, all bit strings are interpreted as binary coded numbers starting with the left bit first. # 8.4 Extended CSD register The Extended CSD register defines e-NAND properties and selected modes. It is 512 bytes long. The most significant 320 bytes are the Properties segment, which defines e-NAND capabilities and cannot be modified by the host. The lower 192 bytes are the modes segment, which defines the configuration e-NAND is working in. These modes can be changed by the host by means of the switch command. | Name | Field | CSD slice | Cell Type | CSD value | Remark | |-------------------------------------------|-----------------------------------------------|-----------|-----------|------------|--------| | Properties segment | | | | | | | Reserved | | [511:506] | | | | | Extended Security Commands Error | EXT_SECURITY_ERR | [505] | R | 0x00 | | | Supported command sets | S_CMD_SET | [504] | R | 0x01 | | | HPI features | HPI_FEATURES | [503] | R | 0x01 | | | Background operations support | BKOPS_SUPPORT | [502] | R | 0x01 | | | Max packed read commands | MAX_PACKED_READS | [501] | R | 0x3F | | | Max packed write commands | MAX_PACKED_WRITES | [500] | R | 0x3F | | | Data Tag Support | DATA_TAG_SUPPORT | [499] | R | 0x01 | | | Tag Unit Size | TAG_UNIT_SIZE | [498] | R | 0x00 | | | Tag Resources Size | TAG_RES_SIZE | [497] | R | 0x00 | | | Context management capabilities | CONTEXT_CAPABILITIES | [496] | R | 0x05 | | | Large Unit size | LARGE_UNIT_SIZE_M1 | [495] | R | 0x01 | | | Extended partitions attribute support | EXT_SUPPORT | [494] | R | 0x03 | | | Supported modes | SUPPORTED_MODES | [493] | R | 0x01 | | | FFU features | FFU_FEATURES | [492] | R | 0x00 | | | Operation codes timeout | OPERATION_CODE_TIME OUT | [491] | R | 0x00 | | | FFU Argument | FFU_ARG | [490:487] | R | 0xFFFAFFF0 | | | Barrier support | BARRIER_SUPPORT | [486] | R | 0x01 | | | Reserved | | [485:309] | | | | | CMD Queuing Support | CMDQ_SUPPORT | [308] | R | 0x01 | | | CMD Queuing Depth | CMDQ_DEPTH | [307] | R | 0x1F | | | Reserved | | [306] | | | | | Number of FW sectors correctly programmed | NUMBER_OF_FW_SECTORS_CORRECTLY_P<br>ROGRAMMED | [305:302] | R | 0x00000000 | | | Vendor proprietary health report | VENDOR_PROPRIETARY_HEALTH_REPORT | [301:270] | R | - | | [Table 26] Extended CSD | Name | Field | CSD slice | Cell Type | CSD value | Remark | |------------------------------------------------------------|----------------------------|-----------|-----------|----------------------------------------------|-------------| | Device life time estimation type B | DEVICE_LIFE_TIME_EST_TYP_B | [269] | R | Variable | | | Device life time estimation type A | DEVICE_LIFE_TIME_EST_TYP_A | [268] | R | Variable | | | Pre EOL information | PRE_EOL_INFO | [267] | R | 0x01 | | | Optimal read size | OPTIMAL_READ_SIZE | [266] | R | 0x20 | | | Optimal write size | OPTIMAL_WRITE_SIZE | [265] | R | 0x20 | | | Optimal trim unit size | OPTIMAL_TRIM_UNIT_SIZE | [264] | R | 0x01 | | | Device version | DEVICE_VERSION | [263:262] | R | 16GB: 0x410E<br>32GB: 0x420E<br>64GB: 0x430E | | | Firmware version | FIRMWARE_VERSION | [261:254] | R | - | Not fixed | | Power class for 200MHz, DDR at Vcc=3.6V | PWR_CL_DDR_200_360 | [253] | R | 0x04 | | | Cache size | CACHE_SIZE | [252:249] | R | 0x00000800 | | | Generic CMD6 timeout | GENERIC_CMD6_TIME | [248] | R | 0x0A | | | Power off Notification (long) timeout | POWER_OFF_LONG_TIME | [247] | R | 0x3C | | | Background operations status | BKOPS_STATUS | [246] | R | 0x00 | | | Number of correctly programmed sectors | CORRECTLY_PRG_SECTORS_NUM | [245:242] | R | - | Not fixed | | 1st initialization time after partitioning | INI_TIMEOUT_AP | [241] | R | 0x0A | | | Cache Flushing Policy | CACHE_FLUSH_POLICY | [240] | R | 0x01 | | | Power class for 52MHz, DDR at Vcc=3.6V | PWR_CL_DDR_52_360 | [239] | R | 0x00 | | | Power class for 52MHz, DDR at Vcc=1.95V | PWR_CL_DDR_52_195 | [238] | R | 0x00 | Not support | | Power class for 200MHz<br>at Vccq=1.95, Vcc=3.6V | PWR_CL_200_195 | [237] | R | 0x00 | | | Power class for 200MHz<br>at Vccq=1.3, Vcc=3.6V | PWR_CL_200_130 | [236] | R | 0x00 | Not support | | Minimum write performance<br>for 8bit at 52MHz in DDR mode | MIN_PERF_DDR_W_8_52 | [235] | R | 0x00 | | | Minimum read performance for 8bit at 52MHz in DDR mode | MIN_PERF_DDR_R_8_52 | [234] | R | 0x00 | | | Reserved | | [233] | | | | | TRIM multiplier | TRIM_MULT | [232] | R | 0x02 | | | Secure feature support | SEC_FEATURE_SUPPORT | [231] | R | 0x55 | | | Secure erase multiplier | SEC_ERASE_MULT | [230] | R | 0xFA | | | Secure TRIM multiplier | SEC_TRIM_MULT | [229] | R | 0xFA | | [Table 26] Extended CSD(Continued) | Name | Field | CSD slice | Cell Type | CSD value | Remark | |----------------------------------------------------------------|-----------------------------------------|-----------|-----------|-----------------------------------------------------------------|-------------| | Boot information | BOOT_INFO | [228] | R | 0x07 | | | Reserved | | [227] | | | | | Boot partition size | BOOT_SIZE_MULTI | [226] | R | 0x20 | | | Access size | ACC_SIZE | [225] | R | 0x07 | | | High-capacity erase unit size | HC_ERASE_GRP_SIZE | [224] | R | 0x01 | | | High-capacity erase timeout | ERASE_TIMEOUT_MULT | [223] | R | 0x02 | | | Reliable write sector count | REL_WR_SEC_C | [222] | R | 0x01 | | | High-capacity write protect group size | HC_WP_GRP_SIZE | [221] | R | 0x10 | | | Sleep current(Vcc) | S_C_Vcc | [220] | R | 0x08 | | | Sleep current(Vccq) | S_C_Vccq | [219] | R | 0x09 | | | Production state awareness timeout | PRODUCTION_STATE_<br>AWARENES S_TIMEOUT | [218] | R | 0x0A | | | Sleep/awake timeout | S_A_TIMEOUT | [217] | R | 0x15 | | | Sleep Notification Timeout | SLEEP_NOTIFICATION_TIME | [216] | R | 0x0E | | | Sector count | SEC_COUNT | [215:212] | R | 16GB:<br>0X1D5A000<br>32GB:<br>0X03A3E000<br>64GB:<br>0X747C000 | | | Secure Write Protect information | SECURE_WP_INFO | [211] | R | 0x01 | | | Minimum write performance for 8bit at52MHz | MIN_PERF_W_8_52 | [210] | R | 16GB: 0X3C<br>32GB: 0x78<br>64GB: 0X8C | | | Minimum read performance<br>for 8bit at 52MHz | MIN_PERF_R_8_52 | [209] | R | 0x8C | | | Minimum write performance for 8bit at 26MHz, for 4bit at 52MHz | MIN_PERF_W_8_26_4_52 | [208] | R | 16GB: 0X3C<br>32GB/64GB:<br>0X46 | | | Minimum read performance for 8bit at 26MHz, for 4bit at 52MHz | MIN_PERF_R_8_26_4_52 | [207] | R | 0x46 | | | Minimum write performance for 4bit at 26MHz | MIN_PERF_W_4_26 | [206] | R | 0x1E | | | Minimum read performance for 4bit at 26MHz | MIN_PERF_R_4_26 | [205] | R | 0x1E | | | Reserved | | [204] | | | | | Power class for 26MHz at 3.6V | PWR_CL_26_360 | [203] | R | 0x00 | | | Power class for 52MHz at 3.6V | PWR_CL_52_360 | [202] | R | 0x00 | | | Power class for 26MHz at 1.95V | PWR_CL_26_195 | [201] | R | 0x00 | Not support | | Power class for 52MHz at 1.95V | PWR_CL_52_195 | [200] | R | 0x00 | Not support | [Table 26] Extended CSD(Continued) | Name | Field | CSD slice | Cell Type | CSD value | Remark | |----------------------------------------|-----------------------|-----------|--------------------|-----------|--------| | Partition switching timing | PARTITION_SWITCH_TIME | [199] | R | 0x01 | | | Out-of-interrupt busy timing | OUT_OF_INTERRUPT_TIME | [198] | R | 0x0A | | | I/O Driver Strength | DRIVER_STRENGTH | [197] | R | 0x1F | | | Device type | DEVICE_TYPE | [196] | R | 0x57 | | | Reserved | | [195] | | | | | CSD structure | CSD_STRUCTURE | [194] | R | 0x02 | | | Reserved | | [193] | | | | | Extended CSD revision | EXT_CSD_REV | [192] | R | 0x08 | | | Modes Segment | | | l | | | | Command set | CMD_SET | [191] | R/W/E_P | 0x00 | | | Reserved | | [190] | | | | | Command set revision | CMD_SET_REV | [189] | R | 0x00 | | | Reserved | | [188] | | | | | Power class | POWER_CLASS | [187] | R/W/E_P | 0x00 | | | Reserved | | [186] | | | | | High-speed interface timing | HS_TIMING | [185] | R/W/E_P | 0x00 | | | Strobe Support | STROBE_SUPPORT | [184] | R | 0x01 | | | Bus width mode | BUS_WIDTH | [183] | W/E_P | 0x00 | | | Reserved | | [182] | | | | | Erased memory content | ERASED_MEM_CONT | [181] | R | 0x00 | | | Reserved | | [180] | | | | | Partition configuration | PARTITION_CONFIG | [179] | R/W/E &<br>R/W/E_P | 0x00 | | | Boot config protection | BOOT_CONFIG_PROT | [178] | R/W/E &<br>R/W/C_P | 0x00 | | | Boot bus conditions | BOOT_BUS_CONDITIONS | [177] | R/W/E | 0x00 | | | Reserved | | [176] | | | | | High-density erase group definition | ERASE_GROUP_DEF | [175] | R/W/E_P | 0x00 | | | Boot write protection status registers | BOOT_WP_STATUS | [174] | R | 0x00 | | | Boot area write protection register | BOOT_WP | [173] | R/W/E &<br>R/W/C_P | 0x00 | | | Reserved | | [172] | | | | [Table 26] Extended CSD(Continued) | Name | Field | CSD slice | Cell Type | CSD value | Remark | |-------------------------------------------|-----------------------------|-----------|-------------------------------|-------------------------------------------------------------|--------| | User area write protection register | USER_WP | [171] | R/W, R/W/<br>C_P & /W/<br>E_P | 0x00 | | | Reserved | | [170] | | | | | FW configuration | FW_CONFIG | [169] | R/W | 0x00 | | | RPMB Size | RPMB_SIZE_MULT | [168] | R | 0x80 | | | Write reliability setting register | WR_REL_SET | [167] | R/W | 0x1F | | | Write reliability parameter register | WR_REL_PARAM | [166] | R | 0x15 | | | Sanitize start | SANITIZE_START | [165] | W/E_P | 0x00 | | | Manually start background operations | BKOPS_START | [164] | W/E_P | 0x00 | | | Enable background operations<br>Handshake | BKOPS_EN | [163] | R/W | 0x00 | | | H/W reset function | RST_n_FUNCTION | [162] | R/W | 0x00 | | | HPI management | HPI_MGMT | [161] | R/W/E_P | 0x00 | | | Partitioning support | PARTITIONING_SUPPORT | [160] | R | 0x07 | | | Max enhanced area size | MAX_ENH_SIZE_MULT | [159:157] | R | 16GB:<br>0X0003AB<br>32GB:<br>0X000747<br>64GB:<br>0X000E8F | | | Partitions attribute | PARTITIONS_ATTRIBUTE | [156] | R/W | 0x00 | | | Partitioning setting | PARTITION_SETTING_COMPLETED | [155] | R/W | 0x00 | | | General purpose partition size | GP_SIZE_MULT | [154:143] | R/W | 0x0000 | | | Enhanced user data area size | ENH_SIZE_MULT | [142:140] | R/W | 0x000000 | | | Enhanced user data start address | ENH_START_ADDR | [139:136] | R/W | 0x00000000 | | | Reserved | | [135] | | | | | Bad Block management mode | SEC_BAD_BLK_MGMNT | [134] | R/W | 0x00 | | | Production state awareness | PRODUCTION_STATE_AWARENESS | [133] | R/W/E | 0x00 | | | Package Case Temperature is Controlled | TCASE_SUPPORT | [132] | W/E_P | 0x00 | | | Periodic Wake-up | PERIODIC_WAKEUP | [131] | R/W/E | 0x00 | | | Program CID/CSD in DDR mode support | PROGRAM_CID_CSD_DDR_SUPPORT | [130] | R | 0x01 | | | Reserved | | [129:128] | | | | | Vendor Specific Fields | VENDOR_SPECIFIC_FIELD | [127:64] | Vendor<br>specific | | | [Table 26] Extended CSD(Continued) | Name | Field | CSD slice | Cell Type | CSD value | Remark | |----------------------------------------------------------|----------------------------------------|-----------|-----------|-------------------------------------------------------------------|--------| | Native sector size | NATIVE_SECTOR_SIZE | [63] | R | 0x01 | | | Sector size emulation | USE_NATIVE_SECTOR | [62] | R/W | 0x00 | | | Sector size | DATA_SECTOR_SIZE | [61] | R | 0x00 | | | 1st initialization after disabling sector size emulation | INI_TIMEOUT_EMU | [60] | R | 0x0A | | | Class 6 commands control | Class6_CTRL | [59] | R/W/E_P | 0x00 | | | Number of addressed group to be Released | DYNCAP_NEEDED | [58] | R | 0x00 | | | Exception events control | EXCEPTION_EVENTS_CTRL | [57:56] | R/W/E_P | 0x0000 | | | Exception events status | EXCEPTION_EVENTS_STATUS | [55:54] | R | 0x0000 | | | Extended Partitions Attribute | EXT_PARTITIONS_ATTRIBUTE | [53:52] | R/W | 0x0000 | | | Context configuration | CONTEXT_CONF | [51:37] | R/W/E_P | 0x0000 | | | Packed command status | PACKED_COMMAND_STATUS | [36] | R | 0x00 | | | Packed command failure index | PACKED_FAILURE_INDEX | [35] | R | 0x00 | | | Power Off Notification | POWER_OFF_NOTIFICATION | [34] | R/W/E_P | 0x00 | | | Control to turn the Cache ON/OFF | CACHE_CTRL | [33] | R/W/E_P | 0x00 | | | Flushing of the cache | FLUSH_CACHE | [32] | W/E_P | 0x00 | | | Control to turn the barrier ON/OFF | BARRIER_CONTROL | [31] | R/W | 0x00 | | | Mode config | MODE_CONFIG | [30] | R/W/E_P | 0x00 | | | Mode operation codes | MODE_OPERATION_CODES | [29] | W/E_P | 0x00 | | | Reserved | | [28:27] | | | | | FFU Status | FFU_STATUS | [26] | R | 0x00 | | | Pre loading data size | PRE_LOADING_DATA_SIZE | [25:22] | R/W/E_P | 0X00000000 | | | Max pre loading data size | MAX_PRE_LOADING_DATA_SIZE | [21:18] | R | 16GB:<br>0x00EAD000<br>32GB:<br>0x01D1F000<br>64GB:<br>0x03A3E000 | | | Product state awareness enablement | PRODUCT_STATE_AWARENESS_<br>ENABLEMENT | [17] | R/W/E & R | 0x01 | | | Secure Removal Type | SECURE_REMOVAL_TYPE | [16] | R/W & R | 0x0B | | | Command Queue Mode Enable | CMDQ_MODE_EN | [15] | R/W/E_P | 0x00 | | | Reserved | | [14:0] | | | | # [Table 26] Extended CSD(Continued) - Reserved bits should read as "0" - Obsolete values should be don't care #### 8.5 RCA (Relative card address) The writable 16-bit relative card address (RCA) register carries the card address assigned by the host during the card identification. This address is used for the addressed host-card communication after the card identification procedure. The default value of the RCA register is 0x0001. The value 0x0000 is reserved to set all cards into the Stand-by State with CMD7. #### 8.6 DSR (Driver stage register) It can be optionally used to improve the bus performance for extended operating conditions (depending on parameters like bus length, transfer rate or number of Devices). The CSD register carries the information about the DSR register usage. The default value of the DSR register is 0x404.