0
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心
发布
  • 发文章

  • 发资料

  • 发帖

  • 提问

  • 发视频

创作活动
NAND16GAH0D

NAND16GAH0D

  • 厂商:

    NUMONYX

  • 封装:

  • 描述:

    NAND16GAH0D - 1 Gbyte, 2 Gbyte, 1.8 V/3 V supply, NAND Flash memories with MultiMediaCard™ interface...

  • 数据手册
  • 价格&库存
NAND16GAH0D 数据手册
NAND08GAH0A NAND16GAH0D 1 Gbyte, 2 Gbyte, 1.8 V/3 V supply, NAND Flash memories with MultiMediaCard™ interface Preliminary Data Features ■ ■ ■ ■ ■ Packaged NAND Flash memory with MultiMediaCard interface 1, 2 Gbytes of formatted data storage eMMC/MultiMediaCard system specification, compliant with V4.1 Full backward compatibilty with previous MultiMediaCard system specification Bus mode – High-speed MultiMediaCard protocol – SPI protocol – Three different data bus widths:1 bit, 4 bits, 8 bits – Data transfer rate: up to 52 Mbyte/s Operating voltage range: – VCCQ =1.8 V/3 V – VCC = 3 V Supported clock frequencies: 0 to 52 MHz Multiple Block Read (x 8 at 52 MHz): up to 3.5 Mbyte/s Multiple Block Write (x 8 at 52 MHz): up to 8.5 Mbyte/s Power dissipation – Standby current: down to 200 µA – Read current: down to 30 mA – Write current: down to 30 mA ■ ■ FBGA LFBGA169 12 x 16 x 1.4 mm (ZA) ■ ■ ■ ■ ■ ■ Error free memory access – Internal enhanced data management algorithm (wear levelling, bad block management, garbage collection) – Internal error correction code Data integrity – Data reliability: less than 1 non-recoverable error per 1014 bits read – Endurance: more that 2,000,000 Program/Erase cycles Security – Password protection of data – Built-in write protection (permanent or temporary) December 2007 Rev 2 1/116 www.numonyx.com 1 This is preliminary information on a new product now in development or undergoing evaluation. Details are subject to change without notice. Contents NAND08GAH0A, NAND16GAH0D Contents 1 2 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Device physical description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 2.1 2.2 Package connections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Form factor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 3 4 Memory array partitioning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 MultiMediaCard interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 4.1 Signals description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 4.1.1 4.1.2 4.1.3 4.1.4 4.1.5 4.1.6 4.1.7 Clock (CLK) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Command (CMD) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Input/outputs (DAT0-DAT7) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 VCC core supply voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 VSS ground . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 VCCQ input/output supply voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 VSSQ supply voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.2 4.3 Bus topology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Power-up and power-down . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.3.1 4.3.2 Power-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 Power-down . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.4 Electrical specifications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 5 High speed MultiMediaCard operation . . . . . . . . . . . . . . . . . . . . . . . . . 24 5.1 5.2 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 Card Identification mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 5.2.1 5.2.2 5.2.3 5.2.4 Card reset . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Input/output voltage range validation . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 From Busy to Ready state . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Card Identification process . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 5.3 Data Transfer mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 5.3.1 5.3.2 5.3.3 Active command set selection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 High speed mode selection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Power class selection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 2/116 NAND08GAH0A, NAND16GAH0D 5.3.4 5.3.5 5.3.6 5.3.7 5.3.8 5.3.9 5.3.10 Contents Bus test procedure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Bus width selection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 Data Read . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 Single Block/Multiple Block Read . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 Data Write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 Single Block/Multiple Block Write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Group Erase . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 5.4 5.5 Write protection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Device locking/unlocking (password protection) . . . . . . . . . . . . . . . . . . . . 37 5.5.1 5.5.2 5.5.3 5.5.4 5.5.5 5.5.6 Setting the password . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 Resetting the password . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 Locking the device . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 Unlocking the device . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 Performing a Forced Erase . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 Application specific commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 5.6 5.7 Clock control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 Error conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 5.7.1 5.7.2 CRC and illegal commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 Read, Write and Erase timeout conditions . . . . . . . . . . . . . . . . . . . . . . 43 6 Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 6.1 6.2 6.3 Command classes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Detailed command description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 Device state transition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 7 Responses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 7.1 7.2 7.3 7.4 7.5 R1 response (normal response command) . . . . . . . . . . . . . . . . . . . . . . . 52 R1b response . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 R2 response (CID, CSD register) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 R3 response (OCR register) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 R4 response (Fast I/O) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 8 Device registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 8.1 8.2 8.3 Operation conditions register (OCR) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 Card identification (CID) register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Card specific data register (CSD) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 3/116 Contents 8.3.1 8.3.2 8.3.3 8.3.4 8.3.5 8.3.6 8.3.7 8.3.8 8.3.9 8.3.10 8.3.11 8.3.12 8.3.13 8.3.14 8.3.15 8.3.16 8.3.17 8.3.18 8.3.19 8.3.20 8.3.21 8.3.22 8.3.23 8.3.24 8.3.25 8.3.26 8.3.27 8.3.28 8.3.29 8.3.30 8.3.31 NAND08GAH0A, NAND16GAH0D CSD_STRUCTURE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 SPEC_VERS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 TAAC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 NSAC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 TRAN_SPEED . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 CCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 READ_BL_LEN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 READ_BL_PARTIAL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 WRITE_BLK_MISALIGN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 READ_BLK_MISALIGN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 DSR_IMP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 C_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 VDD_R_CURR_MIN, VDD_W_CURR_MIN . . . . . . . . . . . . . . . . . . . . . 61 VDD_R_CURR_MAX, VDD_W_CURR_MAX . . . . . . . . . . . . . . . . . . . . 61 C_SIZE_MULT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 ERASE_GRP_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 ERASE_GRP_MULT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 WP_GRP_SIZE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 WP_GRP_ENABLE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 DEFAULT_ECC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 R2W_FACTOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 WRITE_BL_LEN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 WRITE_BL_LEN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 FILE_FORMAT_GRP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 COPY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 PERM_WRITE_PROTECT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 TMP_WRITE_PROTECT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 CONTENT_PROT_APP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 FILE_FORMAT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 ECC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 CRC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 8.4 Extended CSD register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 8.4.1 8.4.2 8.4.3 8.4.4 8.4.5 S_CMD_SET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 MIN_PERF_a_b_ff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 PWR_CL_ff_vvv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 CARD_TYPE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 CSD_STRUCTURE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 4/116 NAND08GAH0A, NAND16GAH0D 8.4.6 8.4.7 8.4.8 8.4.9 8.4.10 8.4.11 Contents EXT_CSD_REV . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 CMD_SET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 CMD_SET_REV . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 POWER_CLASS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 HS_TIMING . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 BUS_WIDTH . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 8.5 8.6 8.7 RCA (relative card address) register . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 DSR (driver stage register) register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 Status register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 9 Timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 9.1 Command and response timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 9.1.1 9.1.2 9.1.3 9.1.4 9.1.5 9.1.6 Card identification and card operation conditions . . . . . . . . . . . . . . . . . 76 Assignment of relative card address . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 Data Transfer mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 R1b responses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 Last device response to Next Host command . . . . . . . . . . . . . . . . . . . . 77 Last Host command to Next Host command . . . . . . . . . . . . . . . . . . . . . 77 9.2 Data Read timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 9.2.1 9.2.2 Single Block Read . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 Multiple Block Read . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 9.3 Data Write timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 9.3.1 9.3.2 9.3.3 9.3.4 Single Block Write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 Multiple Block Write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 Erase, Set and Clear Write Protect . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Reselecting a busy device . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 9.4 Bus test procedure timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 10 Serial peripheral interface (SPI) mode . . . . . . . . . . . . . . . . . . . . . . . . . 83 10.1 10.2 10.3 10.4 SPI bus topology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 SPI electrical interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83 SPI bus operating conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 SPI bus protocol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 10.4.1 10.4.2 10.4.3 Mode selection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 Bus transfer protection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 Data Read . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 5/116 Contents 10.4.4 10.4.5 10.4.6 10.4.7 10.4.8 10.4.9 NAND08GAH0A, NAND16GAH0D Data Write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 Erase and Write Protect management . . . . . . . . . . . . . . . . . . . . . . . . . . 91 Read the CID and CSD registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 Reset sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 Clock control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 Error conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92 10.4.10 Read, Write, Erase and Forced Erase timeout conditions . . . . . . . . . . . 93 10.4.11 Memory array partitioning . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 10.4.12 Lock/Unlock commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 10.4.13 Application specific commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93 10.5 10.6 SPI mode commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 SPI mode responses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 10.6.1 10.6.2 10.6.3 10.6.4 10.6.5 10.6.6 10.6.7 R1 format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 R1b format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 R2 format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 R3 format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 Data response format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 Data messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 Data error messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 10.7 10.8 10.9 Clearing Status Register bits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 Device registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 SPI bus timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 10.9.1 10.9.2 10.9.3 Command/response timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 Data Read timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 Data Write timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 11 Error protection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 11.1 11.2 CRC7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 CRC16 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 12 13 14 Package mechanical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112 Part numbering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114 Revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 6/116 NAND08GAH0A, NAND16GAH0D List of tables List of tables Table 1. Table 2. Table 3. Table 4. Table 5. Table 6. Table 7. Table 8. Table 9. Table 10. Table 11. Table 12. Table 13. Table 14. Table 15. Table 16. Table 17. Table 18. Table 19. Table 20. Table 21. Table 22. Table 23. Table 24. Table 25. Table 26. Table 27. Table 28. Table 29. Table 30. Table 31. Table 32. Table 33. Table 34. Table 35. Table 36. Table 37. Table 38. Table 39. Table 40. Table 41. Table 42. Table 43. Table 44. Table 45. Table 46. Table 47. Table 48. System performance. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Current consumption . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 System reliability and maintenance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Communication channel performance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Signal names . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Bus operating conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Open-drain mode bus signal level . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Push-pull mode bus signal level . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Bus AC timings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 Bus modes overview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Data format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 1-bit bus test pattern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 4-bit bus test pattern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 8-bit bus test pattern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Lock/Unlock data block . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 Formulae to calculate typical access and program times . . . . . . . . . . . . . . . . . . . . . . . . . . 43 MultiMediaCard command format. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 Device command classes (CCCs) - supported commands 0 to 27 . . . . . . . . . . . . . . . . . . 45 Card command classes (CCCs) - supported commands 28 to 56 . . . . . . . . . . . . . . . . . . . 45 Basic commands for read-only devices (class 0) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 Block oriented Read commands (class 2) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Block oriented Write commands (class 4). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 Block oriented Write commands (class 6). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 Erase commands (class 5) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 I/O mode commands (class 9) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 Lock (class 7) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 Device state transition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 R1 response . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 R2 response . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 R3 response . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 R4 response . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 OCR register definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 Card identification (CID) register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Card specific data register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 CSD register structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 System specification version . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 TAAC access time definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 Maximum bus clock frequency definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Supported card command classes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Data block length . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 DSR implementation code . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 Current consumption at VCCmin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 Current consumption at VCCmax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 Multiply factor for the device size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 R2W_FACTOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 File formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 ECC type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 CSD field command classes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 7/116 List of tables Table 49. Table 50. Table 51. Table 52. Table 53. Table 54. Table 55. Table 56. Table 57. Table 58. Table 59. Table 60. Table 61. Table 62. Table 63. Table 64. Table 65. Table 66. Table 67. Table 68. Table 69. Table 70. Table 71. Table 72. Table 73. Table 74. NAND08GAH0A, NAND16GAH0D Extended CSD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 Supported command sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 R/W access performance values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 Power classes. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Card type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 CSD Register structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 Extended CSD revision. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 Standard MMC command set revisions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 Power class code . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 Bus mode values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 Status register. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 Timing symbols . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 Timing values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 SPI interface pin configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 MultiMediaCard registers in SPI mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 Command format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 Command classes in SPI mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94 Commands and arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95 Data message first byte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 Status bits definition in SPI mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103 Status bits versus commands and classes (SPI mode) . . . . . . . . . . . . . . . . . . . . . . . . . . 105 SPI timing symbols . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 SPI timing values . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106 LFBGA169 12 x 16 x 1.4 mm 132+21+16 3R14 0.50 mm, package mechanical data . . . 112 Ordering information scheme . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114 Document revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 8/116 NAND08GAH0A, NAND16GAH0D List of figures List of figures Figure 1. Figure 2. Figure 3. Figure 4. Figure 5. Figure 6. Figure 7. Figure 8. Figure 9. Figure 10. Figure 11. Figure 12. Figure 13. Figure 14. Figure 15. Figure 16. Figure 17. Figure 18. Figure 19. Figure 20. Figure 21. Figure 22. Figure 23. Figure 24. Figure 25. Figure 26. Figure 27. Figure 28. Figure 29. Figure 30. Figure 31. Figure 32. Figure 33. Figure 34. Figure 35. Figure 36. Figure 37. Figure 38. Figure 39. Figure 40. Figure 41. Figure 42. Figure 43. Figure 44. Figure 45. Figure 46. Figure 47. Figure 48. Device block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 LFBGA169 package connections (top view through package) . . . . . . . . . . . . . . . . . . . . . . 14 Form factor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Memory array structure. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 Bus circuitry diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Power-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 Power cycling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 Bus signal levels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 Timing diagram data input/output referenced to clock . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 MultiMediaCard state diagram (Card Identification mode) . . . . . . . . . . . . . . . . . . . . . . . . . 27 Data transfer formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 MultiMediaCard state diagram (Data Transfer mode). . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 Identification timing diagram (Card Identification mode). . . . . . . . . . . . . . . . . . . . . . . . . . . 76 SET_RCA timing diagram (Card Identification mode) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 Command response timing diagram (Data Transfer mode) . . . . . . . . . . . . . . . . . . . . . . . . 76 R1b response timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 Last device response to Next Host command timing diagram . . . . . . . . . . . . . . . . . . . . . . 77 Command n end to CMD n+1 start timing diagram (all modes) . . . . . . . . . . . . . . . . . . . . . 77 Single Block Read command timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 Multiple Block Read command timing diagram. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78 STOP_TRANSMISSION command timing diagram (CMD12, Data Transfer mode) . . . . . 79 Single Block Write command timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 Multiple Block Write command timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 STOP_TRANSMISSION during data transfer from the host timing diagram . . . . . . . . . . . 81 STOP_TRANSMISSION during CRC status transfer from the device timing diagram . . . . 81 STOP_TRANSMISSION received after last data block (device busy) . . . . . . . . . . . . . . . . 81 STOP_TRANSMISSION received after last data block (device becomes busy) . . . . . . . . 81 4-bit system bus test procedure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 SPI Single Block Read operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86 SPI Multiple Block Read operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87 SPI Read operation – data error . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 SPI Single Block Write operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 SPI Multiple Block Write operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 Erase and Write Protect operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 R1 response format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 R1b response format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 R2 response format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 R3 response format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 Data response format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101 Data error message format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 Host command to device response timing diagram (device ready) . . . . . . . . . . . . . . . . . 107 Host command to device response timing diagram (device busy) . . . . . . . . . . . . . . . . . . 107 Device response to Host command timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 Single Block Read timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 STOP_TRANSMISSION between blocks in Multiple Block Read timing diagram . . . . . . 108 STOP_TRANSMISSION within a block in Multiple Block Read timing diagram . . . . . . . . 108 CSD and CID register Read timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 Single Block Write timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 9/116 List of figures Figure 49. Figure 50. Figure 51. Figure 52. NAND08GAH0A, NAND16GAH0D Multiple Block Write timing diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 CRC7 generator/checker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 CRC16 generator/checker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 LFBGA169 12 x 16 x 1.4 mm 132+21+16 3R14 0.50 mm, package outline . . . . . . . . . . 112 10/116 NAND08GAH0A, NAND16GAH0D Description 1 Description NAND08GAH0A and NAND16GAH0D are embedded Flash memory storage solutions with MultiMediaCard interface (eMMC™). The eMMC™ was developed for universal low cost data storage and communication media. They can be considered as high speed MultiMediaCards embedded in LFBGA169 12 x 16 x 1.4 mm, 0.5 mm pitch package instead of an MMC. The devices are fully compatible with MMC bus and hosts. NAND08GAH0A and NAND16GAH0D communications are made through an advanced 13pin bus. The bus can be either 1-bit, 4-bit, or 8-bit bus width. The devices operate in highspeed mode at clock frequencies equal or higher than 20 MHz. The communication protocol is defined as a part of this MMC standard and referred to as MultiMediaCard mode. For compatibility with existing controllers the devices may offer, in addition to the MultiMediaCard mode, an alternate communication protocol which is based on the SPI standard. The devices are designed to cover a wide area of applications such as smart phones, cameras, organizers, PDA, digital recorders, MP3 players, pagers, electronic toys, etc. They feature high performance, low power consumption, low cost and high density. To meet the requirements of embedded high density storage media and mobile applications, Numonyx NAND08GAH0A and NAND16GAH0D support both 3 V supply voltage (VCC), and 1.8 V/3 V input/output voltage (VCCQ). The devices have a built-in intelligent controller which manages interface protocols, data storage and retrieval, wear leveling, bad block management, garbage collection, internal ECC. In order to meet environmental requirements, Numonyx offers the NAND08GAH0A and NAND16GAH0D in ECOPACK® packages. ECOPACK packages are Lead-free. The category of second Level Interconnect is marked on the package and on the inner box label, in compliance with JEDEC Standard JESD97. The maximum ratings related to soldering conditions are also marked on the inner box label. ECOPACK is an Numonyx trademark. The system performance and characteristics are given in Table 1, Table 2, Table 3, and Table 4. Related documentation ● eMMC™/MultiMediaCard system specification, version 4.1. 11/116 Description Table 1. System performance NAND08GAH0A, NAND16GAH0D Typical value System performance NAND08GAH0A Reset to Ready Multiple Block Read Single Block Read Multiple Block Write Single Block Write 100 8.9 1.0 2.8 0.1 NAND16GAH0D 100 8.5 1.0 3.5 0.1 ms Mbyte/s Mbyte/s Mbyte/s Mbyte/s Unit Table 2. Operation Current consumption Test conditions Current consumption Unit NAND08GAH0A Typ. Max. NAND16GAH0D Typ. 25 60 20 200 100 200 µA Max. mA mA Read Write VCC= 3 V±5% VCCQ= 3 V±5% or 1.8 V±5% VCC= 3 V±5% 20 40 10 100 Standby VCCQ= 3 V±5% or 1.8 V±5% Table 3. MTBF System reliability and maintenance > 3 million hours None less than 1 non-recoverable error per 1014 bits read 2 000 000 Preventive maintenance Data reliability Endurance Table 4. Communication channel performance MultiMediaCard communication channel performance Three-wire serial data bus (Clock, command, data) Variable clock rate 0, 26, 52 MHz Easy card identification Error protected data transfer Sequential and single/multiple block oriented data transfer 12/116 NAND08GAH0A, NAND16GAH0D Device physical description 2 Device physical description The NAND08GAH0A and NAND16GAH0D contain a single chip controller and Flash memory module, see Figure 1: Device block diagram. The microcontroller interfaces with a host system allowing data to be written to and read from the Flash memory module. The controller allows the host to be independent from details of erasing and programming the Flash memory. Figure 2 shows the package connections. See Table 5: Signal names for the description of the signals corresponding to the balls. Figure 1. Device block diagram Data I/O MultiMediaCard interface Single Chip controller Control Flash module NAND08GAH0A, NAND16GAH0D AI13614b 13/116 Device physical description NAND08GAH0A, NAND16GAH0D 2.1 Figure 2. Package connections LFBGA169 package connections (top view through package) 14 DNU DNU DNU RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV DNU DNU DNU 13 DNU DNU RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV DNU DNU 12 RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV 11 DNU RSV RSV RSV RSV RSV RSV DNU 10 RSV RSV RSV NC NC NC VSS VCC NC RSV RSV RSV 9 DNU RSV RSV RSV NC VCC RSV RSV RSV DNU 8 RSV RSV RSV NC VSS RSV RSV RSV 7 NC NC RSV VSS NC RSV RSV RSV 6 DNU RSV DAT7 VCCQ VCC NC CLK RSV VSSQ DNU 5 DAT2 DAT6 RSV NC VCC VSS NC NC NC CMD VSSQ VCCQ 4 DNU DAT1 DAT5 VSSQ NC VCCQ VCCQ VSSQ DNU 3 DAT0 DAT4 RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV VCCQ 2 DNU DNU DAT3 VCCI RSV RSV RSV RSV RSV RSV RSV RSV RSV VSSQ DNU DNU 1 DNU DNU DNU RSV RSV RSV RSV RSV RSV RSV RSV RSV RSV DNU DNU DNU A B C D E F G H J K L M N P R T U V W Y AA AB AC AD AE AF AG AH AI13626 1. The ball corresponding to VCCI must be decoupled with capacitance C5 (see Table 6). 2.2 Form factor The ball diameter, d, and the ball pitch, p, for LFBGA169 12 x 16 x 1.4 mm package are: ● ● d = 0.30 mm (solder ball diameter) p = 0.5 mm (ball pitch) Figure 3. Form factor VCCQ d VSSQ NC NC NC p AI13622 14/116 NAND08GAH0A, NAND16GAH0D Memory array partitioning 3 Memory array partitioning The basic unit of data transfer to/from the device is one byte. All data transfer operations which require a block size always define block lengths as integer multiples of bytes. Some special functions need other partition granularity. For block oriented commands, the following definitions are used: ● Block: the unit which is related to the block oriented read and write commands. Its size is the number of bytes which are transferred when one block command is issued by the host. The size of a block is either programmable or fixed. The information about allowed block sizes and the programmability is stored in the CSD register. ● Erase Group: the unit which is related to special erase and write commands defined for R/W cards. Its size is the smallest number of consecutive write blocks which can be addressed for erase. The size of the Erase Group depends on each device and is stored in the CSD. ● Write Protect Group: the smallest unit that may be individually write protected. Its size is defined in units of erase groups. The size of a WP-group depends on each device and is stored in the CSD. Figure 4 shows NAND08GAH0A and NAND16GAH0D memory array organization. Figure 4. Memory array structure NAND08GAH0A, NAND16GAH0D Write Protect Group 0 Erase Group 0 Block 0 Erase Group 1 Erase Group n Write Protect Group 1 Write Protect Group 2 Write Protect Group n MultiMediaCard AI13615b 1. n = number of last Erase Group or last Write Protect Group. 15/116 MultiMediaCard interface NAND08GAH0A, NAND16GAH0D 4 MultiMediaCard interface The signal/pin assignments are listed in Table 5. Refer to this table in conjunction with Figure 2 and Figure 3: Form factor. 4.1 4.1.1 Signals description Clock (CLK) The Clock input, CLK, is used to synchronize the memory to the host during command and data transfers. Each clock cycle gates one bit on the command and on all the data lines. The Clock frequency, fPP, may vary between zero and the maximum clock frequency. 4.1.2 Command (CMD) The CMD signal is a bidirectional command channel used for device initialization and command transfer. The CMD signal has two operating modes: open-drain and push-pull. The open-drain mode is used for initialization, while the push-pull mode is used for fast command transfer. Commands are sent by the MultiMediaCard bus master (or host) to the device who answers by sending back responses. 4.1.3 Input/outputs (DAT0-DAT7) DAT0 to DAT7 are bidirectional data channels. The signals operate in push-pull mode. The NAND08GAH0A and NAND16GAH0D include internal pull ups for all data lines. These signals cannot be driven simultaneously by the host and the NAND08GAH0A device. By default, after power-up or hardware reset, only DAT0 is used for data transfers. The host can configure the device to use a wider data bus, DAT0, DAT0-DAT3 or DAT0-DAT7, for data transfer. 4.1.4 VCC core supply voltage VCC provides the power supply to the internal core of the memory device. It is the main power supply for all operations (read, program and erase). 4.1.5 VSS ground Ground, VSS, is the reference for the power supply. It must be connected to the system ground. 4.1.6 VCCQ input/output supply voltage VCCQ provides the power supply to the I/O pins and enables all outputs to be powered independently from VCC. The input/output voltage (VCCQ) can be either within 1.65/1.7 V and 1.95 V (low voltage range) or 2.7 V and 3.6 V (high voltage range). 16/116 NAND08GAH0A, NAND16GAH0D MultiMediaCard interface 4.1.7 VSSQ supply voltage VSSQ ground is the reference for the input/output circuitry driven by VCCQ. Table 5. Name DAT0 DAT1 DAT2 DAT3 DAT4 DAT5 DAT6 DAT7 CMD CLK VCCQ VCC VSSQ VCCI VCC NC RSV DNU NC RSV DNU I Signal names Type(1) I/O (PP) I/O (PP) I/O (PP) I/O (PP) I/O (PP) I/O (PP) I/O (PP) I/O (PP) I/O (OD or PP) I (PP) Data Data Data Data Data Data Data Data Command Clock Input/output power supply Core power supply Input/output ground Must be decoupled with capacitance C5 (see Table 6) Core power supply Not connected(2) Reserved for future use(2) Do not use(2) Description 1. I: input; O: output, OD: open drain, PP: push-pull. 2. NC, RSV and DNU pins can be connected to ground or left floating. 17/116 MultiMediaCard interface NAND08GAH0A, NAND16GAH0D 4.2 Bus topology Figure 5 shows the bus circuitry required for the device. The resistor ROD is switched on and off, synchronously, by the host for the open-drain and push-pull mode transitions. RDAT and RCMD are pull-up resistors that are used to stop the CMD and DAT signals floating when no device is inserted or when all the device drivers are in a high impedance state. A constant current source can replace ROD and achieve a better performance (constant slopes for the signal’s rising and falling edges). If the host does not allow a switchable ROD to be implemented, a fixed RCMD can be used. Consequently, the maximum operating frequency in the open drain mode has to be reduced if the value of RCMD is higher than the minimum given in Table 6: Bus operating conditions. Figure 5. Bus circuitry diagram NAND08GAH0A/NAND16GAH0D in LFBGA169 package VCC VCC VCC VCC VCCQ ROD RDAT RCMD VCCi On-chip regulator HOST C5 CMD DAT CLK CBUS = max (C1, C2, C3) C1 C2 C3 Microcontroller MMC I/O interface Core Flash I/O interface Flash module VSS,VSSQ VSS,VSSQ AI13192c 1. See Table 6 for the values of ROD, RDAT, RCMD, C1, C2, C3, and C5. 18/116 NAND08GAH0A, NAND16GAH0D MultiMediaCard interface 4.3 4.3.1 Power-up and power-down Power-up The power-up and hot insertion (e.g. inserting the device when the bus is operating) are handled locally in each device and in the bus master. VCC must be powered up before or simultaneously with VCCQ. No delay must be respected between VCC and VCCQ ramp up (see Figure 8). After power-up the device enters the Idle state until the CMD1 command is received. The bus master must get the device out of the Idle state. Since the power-up time and the supply voltage ramp up time depend on application parameters such as the bus length and the power supply unit, the host must ensure that the supply voltage has reached the operating level specified in CMD1 before issuing a CMD1 command. CMD1 is a special synchronization command for the host to poll the device states until the power-up is completed correctly. The response of CMD1 contains a busy flag which indicates that a device is not ready. The host has to wait until this flag is cleared. The time for this flag to be cleared is the Identification delay (see Figure 6). After power-up the host starts the clock and sends the initializing sequence on the CMD line (see Figure 6). This sequence is a contiguous stream of logic 1 s. The sequence length is either 1 ms, 74 clock cycles or the supply ramp up time, whichever is the longest. The additional 10 clocks (after the 64 clocks after which the device should be ready for communication) are provided to avoid power-up synchronization problems. The device ignores all commands until the commands CMD1, CMD2 are issued and the RCA of the device is initialized. The initialization delay is relevant only after power-up, the identification delay is relevant for both power-up and hot insertion. After power-up, the maximum initial load the NAND08GAH0A and NAND16GAH0D can present on the VCC line is C4, in parallel with a minimum of R4. During operation, device capacitance on the VCC line must not exceed 10 µF. 4.3.2 Power-down At power-down, VCCQ must go Low before or simultaneously with VCC going Low (see Figure 9). Commands from the bus master are accepted till VCCQ and VCC start to ramp down. 19/116 MultiMediaCard interface Figure 6. Power-up NAND08GAH0A, NAND16GAH0D Supply voltage (3) VCCmax Bus Master voltage (3) VCC VCCmin(3) VCCQmax(3) VCCQmin(3) Memory field working voltage range Card logic working voltage range Time Power Up Supply ramping up First CMD1 to card ready NCC(2) NCC CMD1 CMD1 CMD1 NCC CMD2 Initialization sequence (1) CMD1 repeated until busy flag cleared Initialization delay Identification delay AI14104 1. The initialization sequence is a contiguous stream of logic 1’s. Its length is either 1 ms, 74 clocks or the supply ramp up time, whichever is the longest. The device shall complete its initialization within 1 second from the first CMD1 with a valid V range. 2. NCC is the number of clock cycles. Refer to Table 61 for its value. 3. Refer to Section 8.1: Operation conditions register (OCR) for details on voltage ranges. Figure 7. Power cycling Supply Voltage VCC VCCmin VCCQ VCCQmin Time Command input prohibited Command input prohibited AI14122 20/116 NAND08GAH0A, NAND16GAH0D MultiMediaCard interface 4.4 Electrical specifications Table 6 defines the bus operating conditions for the device. The total capacitance CL of each line of the bus is given by the below equation: C L = C HOST + C BUS + C CARD where CHOST is the bus master capacitance, CBUS the bus capacitance itself and CCARD the capacitance of the device connected to this line. The sum of the host and bus capacitance, CHOST+CBUS, must not to exceed 20 pF. As the bus can be supplied with a variable supply voltage, all bus signal levels are related to the supply voltage (see Figure 8, Table 7, and Table 8). Table 6. Symbol Peak voltage on all lines Input leakage current on all inputs (before initialization sequence and/or internal pull up resistors connected)(3) Input leakage current on all inputs (after initialization sequence and/or internal pull up resistors connected)(3) Output leakage current on all outputs (before initialization sequence) Output leakage current on all outputs (after initialization sequence) Low supply-voltage range (MultiMediaCard v. 4.1) VCCQ VCC VSS RDAT RCMD RINT R4 C4 CL CCARD C1 C2 C3 C5 High supply-voltage range Input/output supply voltage Supply voltage ground Pull-up resistance (to prevent bus floating) Pull-up resistance (to prevent bus floating) Internal pull up resistance DAT1-DAT7 (to prevent unconnected line floating) Load resistance on VCC line after power-up or hot insertion Load capacitance on VCC line after power-up or hot insertion Bus signal line capacitance Single card capacitance Load capacitance on CMD input Load capacitance on DAT input Load capacitance on CLK input Decoupling capacitance on VCCI input Maximum signal line inductance (fPP ≤52 MHz) TBD TBD TBD Bus operating conditions(1)(2) Parameter Min − 0.5 − 100 − 10 − 100 − 10 1.65 2.7 2.7 − 0.5 50 4.7 50 330 10 30 7 TBD TBD TBD 1 16 Max 3.6 100 10 100 10 1.95 V 3.6 3.6 0.5 100 100 150 V V kΩ kΩ kΩ Ω µF pF pF pF pF pF pF nH Unit V µA µA µA µA 1. The current consumption of the device for the different configurations is defined in the POWER_CLASS field of the EXT_CSD register (see Section 8.4). 2. TBD stands for ‘to be defined’. 3. See Section 4.3: Power-up and power-down. 21/116 MultiMediaCard interface Figure 8. Bus signal levels V VCCQ Input High Level VOH VIH NAND08GAH0A, NAND16GAH0D Output High Level Undefined VIL Input Low Level VOL VSSQ Output Low Level t AI13194b Table 7. Symbol VOH VOL Open-drain mode bus signal level(1) Parameter Output High voltage Output Low voltage Conditions IOH = –100 µA IOL = 2 mA Min VCCQ–0.2 0.3 Max Unit V V 1. The values of VIH and VIL are identical in Open-drain and Push-pull mode (see Table 8: Push-pull mode bus signal level). Table 8. Push-pull mode bus signal level(1) VCCQ Symbol Parameter Conditions 1.65 to 1.95 V Min Max 2.7 to 3.6 V Min 0.75 VCCQ Max Unit VOH VOL VIH VIL Output High voltage IOH = –100 µA at VCCQmin VCCQ–0.2 Output Low voltage Input High voltage Input Low voltage IOL = 100 µA at VCCQmin 0.7VCCQ VSSQ–0.3 0.2 V 0.125VCCQ V V V VCC + 0.3 0.625VCCQ VCCQ + 0.3 0.3VCCQ VSS–0.3 0.25VCCQ 1. In accordance with the JEDEC specification JESD8-1A, the device input and output voltages should be within the specified ranges for the whole VCC range. 22/116 NAND08GAH0A, NAND16GAH0D Figure 9. Timing diagram data input/output referenced to clock tPP tWL Clock tIH Input NV NV tISU Output NV tOH "NV" is not valid tOSU AI04337 MultiMediaCard interface VIH VIL tTHL tTLH VIH NV VIL VOH VOL Table 9. Symbol Bus AC timings 20 MHz Parameter Min Clock CLK(2) Max Min Max 26/52 MHz(1) Unit fPP fOD tWL tTLH tTHL Clock frequency Data Transfer mode (PP)(3)(4) Clock frequency Identification mode (OD)(5) Clock Low Clock Rise Clock Fall time(3) time(3)(6) 0 0 10 20 400 0 0 6.5 26/52(1) 400 MHz kHz ns 10 10 3 3 ns ns time(3)(6) Input CMD, DAT (referenced to CLK) tISU tIH Input Set-up time(3) Input Hold time(3) 3 3 3 3 ns ns Output CMD, DAT (referenced to CLK) tOSU tOH Output Set-up time(3) Output Hold time(3) 13.1 9.7 5 5 ns ns 1. fPP=52 MHz is available for VCC=2.7 to 3.6 V 2. All timing values are measured relatively to 50% of the voltage level. 3. Parameter measured with a bus line load capacitance, CL, lower than 30 pF. 4. fPP is measured with a tolerance of 100 KHz. 5. fOD is measured with a tolerance of 20 KHz. 6. Rise and fall times are measured from 10% to 90% of the voltage level for High clock frequencies (26 and 52 MHz). They are measured from VIL(max) to VIH (min) of the voltage level for standard clock frequency (20 MHz). 23/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D 5 5.1 High speed MultiMediaCard operation Overview All communication between the host and the device is controlled by the host (master). The host sends two types of command: ● Broadcast commands intended for all MultimediaCard devices. They are kept for backwards compatibility to previous MultiMediaCard systems, where more than one device was allowed on the bus. Addressed (point-to-point) commands which are sent to the addressed device and cause it to respond. ● A general overview of the command flow is shown in Figure 10 for the Card Identification mode and in Figure 12 for the Data Transfer mode. The commands are listed in the command tables (Table 20, Table 21, Table 22, Table 23, and Table 24). The relation between the current device state, the received command and the resulting state are listed in Table 27. The different operating modes are presented in the following sections, together with the restrictions for controlling the clock signal, and device commands, state transitions and timings. Three operating modes are defined for MultiMediaCard devices: ● Card Identification mode The host enter Card Identification mode after reset and while it is looking for new devices connected to the bus. MultiMediaCard devices enter this mode after reset until the SET_RCA command (CMD3) is received. Interrupt mode (not supported) Data Transfer mode The device enters Data Transfer mode once an RCA is assigned to it. The host will enter data transfer mode after identifying all the devices on the bus. ● ● Table 10 shows the relations between bus modes, operation modes and device states. Each state in the device state diagrams is associated with a bus mode and an operation mode (Figure 10 and Figure 12). A command received with an incorrect CRC is ignored. If the command was issued during an operation (for example block read), the device continues the operation until it receives a correct host command. 24/116 NAND08GAH0A, NAND16GAH0D Table 10. M High speed MultiMediaCard operation Bus modes overview Operation mode Inactive Open-drain Bus mode Device state Inactive (ina) Idle Ready Identification (ident) Standby (stby) Transfer (tran) Bus state test (btst) Sending-data (data) Receiving-data (rcv) Programming (pgr) Disconnect Wait-IRQ (irq) Card Identification mode Data Transfer mode Push-pull Interrupt mode Push-pull 5.2 Card Identification mode When in Card Identification mode, the host resets the device, validates the operating voltage range and the access mode, identifies the device and assigns a Relative Card Address (RCA) to it. In Card Identification mode all data communications are performed using only the command line (CMD). 5.2.1 Card reset After power-up, the device is in Idle state and defaults to operate in MultiMediaCard mode, even if it was previously in the Inactive state. The GO_IDLE_STATE (CMD0) command performs a software reset and puts the device in Idle state. It is also used to switch the device into SPI mode (see Section 10: Serial peripheral interface (SPI) mode). After power-up or a CMD0 command, all outputs are high impedance, and the device is initialized with a default RCA (0x0001) and default Driver Stage Register (DSR) settings. The host starts the device identification process in open-drain mode with the clock frequency set to the identification clock frequency fOD (see Table 9: Bus AC timings). CMD0 is valid in all states, with the exception of the Inactive state. While in Inactive state the device does not accept CMD0 commands unless it is used to switch the device into SPI mode. 25/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D 5.2.2 Input/output voltage range validation All device communicate with the host using an input/output voltage in the VCCQmin and VCCQmax range. In Card Identification mode, the minimum and maximum values for VCCQ are defined in the operation condition register (OCR) and may not cover the whole range. The SEND_OP_COND (CMD1) command is designed to provide hosts with a mechanism to identify and reject devices which do not match the desired VCCQ range. This is performed by the host sending the required VCCQ range as the operand of the CMD1 command (see Section 8.1: Operation conditions register (OCR)). If the device can not perform data transfer in the specified range, it switches into the Inactive state. Otherwise, the device answers sending back its VCCQ range. By omitting the voltage range when issuing the CMD1 command (by setting CMD1 argument to ‘0’), the host queries the device about its input/output voltage range. This bus query should be used if the host is able to select a common voltage range, or if the application needs to be notified of non usable devices connected to the bus. The host then chooses an operating voltage, and reissues the CMD1 together with this condition, sending incompatible devices into the Inactive state. 5.2.3 From Busy to Ready state The busy flag in the CMD1 response can be used by the device to notify the host that the power-up/reset sequence is still ongoing and that the device is not ready for communication. In this case the host must reissue the CMD1 command until the busy flag is cleared. During the initialization procedure, the host should not change the operating voltage range or access mode settings. Any change in the operating conditions is ignored by the device. If this case, the host must reset the device by issuing a CMD0 command, and restart the initialization sequence. However, a hardware reset must be performed for accessing devices that are already in the Inactive state. The GO_INACTIVE_STATE (CMD15) command can be used to send an addressed device into the Inactive state. This command is used when the host explicitly wants to de-activate a device by changing its VCC range into a range which is known not to be supported by this device. 5.2.4 Card Identification process This process is valid when multiple MultiMediaCard devices are connected to the bus. The host starts the card identification process in open-drain mode with the identification clock rate fOD (see Table 9: Bus AC timings). The open drain driver stages on the CMD line allow parallel operation during card identification. After the bus is activated, the host will request the devices to send its valid operating conditions (CMD1). The response to CMD1 is the ‘wired and’ operation on the condition restrictions of all devices in the system. Incompatible devices are sent into Inactive state. The host then issues the broadcast command CMD2 and asks all devices for their unique Card Identification (CID) number. All remaining unidentified devices simultaneously start sending their CID numbers serially, while monitoring their outgoing bit stream. The devices, whose outgoing CID bits do not match the corresponding bits on the command line, stop sending their CID immediately and wait for the next identification cycle (devices stay in the Ready state). Since CID numbers are unique for each device, there should be only one device which successfully sends its full CID-number to the host. This device then goes into the Identification state. 26/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation The host issues CMD3 to assign this device a relative card address (RCA) which will be used to address the device in future data transfer communication. Once the RCA is received the device goes to the Standby state and does not react to further identification cycles. The device also switches its output drivers from open-drain to push-pull. The host repeats the identification process as long as it receives a response (CID) to its identification command (CMD2). When no more devices respond to this command, all devices have been identified. Figure 10. MultiMediaCard state diagram (Card Identification mode) Power On Idle state (idle) Device is busy or host omitted voltage range CMD1 (1) CMD0 from all states except (ina) Inactive state (ina) CMD15 Ready state (ready) Card looses bus CMD2 Card wins bus Identification state (ident) CMD3 CARD IDENTIFICATION MODE Wait-IRQ state (irq) CMD40 Standby state (stby) DATA TRANSFER MODE from all states in data transfer mode Any start bit detected on the bus INTERRUPT MODE DATA TRANSFER MODE AI04340b 1. Incompatible VCCQ voltage range. 2. See Table 10: Bus modes overview for the definition of the abbreviated forms corresponding to the device state. 27/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D 5.3 Data Transfer mode The device enters data transfer mode once an RCA is assigned to it. When the device is in Standby mode, issuing the CMD7 command along with the RCA selects the device and puts it into the Transfer state. The host enters Data Transfer mode after identifying all the MultiMediaCard devices on the bus. When all devices are in Standby state, communication over the CMD and DAT lines will be in push-pull mode (see Table 10: Bus modes overview). The device supports two Read/Write modes as shown in Figure 11: Data transfer formats. ● Single Block mode – In this mode the host reads or writes one data block of a pre-specified length. The data block transmission is protected with a 16 bit Cyclic Redundancy Check (CRC). This mode is similar to the single block mode, but the host can read/write multiple data blocks (all have the same length) which will be stored or retrieved from contiguous memory addresses. ● Multiple Block mode – The host issues CMD9 to obtain the Card Specific Data (CSD register). MultiMediaCard devices which already have an RCA do not respond to the identification command flow in this mode. Until the content of all CSD registers is known by the host, the fPP clock rate must remain at fOD because some devices may have operating frequency restrictions. The relationship between the various operation modes is summarized in Figure 12: MultiMediaCard state diagram (Data Transfer mode). 5.3.1 Active command set selection By default, the device uses the MultiMediaCard standard command set after a power-up or software reset (CMD0). The host can change the active command set by issuing the SWITCH command (CMD6) with the ‘Command Set’ access mode selected. The supported command sets, as well as the currently selected command set, are defined in the EXT_CSD register. 5.3.2 High speed mode selection The device operates in high-speed mode (HS-MMC) at clock frequencies higher than 20 MHz. The host must first check whether the Numonyx NAND08GAH0A and NAND16GAH0D comply with eMMC™/MultiMediaCard system specification version 4.1. The high speed mode of the device must then be enables, before changing the clock frequency to a frequency higher than 20 MHz. This is done by using the SWITCH command to write 0x01 to the HS_TIMING byte, in the modes segment of the EXT_CSD register. 28/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.3.3 Power class selection After checking whether the NAND08GAH0A and NAND16GAH0D complies with eMMC™/MultiMediaCard system specification version 4.0 or higher, the host can change the device power class. After power-up or software reset (CMD0), the device defaults to operate in power class 0 which corresponds to the minimum current consumption for the card type (either Low or High VCCQ voltage range). The PWR_CL_ff_vvv bytes of the EXT_CSD register report the power consumption levels of the device, for a 4-bit or 8-bit bus width, at the supported clock frequencies (26 or 52 MHz). The host can read the PWR_CL_ff_vvv bytes by issuing a SEND_EXT_CSD command, and determine if it will allow the device to use a higher power class. The power class can be changed by using the SWITCH command to program the POWER_CLASS Byte, in the modes segment of the EXT_CSD register. The valid values for the EXT_CSD register are defined in (see Section 8.4.3: PWR_CL_ff_vvv). If the value programmed by the host is invalid, the POWER_CLASS byte remains unchanged and the SWITCH_ERROR bit is set. 5.3.4 Bus test procedure The host can detect the bus functional lines by issuing CMD19 and CMD14 commands. The following steps are required to test the bus functional signals: 1. The host must issue a CMD19 command, followed by a specific data pattern on each selected data lines (see Table 11). The data pattern sent by the host may optionally include a CRC16 checksum, which is ignored by the device. The data pattern to be sent per data line is defined in Table 12, Table 13 and Table 14, according to the bus width. The host must then requests the device to send back the reversed data pattern. This is done by issuing a CMD14 command. The device detects the start bit on DAT0 and synchronizes accordingly the reading of all data inputs. It ignores all data pattern bits except for the first two bits. The device buffer size consequently does not limit the maximum length of the data pattern. The minimum length of the data pattern is two bytes, of which the first two bits of each data line are sent back reversed by the device. The host detects the bus functional lines by comparing the initial data pattern with the reversed pattern sent back by the device. The host ignores all bits except for the first two bits of the reversed data pattern. The length of the reversed data pattern is eight bytes and is always sent using all the device DAT lines (see Table 12, Table 13 and Table 14). The reversed data pattern sent by the device may optionally include a CRC16 checksum, which is ignored by the host. 2. 3. The device has internal pull-up resistor on DAT1-DAT7 lines. If the device is connected to 1bit or 4-bit high-speed MMC system, the input value of the upper bits (e.g. DAT1-DAT7 or DAT4-DAT7) are detected as logic “1” by the device. Table 11. Data format Data pattern 1 0 x x x x ... x x Checksum bit CRC16 End bit 1 Start bit 0 29/116 High speed MultiMediaCard operation Table 12. Data line DAT0 DAT1 DAT2 DAT3 DAT4 DAT5 DAT6 DAT7 NAND08GAH0A, NAND16GAH0D 1-bit bus test pattern Reversed pattern sent by the device 0,01000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 Notes Start bit defines beginning of pattern No data pattern sent No data pattern sent No data pattern sent No data pattern sent No data pattern sent No data pattern sent No data pattern sent Data pattern sent by the host 0,10xxxxxxxxxx,[CRC16],1 Table 13. Data line DAT0 DAT1 DAT2 DAT3 DAT4 DAT5 DAT6 DAT7 4-bit bus test pattern Reversed pattern sent by the device 0,01000000,[CRC16],1 0,10000000,[CRC16],1 0,01000000,[CRC16],1 0,10000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 0,00000000,[CRC16],1 No data pattern sent No data pattern sent No data pattern sent No data pattern sent Notes Start bit defines beginning of pattern Data pattern sent by the host 0,10xxxxxxxxxx,[CRC16],1 0,01xxxxxxxxxx,[CRC16],1 0,10xxxxxxxxxx,[CRC16],1 0,01xxxxxxxxxx,[CRC16],1 Table 14. Data line DAT0 DAT1 DAT2 DAT3 DAT4 DAT5 DAT6 DAT7 8-bit bus test pattern Reversed pattern sent by the device 0,01000000,[CRC16],1 0,10000000,[CRC16],1 0,01000000,[CRC16],1 0,10000000,[CRC16],1 0,01000000,[CRC16],1 0,10000000,[CRC16],1 0,01000000,[CRC16],1 0,10000000,[CRC16],1 Notes Start bit defines beginning of pattern Data pattern sent by the host 0,10xxxxxxxxxx,[CRC16],1 0,01xxxxxxxxxx,[CRC16],1 0,10xxxxxxxxxx,[CRC16],1 0,01xxxxxxxxxx,[CRC16],1 0,10xxxxxxxxxx,[CRC16],1 0,01xxxxxxxxxx,[CRC16],1 0,10xxxxxxxxxx,[CRC16],1 0,01xxxxxxxxxx,[CRC16],1 30/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.3.5 Bus width selection After checking the bus functional lines, the host must change the bus width configuration accordingly. This is done by using the SWITCH command to program the BUS_WIDTH byte in the modes segment of the EXT_CSD register. The BUS_WIDTH byte is write only. By default (after power-up or software reset (CMD0)), the contents of the BUS_WIDTH byte is set to 0x00. The valid values for this register are defined in Section 8.4.11: BUS_WIDTH. If the value programmed by the host is invalid, the BUS_WIDTH byte remains unchanged and the SWITCH_ERROR bit is set. Figure 11. Data transfer formats MULTIPLE BLOCK MODE Memory Blocks Memory Blocks Memory Blocks Memory Blocks Memory Blocks Memory Blocks Memory Blocks Start Address SINGLE BLOCK MODE Memory Blocks Memory Blocks Memory Blocks Memory Blocks Stop Transmission Memory Blocks Memory Blocks Memory Blocks Start Address Start Address Start Address AI13618 31/116 High speed MultiMediaCard operation Figure 12. MultiMediaCard state diagram (Data Transfer mode) NAND08GAH0A, NAND16GAH0D CARD IDENTIFICATION MODE CMD3 CMD15 CMD0 INTERRUPT MODE DATA TRANSFER MODE From all states in Data Transfer mode CMD13, 55 No state transition in Data Transfer Sending data State (data) Wait-IRQ State (irq) CMD40 CMD7 CMD12, 'operation complete' CMD8,17 18,30, 56 (r) Any start bit detected on the bus Stand-by State (stby) CMD7 Transfer State (tran) CMD16, 23, 35, 36 CMD4, 9,10, 39 operation complete CMD28, 29,38 operation complete CMD24, 25, 26, 27, 42, 56 (w) CMD19 CMD24,25 CMD7 Disconnect State (dis) CMD7 Programming State (prg) Receive data State (rcv) Bus state test State (btst) CMD12 or 'Transfer end' CMD14 AI13195 1. See Table 10: Bus modes overview for the definition of the abbreviated forms corresponding to the device state. 2. ‘r’ and ‘w’ stand for read and write. 3. If the device was previously selected and was in Transfer state, its connection with the host is released and it moves back to the Standby state when a CMD7 command is issued along with any address different from the device own RCA. 4. Issuing the CMD7 command along with the reserved RCA 0x0000 returns to Standby state. 5. CMD7 commands issued along with the device RCA while the device is in Transfer state are ignored and may be treated as illegal commands. 6. After the device is assigned an RCA it will not respond to identification commands, CMD1, CMD2, or CMD3. 7. The SET_DSR (CMD4) broadcast command configures the device driver stages. It programs its DSR register according to the application bus length and the data transfer rate. The clock rate must then be switched from fOD to fPP. 8. The busy (Dat0=Low) is always active when the device is in Programming state. A host should not send CMD24/CMD25 while the device is in the Programming state and busy is active. However to ensure compatibility with previous MultiMediaCard specification, the device treats CMD24 and CMD25 as legal or illegal commands when in Programming state (while busy is active). 32/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.3.6 Data Read The DAT0-DAT7 input/outputs are High when no data is transmitted. Data Reads allow data to be transferred from the device to the host. All Data Read commands can be aborted at any time by the STOP_TRANSMISSION command (CMD12), which will terminate the data transfer and return the device to the Transfer state. The DAT bus line is High when no data is transmitted. A transmitted data block consists of a start bit (Low), followed by a continuous data stream. The data stream contains the net payload data (and error correction bits if a non-embedded Error Correction is used). The data stream ends with an end bit (High) (see Figure 19, Figure 20, and Figure 21). The data transmission is synchronous to the clock signal. The payload for block oriented data transfer is preserved by a CRC (Cyclic Redundancy Check) check sum. 5.3.7 Single Block/Multiple Block Read The command CMD17 starts a single Block Read at the address specified in the command. After completion of the Single Block Read command, the device returns to the Transfer state. The command CMD18 starts a Multiple Block Read where several consecutive blocks of data are read. The starting address is specified in the command. The blocks will be continuously transferred until a STOP-TRANSMISSION command (CMD12) is issued. Note that the host CMD12 command has an execution delay due to the serial command transmission. The data transfer stops after the end bit of the CMD12 command. The start address for a read operation can be any byte address in the valid address space of the memory card. During Single or Multiple Block Read operations, the basic unit of data transferred is a block whose maximum size is defined in the CSD Register. If READ_BL_PARTIAL is set, smaller blocks whose starting and ending address are contained within one physical block may also be transmitted. A 16 bit CRC (Cyclic Redundancy Check) is appended to the end of each block ensuring data transfer integrity. Multiple Block Read operations can be of two types: ● Open-ended Multiple Block Read operations the number of blocks is not defined and the device keeps transferring data blocks until a STOP_TRANSMISSION command is issued. Multiple Block Read with pre-defined block count The number of blocks to be transferred is pre-determined so the operation stops after the pre-set number of blocks has been transmitted. When the block count is predefined, the STOP_TRANSMISSION command is not required unless an error occurs. To issue the Multiple Block Read operation with pre-defined block count, the READ_MULTIPLE_BLOCK command must be preceded by the SET_BLOCK_COUNT (CMD23) command, failing which the initiated Multiple Block Read operation will be open-ended. If all the arguments of the CMD23 command are set to 0, the command is accepted. However, a subsequent read will follow the open-ended READ_MULTIPLE_BLOCK operation protocol (STOP_TRANSMISSION command is required) If the host sends a STOP-TRANSMISSION command after the last block of a multiple block operation with a pre-defined number of blocks is transmitted, it is regarded as an illegal command, since the device is no longer in sending data state (Data). 33/116 ● High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D If either one of the following errors is detected when the CMD17/CMD18 command is received, the device rejects the CMD17/CMD18 command, remains in Transfer state and sets the corresponding error bit: ● ● ● The address provides by the host as an argument to either CMD17 or CMD18 is out of range. ADDRESS_OUT_OF_RANGE is set. The currently defined block length is illegal for a read operation. BLOCK_LEN_ERROR is set. The address/block-length combination positions the first data block is misaligned to the device physical blocks. ADDRESS_MISALIGN is set. If the device detects an error (e.g. address out of range, address misalignment, internal error, etc.) during a Multiple Block Read operation, it stops data transmission and remains in the sending data state (Data). The host must then abort the operation by sending the STOPTRANSMISSION command. The read error is reported in the response to the STOPTRANSMISSION command. When the host uses partial blocks, if block misalignment is not allowed, the device returns a block misalignment condition (ADDRESS_MISALIGN bit set to ‘1’) if the total length of the partial blocks is not block aligned, and returns to Transfer state. If the host sets the argument of the SET_BLOCK_COUNT command (CMD23) to 0, the command is accepted; however, a subsequent read will follow the open-ended Multiple Block Read protocol (STOP_TRANSMISSION command - CMD12 - is required). 5.3.8 Data Write Data Writes allow data to be transferred from the host to the device. All data write commands can be aborted any time by the CMD12 command. As soon as the data transfer has completed, the device exits the Data Write state and switches either to the Programming state (transfer successful) or Transfer state (transfer failed). The Data Write format is similar to the Data Read format. For block oriented write data transfer, the CRC check bits are added to each data block. The device performs a CRC check for each data block received prior to a write operation. The polynomial is the same as the one used for a read operation. Read and Parameter Set commands are not allowed while the device is programming. Moving another MultiMediaCard from Standby to Transfer state (using CMD7) does not terminate a programming operation. The device switches to the Disconnect state and releases the DAT line. The device can be reselected using CMD7. In this case it moves to the Programming state and reactivates the busy indication. The device provides buffering for Block Write. This means that the next block can be sent to the device while the previous is being programmed. If all the write buffers are full, and the device is in the Programming state, the DAT line will be kept Low. There is no buffering option for Write CSD, Write CID and Erase. This means that while the device is busy servicing any one of these commands, no other data transfer commands will be accepted. The DAT line will be kept Low as long as the device is busy and in the Programming state. Note: Care should be taken by the host not to reset a device (using CMD0 or CMD15) during any pending or active programming operation. This will terminate the operation and may destroy the data stored on the device. 34/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.3.9 Single Block/Multiple Block Write Single or Multiple Block Write (CMD24-27) allows one or more blocks of data to be transferred from the host to the device with a CRC bit appended to the end of each block by the host. A device supporting Block Write must always be able to accept a block of data defined by WRITE_BL_LEN. If the CRC fails, the device indicates the failure on the DAT line; the transferred data will be discarded and all further transmitted blocks (Multiple Block Write mode) will be ignored. Multiple Block Write operations are initiated by issuing the WRITE_MULTIPLE_BLOCK command (CMD25). There are two types of Multiple Block Write operations: ● Open-ended Multiple Block Write The number of blocks is not defined and the host terminates device programming by sending a STOP-TRANSMISSION command. Multiple Block Write with pre-defined block counts The number of blocks to be programmed is pre-determined so the host does not need to send a STOP-TRANSMISSION command to stop the operation. To issue the Multiple Block Write operation with a pre-defined block count, the WRITE_MULTIPLE_BLOCK command must be preceded by the SET_BLOCK_COUNT (CMD23) command, failing which the initiated Multiple Block Write operation will be open-ended. If all the arguments of the CMD23 command are set to 0, the command is accepted. However, a subsequent write will follow the open-ended WRITE_MULTIPLE_BLOCK operation protocol (STOP_TRANSMISSION command is required). If a Multiple Block Write with pre-defined block count is aborted by a STOPTRANSMISSION command, the data in the remaining blocks are invalid. If the host sends a STOP-TRANSMISSION command after the last block of a Multiple Block Write operation with a pre-defined number of blocks is programmed, it is regarded as an illegal command, since the device is no longer in Receiving data state. ● If either one of the following errors is detected when the CMD24-27 command is received, the device rejects the command, remains in Transfer state and sets the corresponding error bit: ● ● ● The address provides by the host as an argument to either CMD24-27 is out of range. ADDRESS_OUT_OF_RANGE is set. The currently defined block length is illegal for a write operation. BLOCK_LEN_ERROR is set. The address/block-length combination positions the first data block is misaligned to the device physical blocks. ADDRESS_MISALIGN is set. If the device detects an error (e.g. write protect violation, address out of range, address misalignment, internal error, etc.) during a Multiple Block Write operation, it stops data transmission and remains in the Receiving data state. The host must then abort the operation by sending the STOP-TRANSMISSION command. The write error is reported in the response to the STOP-TRANSMISSION command. When the host uses partial blocks and block misalignment is not allowed (WRITE_BLK_MIS-ALIGN parameter not set in CSD Register), the total length of the partial blocks must be block aligned otherwise the device detects the misalignment, return an error data response, ignore subsequent incoming data blocks, and return to Transfer state. The block length does not need to be set prior to programming the CID and CSD registers. The Data transferred to the CID and CSD registers is also CRC protected. If a part of the 35/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D CSD or CID register is stored in ROM it will not be overwritten and the device does not check the ROM data with the content of the received buffer. Some devices may require a long time (1 s max) to write a block of data. After receiving a block of data and completing the CRC check, the device begins writing and hold DAT Low if its write buffer is full and unable to accept new data from a new Block Write command. The host may poll the status of the device with a SEND_STATUS command at any time, and the device responds with its status. The status bit READY_FOR_DATA indicates whether the device can accept new data or whether the write process is still in progress. The host may deselect the device by issuing CMD7 (to select a different device) which will place the device in the Disconnect state and release the DAT line without interrupting the write operation. When re-selecting the device, it will reactivate the busy indication by pulling DAT to Low if programming is still in progress and the write buffer is unavailable. If a block write operation is stopped and the block length and CRC of the last block are valid, the data will be programmed. 5.3.10 Group Erase The device supports Group Erase. The size of the Erase Group is defined in the CSD register. To select an Erase Group, a first command with the starting address is followed by a second command with the final address. After a range is selected, the erase operation is performed by issuing an ERASE command (CMD38). The address field in the CMD35/CMD36/CMD38 commands is the group address in units of bytes. The device will ignore all LSBs below the group size. The host must adhere to the following command sequence: ● ● ● ERASE_GROUP_START (CMD35) ERASE_GROUP_END (CMD36) ERASE (CMD38) If an CMD35/CMD36/CMD38 command is received out of sequence the device sets the ERASE_SEQ_ERROR error bit in the Status Register and reset the whole sequence. If the host provides an out of range address as an argument of the CMD35 or CMD36 command, the device rejects the command, returns the ADDRESS_OUT_OF_RANGE error set, and resets the whole erase sequence. If an non-erase command is received (different form CMD35, CMD36, CMD38 or CMD13), the device returns the ERASE_RESET error, resets the erase sequence and executes the last command. Commands not addressed to the selected card do not abort the erase sequence. If the erase group includes write protected blocks, only unprotected blocks are erased. In this case, the WP_ERASE_SKIP status bit of the Status Register is set. The device indicates that an erase operation is in progress by holding DAT to Low. 36/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.4 Write protection The device supports two levels of write protection commands to protect data against erase or write operations: ● ● The entire memory array may be write protected by setting the permanent or temporary write protect bits of the CSD register. Specific segments of the memory may be write protected. The segment size is defined in units of WP_GRP_SIZE erase groups as specified in the CSD register. The SET_WRITE_PROT (CMD28) command sets the write protection of the addressed write-protect group, and the CLR_WRITE_PROT (CMD29) command clears the write protection of the addressed write-protect group. The SEND_WRITE_PROT (CMD30) command is similar to a single block read command. The device sends a data block containing 32 write protection bits (representing 32 write protect groups starting at the specified address) followed by 16 CRC bits. The address field in the write protect commands is a group address in byte units. The device will ignore all LSBs below the group size. If the host provides an out of range address as an argument to CMD28, CMD29 or CMD30, the device rejects the command, returns the ADDRESS_OUT_OF_RANGE error and remains in the Transfer state. 5.5 Device locking/unlocking (password protection) The password protection feature enables the host to lock the device by providing a password, which later will be used for unlocking the device. The password and its size is kept in an 128-bit PWD and 8-bit PWD_LEN registers, respectively. These registers are non-volatile so that a power-up cycle will not erase them. The host is allowed to reset, initialize, select, query for status, etc., but not to access data on the device. If the password has been previously set (PWD_LEN value is not ‘0’), the device is automatically locked after power-up. A locked device answers and executes all commands belonging to the basic class (class 0) and to the Lock Card class (class 7). The host can consequently reset, initialize, select, query for status, etc., but cannot access the data stored in the device. As for the CSD and CID register write commands, the Lock/Unlock commands are available in Transfer state only. This means that they do not require any address argument and that the device has to be selected before issuing any of these commands. The device Lock/Unlock commands have the same structure and comply with the same command/response transaction as single block write commands. The transferred data block 37/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D includes all the required information of the command (password setting mode, password, Lock/Unlock etc.) (see Table 15): ● ● ERASE bit: this bit must be set to ‘1’ (all other bits shall be ‘0’) to perform a Forced Erase operation, and only the Cmd byte is sent. LOCK/UNLOCK bit: The device is locked and unlocked by setting the Lock/Unlock bit to ‘1’ or ‘0’, respectively. Setting this bit together with the SET_PWD bit is allowed, while setting it together with CLR_PWD bit is forbidden. CLR_PWD bit: this bit must be set to ‘1’ to clear the password. SET_PWD bit: this bit must be set to ‘1’ to set a new password. PWD_LEN: this byte contains the password length expressed in bytes. Valid password length ranges from 1 to 16 bytes. PWD_LEN indicates if a password is currently set. If its value is equal to zero, no password is set, if it is different from zero, the device is locked after power-up. Password (PWD): these bytes contain the new or current password (depending on the command). The data block size is defined by the host before sending the device Lock/Unlock command. Different password sizes are allowed. ● ● ● ● The Lock/Unlock command sequences are described in the following paragraphs. Table 15. Byte 0 1 2 ... PWD_LEN + 1 Password data (PWD) Lock/Unlock data block Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 ERASE Bit 2 LOCK_UNLOCK PWD_LEN Bit 1 CLR_PWD Bit 0 SET_PWD Reserved 38/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.5.1 Setting the password The following steps are required to set the password: 1. 2. Select the device if it has not been not previously selected. This is performed by issuing a CMD7 command. Configure the block length by issuing a CMD16 command. The block length is given by the 8-bit Lock/Unlock mode, the 8-bit password size (in bytes), and the number of bytes of the new password. In case of password replacement, the block size must take into account the fact that both the old and the new passwords are sent with the command. Send a Lock/Unlock command on the data line, along with the data block of the appropriate size and 16-bit CRC. The data block must contain the mode (SET_PWD), the length (PWD_LEN) and the password itself. If a password replacement is performed, the length value (PWD_LEN) must take into account both old and the new password length, and the PWD field must be composed of the current password followed by the new password. 3. If a password replacement is attempted with PWD_LEN set to the length of the current password only, or the current password is not correct (different size and content), then the LOCK_UNLOCK_FAILED error bit will be set in the Status Register and the current password is not changed. In case that PWD matches the sent old password then the given new password and its size will be saved in the PWD and PWD_LEN fields, respectively. Note: The device can be locked immediately after setting the password by programming the Lock/Unlock bit to ‘1’ while setting the password or by sending an additional Lock command. 5.5.2 Resetting the password The following steps are required to reset the password: 1. 2. Select the device if it has not been not previously selected. This is performed by issuing a CMD7 command. Configure the block length by issuing a CMD16 command. The block length is given by the 8-bit Lock/Unlock mode, the 8-bit password size (in bytes), and the number of bytes of the current password. Send the Lock/Unlock command on the data line, along with the data block of the appropriate size and 16- bit CRC. The data block must contain the mode (CLR_PWD), the length (PWD_LEN) and the password itself. (PWD). If the PWD and PWD_LEN content match the password and its size, then the content of the PWD register is cleared and PWD_LEN is set to 0. If the password is not correct then the LOCK_UNLOCK_FAILED error bit is set in the Status Register. 3. 39/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D 5.5.3 Locking the device The following steps are required to lock the device: 1. 2. Select the device if it has not been not previously selected. This is performed by issuing a CMD7 command. Configure the block length by issuing a CMD16 command. The block length is given by the 8-bit Lock/Unlock mode, the 8-bit password size (in bytes), and the number of bytes of the current password. Send the Lock/Unlock command on the data line, along with the data block of the appropriate size and 16- bit CRC. The data block must indicate the Lock mode, the length (PWD_LEN) and the password (PWD) itself. If the PWD content is identical to the device password, the device is locked and the locked status bit set in the Status Register. If the password is not correct, the LOCK_UNLOCK_FAILED error bit is set in the Status Register. 3. If the password was previously set (PWD_LEN is not ‘0’), the device is automatically locked after power-up. An attempt to lock a locked device or to lock a device that does with no password defined will fail and the LOCK_UNLOCK_FAILED error bit will be set in the Status Register. Note: It is possible to set the password and to lock the device in the same sequence. In this case the host must go through all the steps required to set the password (see Section 5.5.1: Setting the password) and set the Lock bit while the new password command is issued. 5.5.4 Unlocking the device The following steps are required to lock the device: 1. Configure the block length by issuing a CMD16 command. The block length is given by the 8-bit Lock/Unlock mode, the 8-bit password size (in bytes), and the number of bytes of the current password. Send the Lock/Unlock command on the data line, along with the data block of the appropriate size and 16- bit CRC. The data block indicates the Unlock mode, the length (PWD_LEN) and the password (PWD) itself. If the PWD content is identical to the device password, the device is unlocked and the locked status bit is cleared in the Status Register. If the password is incorrect, the LOCK_UNLOCK_FAILED error bit is set in the Status Register. 2. An attempt to unlock an unlocked device will fail and LOCK_UNLOCK_FAILED error bit will be set in the Status Register. Note: The device is unlocked for the current power session only. As long as the PWD is not cleared, the device will be automatically locked after the next power-up. The only way to unlock the device is to clear the password. 40/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.5.5 Performing a Forced Erase If the user forgets the password, it is possible to erase all the device data along with the PWD content. This operation is called a Forced Erase. The following steps are required to perform a Forced Erase operation on the device: 1. 2. 3. Select the device if it has not been not previously selected. This is performed by issuing a CMD7 command. Configure the block length to 1 byte (8-bit Lock/unlock command) by issuing a CMD16 command. Send the Lock/Unlock command on the data line, along with the data block of the appropriate size and 16- bit CRC. The data block indicates the ERASE mode (the ERASE bit must be the only bit set to ‘1’). The whole memory content is then erased including the password (PWD) and PWD_LEN register, and the locked device is unlocked. In addition, if the device was temporary write protected, it is unprotected (write enabled), and the CSD temporary-write-protect bit and all Write-Protect-Groups are cleared. If other bits than the ERASE bit are set to ‘1’, the LOCK_UNLOCK_FAILED error bit is set and the Forced Erase operation fails. An attempt to force erase on an unlocked device will fail and LOCK_UNLOCK_FAILED error bit will be set in the Status Register. Issuing a Forced Erase command on a permanently-write-protected device will fail, the device will remain locked, and the LOCK_UNLOCK_FAILED error bit will be set. The Forced Erase timeout is specified in Table 16. 5.5.6 Application specific commands The NAND08GAH0A and NAND16GAH0D devices support two application specific commands: ● ● APP_CMD (CMD55) GEN_CMD (CMD56) APP_CMD command (CMD55) Receiving a CMD55 command from the host causes the device to interpret the next command as an application specific command, ACMD. The ACMD command has the same structure as a regular MultiMediaCard standard commands and may have the same CMD number. The device recognizes it as an application specific command because it follows the APP_CMD command. If the application specific version of the command that follows the APP_CMD command is supported, the non standard version is used. If it is not supported, the standard version is used. Let us take the example of a device accepting ACMD13 but not ACMD7. When receiving the APP_CMD command immediately followed by command 13, the device will interpret it as the non standard command ACMD13. Whereas it will interpret command 7 as the standard command CMD7. 41/116 High speed MultiMediaCard operation NAND08GAH0A, NAND16GAH0D To use one of the application specific ACMD commands, the host must follow the steps described below: ● ● Send the APP_CMD command. The device will respond with APP_CMD bit (new status bit) of the response set to ‘1’ to signal to the host that ACMD is now expected. Send the required ACMD command. The device will respond with APP_CMD bit set, indicating that the accepted command was interpreted as an ACMD command. – – If a non-ACMD command is sent, then the device will handle it as a normal command, and the APP_CMD bit in the Card status will remain set to ‘0’. If a non valid command is sent (neither ACMD nor CMD) then the device will handle it as a standard MultiMediaCard illegal command. GEN_CMD command (CMD56) Bus operation during a GEN_CMD command is identical as Single Block Read or Write commands (CMD24 or CMD17). The only difference is that the argument indicates the direction of the data transfer (rather than the address) and the data block is not a memory payload data but has a vendor specific format and meaning. The card must be selected (Transfer state) before the host sends a CMD56 command. The data block size is specified in the BLOCK_LEN defined with CMD16. The response to CMD56 will be of R1 type. 5.6 Clock control The device bus clock signal can be used by the host to set the device to energy saving mode or to control the data flow on the bus. The host is allowed to lower the clock frequency or shut it down. There are a few restrictions the host must follow: ● ● ● The bus frequency can be changed at any time, under the restrictions of maximum data transfer frequency and the identification frequency The clock must be running for the device to output data or response tokens After the last bus transaction, the host is required to provide 8 clock cycles for the device to complete before shutting down the clock. The host is allowed to shut down the clock of a busy device. The device will complete the programming operation regardless of the host clock. However, the host must provide a clock edge for the device to turn off its busy flag. Without a clock edge the MultiMediaCard (unless previously disconnected by a deselect command CMD7) will force the DAT line Low, permanently. 42/116 NAND08GAH0A, NAND16GAH0D High speed MultiMediaCard operation 5.7 5.7.1 Error conditions CRC and illegal commands All commands are protected by CRC (Cyclic Redundancy Check) bits. If the addressed device CRC check fails, the device does not respond and the command is not executed. The device does not change its state, and the COM_CRC_ERROR bit is set in the Status Register. Similarly, if an illegal command has been received, the device will not respond or change its state and will set the ILLEGAL_COMMAND error bit in the Status Register. Error conditions are not shown in the state diagrams (Figure 10 and Figure 12). Refer to Table 27 for a complete state transition description. There are different kinds of illegal commands: ● ● ● Commands which belong to classes not supported by the device (e.g. write commands in read only devices) Commands not allowed in the current state (e.g. CMD2 in Transfer state) Undefined commands (e.g. CMD44). 5.7.2 Read, Write and Erase timeout conditions The times after which a timeout condition for read/write/erase operations occurs are 10 times longer than the typical access/program times for these operations. A device will complete the command within this time, or give up and return an error message. If the host does not get a response within the defined timeout it should assume the device is not going to respond and reset the device. Table 16 gives the formulae required to calculate typical access and program times. Table 16. Time Formulae to calculate typical access and program times(1) Unit Formula Description These parameters define the typical delay between the end bit of the Read command and the start bit of the Data Block. This applies to all Write/Erase commands This gives an approximate value Duration of the Forced Erase operation using CMD42 command Read Access time clock cycles (TAAC + NSAC) Block Write time Erase time Forced Erase time clock cycles clock cycles min (Read Access time * R2W_FACTOR) Number of Erase groups * Block Write time 3 1. See Section 8.3: Card specific data register (CSD) for the definition of the parameters used to calculate the maximum clock frequency. 43/116 Commands NAND08GAH0A, NAND16GAH0D 6 Commands There are four kinds of commands defined on the bus: ● ● ● ● Broadcast commands (bc)—sent on CMD, no response Broadcast commands with response (bcr)— sent on CMD, response (all devices simultaneously) on CMD Addressed (point-to-point) commands (ac)—sent on CMD, response on CMD Addressed (point-to-point) data transfer commands (adtc)—sent on CMD, response on CMD, data transfer on DAT. All commands are 48 bits long, and are protected by a CRC. The command transmission always starts with the MSB (see Table 17: MultiMediaCard command format). 6.1 Command classes The command set of the device is divided into several classes (See Table 18 and Table 19). Each class supports a set of MultiMediaCard functions. Class 0 is mandatory and supported by all MultiMediaCards. The other classes are optional and can be interpreted as a tool box. By using different classes, several configurations can be chosen (e.g. a block writable device). The supported Card Command Classes (CCC) are coded as a parameter in the Card Specific Data (CSD) register of each device, providing the host with information on how to access the device. Table 20, Table 21, Table 22, Table 23 and Table 24 define in detail the device bus commands. Table 27 defines the device state transitions depending on the command received. Table 17. Bit position Width (bits) Value Description MultiMediaCard command format 47 1 ‘0’ Start bit 46 1 ‘1’ Host 45...40 6 x Command 39...8 32 x Argument 7...1 7 x CRC7 0 1 ‘1’ End bit 44/116 NAND08GAH0A, NAND16GAH0D Table 18. Device command class (CCC) Class 0 Class 2 Class 4 Class 5 Class 6 Class 7 Class 9 Commands Device command classes (CCCs) - supported commands 0 to 27 Supported commands, CMD Class description 0 1 2 3 4 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 23 24 25 26 27 +++++ + ++ + + + + + + + + + + + + + + + Basic Block Read Block Write Erase Write Protection Lock I/O mode + Table 19. Card command classes (CCCs) - supported commands 28 to 56 Supported commands, CMD Class description 28 Basic Block Read Block Write Erase Write Protection Lock I/O mode + + + + + + + + + 29 30 35 36 38 39 40 42 55 56 Card command class (CCC) Class 0 Class 2 Class 4 Class 5 Class 6 Class 7 Class 9 45/116 Commands NAND08GAH0A, NAND16GAH0D 6.2 Detailed command description The following tables provide a detailed description of MultiMediaCard commands. The responses R1 to R4 are defined in Section 7: Responses.The registers CID, CSD, EXT_CSD and DSR are described in Section 8: Device registers. Table 20. Cmd Index CMD0 Basic commands for read-only devices (class 0) Type bc Argument [31:0] stuff bits [31:0] OCR without busy Response Abbreviation GO_IDLE_STATE Command description Resets all devices to Idle state. All devices in Idle state after power-up Asks all devices in Idle state to send their OCR content in the response on CMD line Asks all devices in Ready state to send their CID(1) numbers on CMD line Assigns relative address to the device in identification state Programs the DSR of all devices in Standby state CMD1 bcr R3 SEND_OP_COND CMD2 bcr [31:0] stuff bits [31:16] RCA [15:0] stuff bits [31:16] DSR [15:0] stuff bits R2 ALL_SEND_CID CMD3 CMD4 CMD5 ac bc R1 - SET_RELATIVE_ADDR SET_DSR Reserved [31:26] Set to ‘0’ [25:24] Access [23:16] Index [15:8] Value [7:3] Set to ‘0’ [2:0] Cmd Set CMD6 ac R1b SWITCH Switches the device operating mode or modifies the EXT_CSD register (see Section 8.4: Extended CSD register) CMD7 ac [31:16] RCA [15:0] stuff bits R1/R1b(2) SELECT/DESELECT_ CARD Command toggles a device between the Standby and Transfer states or between the Programming and Disconnect states. In both cases the device is selected by its own relative address and deselected by any other address; address 0 deselects all Ask the address device to send back its EXT_CSD register as a data block Asks the addressed device to send its card specific data, CSD, on CMD line. Asks the addressed device to send its card identification data, CID, on CMD line. CMD8 adtc [31:0] stuff bits R1 SEND_EXT_CSD CMD9 ac [31:16] RCA [15:0] stuff bits [31:16] RCA [15:0] stuff bits R2 SEND_CSD CMD10 CMD11 ac R2 SEND_CID Reserved 46/116 NAND08GAH0A, NAND16GAH0D Table 20. Cmd Index CMD12 CMD13 CMD14 Commands Basic commands for read-only devices (class 0) (continued) Type ac ac adtc Argument [31:0] stuff bits [31:16] RCA [15:0] stuff bits [31:0] stuff bits [31:16] RCA [15:0] stuff bits [31:0] stuff bits Response R1/R1b(3) R1 R1 Abbreviation STOP_TRANSMISSION SEND_STAT BUSTEST_R Command description Forces the device to stop transmission. Asks the addressed device to send its Status Register. Reads the reversed bus test data pattern from a device. Sets the device to Inactive state to prevent communication breakdowns in the stack of devices. Sends the bus test data pattern to the device. CMD15 ac - GO_INACTIVE_STATE CMD19 adtc R1 BUSTEST_W 1. The addressing capability for 8-bit address resolution is 232 = 4 Gbytes. 2. The response is R1 when the selecting from Standby to Transfer state, and R1b when selecting from Disconnected state to Programming state. 3. The response is R1 and R1b, for read and write operations, respectively. Table 21. Cmd index CMD16 Block oriented Read commands (class 2) Type Argument [31:0] block length [31:0] data address [31:0] data address Response Abbreviation Command description Selects block length (in bytes) for all following block commands (Read and Write)(1) Reads a block of the size selected by the SET_BLOCKLEN command(2) Continuously send blocks of data until interrupted by a Stop command. ac R1 SET_BLOCKLEN CMD17 CMD18 adtc adtc R1 R1 READ_SINGLE_BLOCK READ_MULTIPLE_BLOCK 1. The default block length is as specified in Section 8.3: Card specific data register (CSD). 2. The data transferred must not cross a physical block boundary unless RD_BLK_MISALIGN is set in the CSD. 47/116 Commands Table 22. Cmd index NAND08GAH0A, NAND16GAH0D Block oriented Write commands (class 4) Type Argument [31:16] set to 0 [15:0] number of blocks Response Abbreviation Command description Defines the number of blocks which are going to be transferred in the next Multiple Block Read or Write command Writes a block of the size selected by the SET_BLOCKLEN command CMD23 ac R1 SET_BLOCK_COUNT CMD24 adtc [31:0] data address R1 WRITE_BLOCK CMD25 adtc [31:0] data address R1 Continuously writes blocks of WRITE_MULTIPLE_BLOCK data until interrupted by a Stop command Programs the CID register - done once per device and is normally reserved for the manufacturer. The device contains hardware to prevent further programming Programs the programmable bits of the CSD CMD26 adtc [31:0] stuff bits R1 PROGRAM_CID CMD27 adtc [31:0] stuff bits R1 PROGRAM_CSD Table 23. Cmd index Block oriented Write commands (class 6) Type Argument Response Abbreviation Command description If the device has write protection features, this command sets the write protection bit of the addressed group. The properties of write protection are coded in the card specific data (WP_GRP_SIZE) If the device provides write protection features, this command clears the write protection bit of the addressed group If the device provides write protection features, this command asks the device to send the status of the write protection bits(1) CMD28 ac [31:0] data address R1b SET_WRITE_PROT CMD29 ac [31:0] data address R1b CLR_WRITE_PROT CMD30 adtc [31:0] write protect data address R1 SEND_WRITE_ PROT CMD31 Reserved 1. 32 write protection bits (representing 32 write protect groups starting at the specified address) followed by 16 CRC bits are transferred in a payload format via the data line. The last (least significant) bit of the protection bits corresponds to the first addressed group. If the addresses of the last groups are outside the valid range, then the corresponding write protection bits are set to zero. 48/116 NAND08GAH0A, NAND16GAH0D Table 24. Cmd index CMD35 Commands Erase commands (class 5) Type Argument [31:0] data address [31:0] data address [31:0] stuff bits Response Abbreviation Command description Sets the address of the first Erase Group within a range to be selected for erase. Sets the address of the last Erase Group within a continuous range to be selected for erase. Erases all previously selected groups ac R1 ERASE_GROUP_START CMD36 ac R1 ERASE_GROUP_END CMD38 ac R1b ERASE Table 25. Cmd index I/O mode commands (class 9) Type Argument [31:16] RCA [15:15] register write flag [14:8] register address [7:0] register data Response Abbreviation Command description Used to write and read 8 bit (register) data fields. The command addresses a device and a register and provides the data for writing if the write flag is set. This command accesses application dependent registers which are not defined in the MultiMediaCard standard. CMD39 ac R4 FAST_IO CMD40-41 Reserved Table 26. Cmd index Lock (class 7) Type Argument [31:0] stuff bits Response Abbreviation Command description Used to set/reset the password or lock/unlock the device. The size of the data block is set by the SET_BLOCK_LEN command. CMD42 adtc R1 LOCK_UNLOCK CMD43... CMD54 [31:16] RCA [15:0] stuff bits Reserved Indicates to the device that the next command is an application specific command rather than a standard command Used either to transfer a data block to the device or to get a data block from the device for general purpose / application specific commands. The size of the data block shall be set by issuing a SET_BLOCK_LEN command CMD55 ac R1 APP_CMD CMD56 adtc [31:1] stuff bits [0] RD/WR(1) R1 GEN_CMD 1. RD/WR is set to ‘1’ if the host receives a data block from the device, and to ‘0’ if the host sends a data block to the device. 49/116 Commands NAND08GAH0A, NAND16GAH0D 6.3 Device state transition Table 27: Device state transition gives the device state transitions according to the command received from the host. Table 27. Device state transition Current state Command idle ready ident stby tran data btst rcv prg dis ina irq changes to Class independent CRC error Command not supported class 0 CMD0 CMD1, VCC range compatible CMD1, device busy CMD1, VCC range not compatible CMD2, device wins bus CMD2, device loses bus CMD3 CMD4 CMD6 CMD7, device addressed CMD7, device not addressed CMD8 CMD9 CMD10 CMD12 CMD13 CMD14 CMD15 CMD19 idle ready idle ina – – – – – – – – – – – – – – – idle – – – ident ready – – – – – – – – – – – – – idle – – – – – stby – – – – – – – – – – – – idle – – – – – – stby – tran – – stby stby – stby – ina – idle – – – – – – – prg – stby data – – – tran – ina btst idle – – – – – – – – – stby – – – tran data – ina – idle – – – – – – – – – – – – – – btst tran ina – idle – – – – – – – – – – – – – prg rcv – ina – idle – – – – – – – – – dis – – – – prg – ina – idle – – – – – – – – prg – – – – – dis – ina – – – – – – – – – – – – – – – – – – – – stby stby stby stby stby stby stby stby stby stby stby stby stby stby stby stby stby stby stby – – – – – – – – – – – – – – – – – – – – – – stby stby 50/116 NAND08GAH0A, NAND16GAH0D Table 27. Device state transition (continued) Current state Command idle ready ident stby tran data btst rcv prg dis Commands ina irq changes to class 2 CMD16 CMD17 CMD18 CMD23 class 4 CMD16 CMD23 CMD24 CMD25 CMD26 CMD27 class 6 CMD28 CMD29 CMD30 class 5 CMD35 CMD36 CMD38 class 7 CMD16 CMD42 class 8 CMD55 CMD56, RD/WR = 0 CMD56, RD/WR = 1 class 9 CMD39 CMD60-CMD63 – – – stby – – – – – – stby – – – – – – – – – stby – – tran rcv data rcv – – btst – – rcv – – prg – – dis – – – – – irq stby stby – – – – rcv see class 2 – – – – – – stby – – – – – – – – – – – – tran tran prg – – – – – – – – – – – – – – – – – – stby stby stby – – – – – – – – – – – – prg prg data – – – – – – – – – – – – – – – – – – stby stby stby – – – – – – – – – – – – – – – – rcv rcv rcv rcv see class 2 see class 2 – – – – – – – – – – – – rcv rcv – – – – – – – – – – stby stby stby stby – – – – – – – – – – – – – – – – tran data data tran – – – – – – – – – – – – – – – – – – – – – – – – stby stby stby stby Reserved for manufacturer 51/116 Responses NAND08GAH0A, NAND16GAH0D 7 Responses All responses are sent via the CMD command line. The response transmission always starts with the left bit of the bit string corresponding to the response code word. The code length depends on the response type. A response always starts with a start bit (always ‘0’), followed by the bit indicating the direction of transmission (device = ‘0’). A value denoted by ‘x’ in the tables below indicates a variable entry. All responses except for the R3 type (see Section 7.4) are protected by a CRC. Every command code word is terminated by the end bit (always ‘1’). There are five response types: R1, R1b, R2, R3, R4. 7.1 R1 response (normal response command) R1 response code length is 48 bits. Bits 45 to 40 indicate the index of the command to be responded to, this value being interpreted as a binary coded number (between 0 and 63). The status of the device is coded in 32 bits. See Table 28 for a full description of R1 responses. Table 28. Bit position Width (bits) Value Description R1 response 47 1 ‘0’ Start bit 46 1 ‘0’ Transmission bit [45:40] 6 X Command index [39:8] 32 X Device status [7:1] 7 X CRC7 0 1 ‘1’ End bit 7.2 R1b response R1b response is identical to R1, except that it has an additional busy flag sent via the DAT line as defined in the MultiMediaCard specification. 7.3 R2 response (CID, CSD register) R2 response code length is 136 bits. The content of the CID register is sent as a response to CMD2, CMD9 and CMD10 commands. Only bits 127 to 1 of the CID and CSD registers are transferred. The reserved bit (bit 0) of these registers is replaced by the end bit of the response. See Table 29 for a full description of R2 responses. Table 29. R2 response 135 1 ‘0’ Start bit 134 1 ‘0’ Transmission bit [133:128] 6 ‘111111’ Reserved [127:1] 127 x CRC7 0 1 ‘1’ End bit Bit position Width (bits) Value Description 52/116 NAND08GAH0A, NAND16GAH0D Responses 7.4 R3 response (OCR register) R3 response code length is 48 bits. The contents of the OCR register is sent as a response to CMD1 commands. See Table 30 for a full description of R3 responses. Table 30. Bit position Width (bits) Value Description R3 response 47 1 ‘0’ Start bit 46 1 ‘0’ Transmission bit [45:40] 6 ‘111111’ Reserved [39:8] 32 x OCR register [7:1] 7 ‘1111111’ Reserved 0 1 ‘1’ End bit 7.5 R4 response (Fast I/O) R4 response code length is 48 bits. The argument field contains the RCA of the addressed device, the register address to be read out or written to, and its contents. See Table 31 for a full description of R4 responses. Table 31. Bit position Width (bits) Value R4 response 47 1 ‘0’ Start bit 46 1 ‘0’ Transmission bit [45:40] 6 ‘100111’ 16 x RCA [31:16] [39:8] Argument field 8 x Register addr. [15:8] 8 x Read register contents [7:1] 7 x 0 1 ‘1’ Description CMD39 CRC7 End bit 53/116 Device registers NAND08GAH0A, NAND16GAH0D 8 Device registers There are five 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. The device does not implement the DSR register. The MultiMediaCard has a status register to provide information about the device current state and completion codes for the last host command. 8.1 Operation conditions register (OCR) The 32-bit operation conditions register stores the VCCQ, the input/output voltage of the Flash memory component. The device is capable of communicating (identification procedure and data transfer) with any MultiMediaCard host using any operating voltage within 1.65 V and 1.95 V (low-voltage range) or 2.7 V and 3.6 V (high-voltage range) depending on the voltage range supported by the host. The 31 least significant bits are constant. Bit 32 is the busy flag as defined in the MultiMediaCard specification document. If the host tries to change the OCR values during an initialization procedure the changes in the OCR content will be ignored. The level coding of the OCR register is as follows: ● ● Restricted voltage windows = Low Device busy = Low OCR register definition OCR bit 6 to 0 7 14 to 8 23 to 15 30 to 24 31 Description Reserved Low VCCQ 2.0 - 2.6 2.7 - 3.6 (High VCCQ Reserved range)(1) MultiMediaCard 000 0000b 1b 000 0000b 1 1111 1111b 000 0000b Table 32. Power-up status bit (busy) (2) 1. The voltage for internal Flash memories (VCCi) should be in the 2.7 V to 3.6 V range. 2. This bit is set to Low if the device has not finished the power-up routine. 54/116 NAND08GAH0A, NAND16GAH0D Device registers 8.2 Card identification (CID) register The CID register is 16 bytes long and contains a unique card identification number used during the card identification procedure. It is a 128 bit wide register with the content as defined in Table 33. It is programmed during device manufacturing and can not be changed by MultiMediaCard hosts. Table 33. Card identification (CID) register Field MID OID PNM PRV PSN MDT CRC Width 8 16 48 8 32 8 7 1 CID - slice [127:120] [119:104] [103:56] [55:48] [47:16] [15:8] [7:1] [0:0] CID - value 0x33 0x5354 eMMC01 1.0 TBD Manufacturing date TBD - Name Manufacture ID OEM/application ID Product name Product revision Product serial number Manufacturing date CRC7 checksum Not used, always ‘1’ 8.3 Card specific data register (CSD) All the configuration information required to access the device data is stored in the CSD register. The MSB bytes of the register contain the manufacturer data and the two least significant bytes contains the host controlled data (the device Copy, Write Protection and the user ECC register). The host can read the CSD register and alter the host controlled data bytes using the SEND_CSD and PROGRAM_CSD commands. In Table 34, the cell type column defines the CSD field as Read only (R), One Time Programmable (R/W) or erasable (R/W/E). The programmable part of the register (entries marked by W or E) can be changed by command CMD27. The Copy bit in the CSD can be used to mark the device as an original or a copy. Once set it cannot be cleared. The device can be purchased with the copy bit set (copy) or cleared, indicating the device is a master. The One Time Programmable (OTP) characteristic of the Copy bit is implemented in the MultiMediaCard controller firmware and not with a physical OTP cell. Table 35 to Table 47 describe the CSD fields and the relevant data types. If not otherwise defined, all bit strings are interpreted as binary coded numbers starting with the left bit first. 55/116 Device registers Table 34. Card specific data register Name CSD structure MultiMediaCard protocol version Reserved Data Read Access-time-1 TAAC Field CSD_STRUCTURE SPEC_VERS Width [bits] 2 4 2 8 8 8 12 Cell type R R R R R R R NAND08GAH0A, NAND16GAH0D CSDslice [127:126] [125:122] [121:120] [119:112] [111:104] [103:96] [95:84] CSD-value 0x3 (see Table 49: Extended CSD) 0x4 (version 4.0, 4.1, 4.2) TBD(1) 0x5E (TAAC=5000 µs, NSAC=0 cycles) 0x2A (20 Mbit/s) 0x1F5 (classes 0, 2, 4, 5, 6, 7, 8) NAND08GAH0A 512 bytes Data Read Access-time-2 in NSAC CLK cycles (NSAC*100) Max. Data Transfer rate Command classes TRAN_SPEED CCC Max. Read Data Block Length Partial Blocks for Read allowed Write Block misalignment Read Block misalignment DSR implemented Reserved Device size Max. Read current at VCC(min) Max. Read current at VCC(max) Max. Write current at VCC(min) Max. Write current at VCC(max) Device size multiplier Erase group size Erase group size multiplier Write Protect group size READ_BL_LEN 4 R [83:80] NAND16GAH0D 1024 bytes READ_BL_PARTIAL WRITE_BLK_MISALIGN READ_BLK_MISALIGN DSR_IMP 1 1 1 1 2 R R R R R R R R R R R R R R R R R [79:79] [78:78] [77:77] [76:76] [75:74] [73:62] [61:59] [58:56] [55:53] [52:50] [49:47] [46:42] [41:37] 1 (Yes) 0 (No) 0 (No) 0 (No) 0 (No) According to device density 35 mA 45 mA 35 mA 45 mA According to device density 32 Erase groups NAND08GAH0A 4 8 C_SIZE VDD_R_CURR_MIN VDD_R_CURR_MAX VDD_W_CURR_MIN VDD_W_CURR_MAX C_SIZE_MULT ERASE_GRP_SIZE ERASE_GRP_MULT WP_GRP_SIZE 12 3 3 3 3 3 5 5 5 1 2 3 NAND16GAH0D [36:32] [31:31] [30:29] [28:26] 32 1 (Yes) 0 (None) 32 Write Protect Group Enable WP_GRP_ENABLE Manufacturer Default ECC Write speed factor DEFAULT_ECC R2W_FACTOR 56/116 NAND08GAH0A, NAND16GAH0D Table 34. Card specific data register (continued) Name Field Width [bits] Cell type CSDslice Device registers CSD-value NAND08GAH0A 512 bytes Max. Write Data Block Length Partial Blocks for Write Allowed Reserved Content protection application FileFormatGroup Copy Flag (OTP) WRITE_BL_LEN 4 R [25:22] NAND16GAH0D 1024 bytes 0 (No) WRITE_BL_PARTIAL 1 R [21:21] [20:20] CONTENT_PROT_APP FILE_FORMAT_GROUP COPY 1 1 1 1 1 R R/W R/W R/W R/W/ E [16:16] [15:15] [14:14] [13:13] [12:12] 0 (No) 0 (No) 0 (No) 0 (No) 0 (No) HD (Hard disk-like file system with partition table) 0 (None) 0x10 1 Permanent Write Protection PERM_WRITE_PROTECT Temporary Write Protection TMP_WRITE_PROTECT FileFormat FILE_FORMAT 2 R/W [11:10] ECC Code 2 R/W/E None 0 ECC CRC Not used, always ‘1’ 1. TBD stands for ‘to be defined’. 2 7 1 R/W/ E R/W/ E - [9:8] [7:1] [0:0] CRC 8.3.1 CSD_STRUCTURE This field describes the version of the CSD structure. Table 35. CSD register structure CSD structure version CSD version No. 1.0 CSD version No. 1.1 CSD version No. 1.2 Valid for system specification version Allocated by MMCA Allocated by MMCA version 4.1 - 4.2 CSD_STRUCTURE 0 1 2 3 Version is coded in the CSD_STRUCTURE byte in the EXT_CSD register 57/116 Device registers NAND08GAH0A, NAND16GAH0D 8.3.2 SPEC_VERS Defines the MultiMediaCard system specification version supported by the device. Table 36. System specification version System specification version number Allocated by MMCA Allocated by MMCA Allocated by MMCA Allocated by MMCA Version 4.1 - 4.2 Reserved SPEC_VERS 0 1 2 3 4 5 - 15 8.3.3 TAAC Defines the asynchronous part of the data access time. Table 37. TAAC access time definition Code Time unit 0=1 ns, 1=10 ns, 2=100 ns, 3=1 µs, 4=10 µs, 5=100 µs, 6=1 ms, 7=10 ms Multiplier factor 0=reserved, 1=1.0, 2=1.2, 3=1.3, 4=1.5, 5=2.0, 6=2.5, 7=3.0, 8=3.5, 9=4.0, A=4.5, B=5.0, C=5.5, D=6.0, E=7.0, F=8.0 Reserved TAAC bit position 2:0 6:3 7 8.3.4 NSAC Defines the typical case for the clock dependent factor of the data access time. The unit for NSAC is 100 clock cycles. Therefore, the maximal value for the clock dependent part of the data access time is 25.5k clock cycles. The total access time NAC as expressed in the Table 61: Timing values is calculated based on TAAC and NSAC. It has to be computed by the host for the actual clock rate. The read access time should be interpreted as a typical delay for the first data bit of a data block. 58/116 NAND08GAH0A, NAND16GAH0D Device registers 8.3.5 TRAN_SPEED Table 38 defines the clock frequency when not in high speed mode. For devices supporting version 4.0, and higher, of the specification, the value shall be 20 MHz (0x2A): Table 38. Maximum bus clock frequency definition Code Frequency unit 0=100 KHz, 1=1 MHz, 2=10 MHz, 3=100 MHz, 4...7=reserved Multiplier factor 0=reserved, 1=1.0, 2=1.2, 3=1.3, 4=1.5, 5=2.0, 6=2.6, 7=3.0, 8=3.5, 9=4.0, A=4.5, B=5.2, C=5.5, D=6.0, E=7.0, F=8.0 Reserved TRAN_SPEED bit 2:0 6:3 7 8.3.6 CCC The MultiMediaCard command set is divided into subsets (command classes). The card command class register CCC defines which command classes are supported by this device. A value of ‘1’ in a CCC bit means that the corresponding command class is supported. For command class definition refer to Table 18 and Table 19. Table 39. Supported card command classes CCC bit 0 class 0 ......... 11 class 11 Supported card command class 8.3.7 READ_BL_LEN The purpose of this field is to indicate the maximum data block length that is supported by the device when performing read operations. The data block length is computed as 2READ_BL_LEN. The block length can therefore range from one to 16 Kbytes. After power-up or software reset, the device defaults to operate in 512-byte block length. Table 40. Data block length Block length 20= 1 bytes 21= 2 bytes ... 210= 1024 bytes ‘00000’ ... Comment READ_BL_LEN 0 1 ... 10(1) 11- 15 1. This bit is only available for the NAND16GAH0D. It must be set to ‘0’ for the NAND08GAH0A. 59/116 Device registers NAND08GAH0A, NAND16GAH0D 8.3.8 READ_BL_PARTIAL Defines whether partial block sizes can be used in block read commands. ● NAND08GAH0A and NAND16GAH0D (densities ≤2 Gbytes, byte access mode): – – READ_BL_PARTIAL = ‘0’ means that only the 512-byte and the READ_BL_LEN size can be used for block oriented data transfers. READ_BL_PARTIAL = ‘1’ means that smaller blocks can be used as well. The minimum block size will be equal to minimum addressable unit (one byte). 8.3.9 WRITE_BLK_MISALIGN Defines if the data block to be written by one command can be spread over more than one physical block of the memory device. The size of the memory block is defined in WRITE_BL_LEN. WRITE_BLK_MISALIGN=0 signals that cross physical block boundaries are invalid. WRITE_BLK_MISALIGN=1 signals that cross physical block boundaries are allowed. 8.3.10 READ_BLK_MISALIGN Defines if the data block to be read by one command can be spread over more than one physical block of the memory device. The size of the memory block is defined in READ_BL_LEN. READ_BLK_MISALIGN=0 signals that cross physical block boundaries are invalid. READ_BLK_MISALIGN=1 signals that cross physical block boundaries are allowed. 8.3.11 DSR_IMP This parameter allows to select the configurable driver stage on the device. If set, a driver stage register (DSR) must be implemented also. Table 41. DSR implementation code DSR type DSR is not implemented DSR implemented DSR_IMP 0 1 8.3.12 C_SIZE This parameter is used to compute the NAND08GAH0A and NAND16GAH0D memory density. The memory capacity of the device is computed from the entries C_SIZE, C_SIZE_MULT and READ_BL_LEN as follows: Memory capacity = BLOCKNR * BLOCK_LEN, where: ● ● ● BLOCKNR = (C_SIZE+1) * MULT MULT = 2C_SIZE_MULT+2 (C_SIZE_MULT < 8) BLOCK_LEN = 2READ_BL_LEN, (READ_BL_LEN < 12) Therefore, the maximal capacity which can be coded is 4096*512*2048 = 4 Gbytes. 60/116 NAND08GAH0A, NAND16GAH0D Device registers Example: A 4 Mbyte device with BLOCK_LEN = 512 can be coded by C_SIZE_MULT = 0 and C_SIZE = 2047. 8.3.13 VDD_R_CURR_MIN, VDD_W_CURR_MIN The minimum values for read and write currents at the minimum VCC power supply (VCCmin) are coded as follows: Table 42. Current consumption at VCCmin VDD_R_CURR_MIN VDD_W_CURR_MIN 2:0 Code for current consumption at VCCmin 0 = 0.5 mA; 1 = 1 mA; 2 = 5 mA; 3 = 10 mA; 4 = 25 mA; 5 = 35 mA; 6 = 60 mA; 7 = 100 mA The values in these fields are valid when the device is not in high speed mode. When the device is in High Speed mode, the current consumption is chosen by the host, from the power classes defined in the PWR_ff_vvv registers, in the EXT_CSD register. 8.3.14 VDD_R_CURR_MAX, VDD_W_CURR_MAX The maximum values for read and write currents at the maximum VCC power supply (VCCmax) are coded as follows: Table 43. Current consumption at VCCmax VDD_R_CURR_MAX VDD_W_CURR_MAX 2:0 Code for current consumption at VCCmax 0 = 1 mA; 1 = 5 mA; 2 = 10 mA; 3 = 25 mA; 4 = 35 mA; 5 = 45 mA; 6 = 80 mA; 7 = 200 mA The values in these fields are valid when the device is not in High Speed mode. When the device is in high speed mode, the current consumption is chosen by the host, from the power classes defined in the PWR_ff_vvv registers, in the EXT_CSD register. 8.3.15 C_SIZE_MULT This parameter is used for coding a factor MULT for computing the total device size (see Section 8.3.12: C_SIZE). The factor MULT is defined as 2C_SIZE_MULT+2. Table 44. Multiply factor for the device size C_SIZE_MULT 0 1 2 3 4 5 6 7 22 = 4 23 = 8 24 = 16 25 = 32 26 = 64 27 = 128 28 = 256 29 = 512 MULT 61/116 Device registers NAND08GAH0A, NAND16GAH0D 8.3.16 ERASE_GRP_SIZE The contents of this register is a 5 bit binary coded value used to calculate the size of the erasable unit of the device. The size of the erase unit (also referred to as erase group) is determined by the ERASE_GRP_SIZE and the ERASE_GRP_MULT entries of the CSD, using the following equation: size of erasable unit = (ERASE_GRP_SIZE+1) * (ERASE_GRP_MULT +1) This size is given as the minimum number of write blocks that can be erased in a single erase command. 8.3.17 ERASE_GRP_MULT A 5 bit binary coded value used for calculating the size of the erasable unit of the device. See Section 8.3.16: ERASE_GRP_SIZE for detailed description. 8.3.18 WP_GRP_SIZE The size of a write protected group. The contents of this register is a 5 bit binary coded value, defining the number of erase groups that can be write protected. The actual size is computed by increasing this number by one. A value of zero means 1 erase group, 31 means 32 erase groups. 8.3.19 WP_GRP_ENABLE A value of ‘0’ means no group write protection possible. 8.3.20 DEFAULT_ECC Set by the device manufacturer. It defines the ECC code which is recommended for use. The field definition is the same as for the ECC field described later. 8.3.21 R2W_FACTOR Defines the typical block program time as a multiple of the read access time. The following table defines the field format. Table 45. R2W_FACTOR Multiples of read access time 1 2 (write half as fast as read) 4 8 16 32 64 128 R2W_FACTOR 0 1 2 3 4 5 6 7 62/116 NAND08GAH0A, NAND16GAH0D Device registers 8.3.22 WRITE_BL_LEN Block length for write operations. See READ_BL_LEN for field coding. 8.3.23 WRITE_BL_LEN Block length for write operations. See Section 8.3.7: READ_BL_LEN for field coding. Note that the support for 512 byte write access is mandatory for all cards. And that the cards has to be in 512 byte block length mode by default after power-up, or software reset. The purpose of this register is to indicate the maximum write data block length supported. Defines whether partial block sizes can be used in block write commands. ● NAND08GAH0A and NAND16GAH0D (densities ≤2 Gbytes, byte access mode): – – WRITE_BL_PARTIAL=’0’ means that only the 512 bytes and the WRITE_BL_LEN block size can be used for block oriented data write. WRITE_BL_PARTIAL=’1’ means that smaller blocks can be used as well. The minimum block size is one byte. 8.3.24 FILE_FORMAT_GRP Indicates the selected group of file formats. This field is read-only for ROM. The usage of this field is shown in Table 46: File formats. 8.3.25 COPY Defines if the contents is original (= ‘0’) or has been copied (=‘1’). The COPY bit for OTP and MTP devices, sold to end consumers, is set to ‘1’ which identifies the device contents as a copy. The COPY bit is a one-time-programmable bit. 8.3.26 PERM_WRITE_PROTECT Permanently protects the whole device content against overwriting or erasing (all write and erase commands for this device are permanently disabled). The default value is ‘0’, i.e. not permanently write protected. 8.3.27 TMP_WRITE_PROTECT Temporarily protects the whole device content from being overwritten or erased (all write and erase commands for this device are temporarily disabled). This bit can be set and reset. The default value is ‘0’, i.e. not write protected. 8.3.28 CONTENT_PROT_APP This field in the CSD indicates whether the content protection application is supported. MultiMediaCards which implement the content protection application will have this bit set to ‘1’. 63/116 Device registers NAND08GAH0A, NAND16GAH0D 8.3.29 FILE_FORMAT Indicates the file format on the device. This field is read-only for ROM. The following formats are defined: Table 46. File formats FILE_FORMAT 0 1 2 3 0,1,2,3 Type Hard disk-like file system with partition table. DOS FAT (floppy-like) with boot block only (no partition table). Universal file format Others/unknown Reserved FILE_FORMAT_GRP 0 0 0 0 1 8.3.30 ECC Defines the ECC code that was used for storing data on the device. This field is used by the host (or application) to decode the user data. The following table defines the field format: Table 47. ECC type ECC type None (default) BCH (542,512) Reserved Maximum number of correctable bits per block none 3 - ECC 0 1 2-3 8.3.31 CRC The CRC field carries the check sum for the CSD contents. It is computed according to Section 11: Error protection. The checksum has to be recalculated by the host for any CSD modification. The default corresponds to the initial CSD contents. The following table lists the correspondence between the CSD entries and the command classes. A ‘+’ entry indicates that the CSD field affects the commands of the related command class. 64/116 NAND08GAH0A, NAND16GAH0D Table 48. CSD field command classes Command classes CSD field 0 CSD_STRUCTURE SPEC_VERS TAAC NSAC TRAN_SPEED CCC READ_BL_LEN READ_BL_PARTIAL WRITE_BLK_MISALIGN READ_BLK_MISALIGN DSR_IMP C_SIZE_MANT C_SIZE_EXP VDD_R_CURR_MIN VDD_R_CURR_MAX VDD_W_CURR_MIN VDD_W_CURR_MAX ERASE_GRP_SIZE WP_GRP_SIZE WP_GRP_ENABLE DEFAULT_ECC R2W_FACTOR WRITE_BL_LEN WRITE_BL_PARTIAL FILE_FORMAT_GRP COPY PERM_WRITE_PROTECT TMP_WRITE_PROTECT FILE_FORMAT ECC CRC + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1 + + + + + + 2 + + + + + + + + + 3 + + + + + + 4 + + + + + + + + 5 + + + + 6 + + + + Device registers 7 + + + + 8 + + + + 9 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 65/116 Device registers NAND08GAH0A, NAND16GAH0D 8.4 Extended CSD register The Extended CSD Register defines the device properties and selected modes. It is 512 bytes long. The 320 most significant bytes are the properties segment that defines the device capabilities and cannot be modified by the host. The 192 lower bytes are the modes segment that defines the configuration the device is working in. These modes can be changed by the host by means of the SWITCH command. Table 49. Extended CSD(1) Field Size (bytes) Cell type CSD-slice CSDslice value Name Properties segment Reserved(2) Supported command sets Reserved(2) Reserved (2) 7 S_CMD_SET 1 288 1 1 R R [511:505] [504] [503:216] [211] [210] TBD 00 TBD TBD 0x08 Minimum Write performance for 8 bit at MIN_PERF_W_8_52 52 MHz Minimum Read performance for 8 bit at MIN_PERF_R_8_52 52 MHz 1 R [209] 0x08 Minimum Write performance for 8 bit at MIN_PERF_W_8_26_ 1 26 MHz / 4 bit at 4_52 52 MHz Minimum Read performance for 8 bit at MIN_PERF_R_8_26_ 1 26 MHz / 4 bit at 4_52 52 MHz Minimum Write performance for 4 bit at MIN_PERF_W_4_26 26 MHz Minimum Read performance for 4 bit at MIN_PERF_R_4_26 26 MHz Reserved(2) Power class for 26 MHz at 3.6 V Power class for 52 MHz at 3.6 V Power class for 26 MHz at 1.95 V PWR_CL_26_360 PWR_CL_52_360 PWR_CL_26_195 1 R [208] 0x08 R [207] 0x08 R [206] 0x08 1 1 1 1 1 R [205] [204] 0x08 TBD 00 00 00 R R R [203] [202] [201] 66/116 NAND08GAH0A, NAND16GAH0D Table 49. Extended CSD(1) (continued) Field Size (bytes) Cell type Device registers Name Power class for 52 MHz at 1.95 V Reserved(2) Card type Reserved (2) CSD-slice CSDslice value 00 TBD 01 TBD 02 TBD 01 PWR_CL_52_195 1 3 R [200] [199:197] CARD_TYPE 1 1 R [196] [195] CSD structure version Reserved(2) CSD_STRUCTURE 1 1 1 R [194] [193] Extended CSD revision EXT_CSD_REV Modes segment Command Set Reserved(2) Command set revision Reserved (2) R [192] CMD_SET 1 1 R/W [191] [190] 00 TBD 00 TBD 00 TBD 00 TBD 00 TBD TBD CMD_SET_REV 1 1 RO [189] [188] Power class Reserved(2) High speed interface timing Reserved(2) Bus Width mode Reserved(2) Reserved (2) POWER_CLASS 1 1 R/W [187] [186] HS_TIMING 1 1 R/W [185] [184] BUS_WIDTH 1 1 181 WO [183] [182] [180:0] 1. TBD stands for ‘to be defined’. 2. Reserved bits should read as ‘0’. 8.4.1 S_CMD_SET This field defines which command sets are supported by the device. Table 50. Supported command sets Bit 7-5 4 3 2 1 0 Reserved Allocated by MMCA Allocated by MMCA Allocated by MMCA Allocated by MMCA Standard MMC Command set 67/116 Device registers NAND08GAH0A, NAND16GAH0D 8.4.2 MIN_PERF_a_b_ff These fields defines the overall minimum performance value for the read and write access with different bus width and maximum clock frequency modes. The value in the register is coded as follows. Other than defined values are illegal. Table 51. Value 0x00 0x08 0x0A 0x0F 0x14 R/W access performance values Performance For devices not reaching the 2.4 Mbyte/s minimum value Class A: 2.4 Mbyte/s and is the lowest allowed value for MMCplus and MMCmobile(16 x 150 Kbyte/s) Class B: 3.0 Mbyte/s and is the next allowed value (20 x 150 Kbyte/s) Class C: 4.5 Mbyte/s and is the next allowed value (30 x 150 Kbyte/s) Class D: 6.0 Mbyte/s and is the next allowed value (40 x 150 Kbyte/s) Class E: 9.0 Mbyte/s and is the next allowed value (60 x 150 Kbyte/s) This is also the highest class which any MMCplus or MMC mobile card is needed to support in low bus category operation mode (26 MHz with 4 bit data bus). An MMCplus or MMCmobile card supporting any higher class than this has to support this class also (in low category bus operation mode). Class F: Equals 12.0 Mbyte/s and is the next allowed value (80 x 150 Kbyte/s) Class G: Equals 15.0 Mbyte/s and is the next allowed value (100 x 150 Kbyte/s) Class H: Equals 18.0 Mbyte/s and is the next allowed value (120 x 150 Kbyte/s) Class J: Equals 21.0 Mbyte/s and is the next allowed value (140 x 150 Kbyte/s) This is also the highest class which any MMCplus or MMCmobile card is needed to support in mid bus category operation mode (26 MHz with 8 bit data bus or 52 MHz with 4 bit data bus). An MMCplus or MMCmobile card supporting any higher class than this has to support this class (in mid category bus operation mode) and class E also (in low category bus operation mode) Class K: Equals 24.0 Mbyte/s and is the next allowed value (160 x 150 Kbyte/s) Class M: Equals 30.0 Mbyte/s and is the next allowed value (200 x 150 Kbyte/s) Class O: Equals 36.0 Mbyte/s and is the next allowed value (240 x 150 Kbyte/s) Class R: Equals 42.0 Mbyte/s and is the next allowed value (280 x 150 Kbyte/s) Class T: Equals 48.0 MByte/s and is the last defined value (320 x 150 Kbyte/s) 0x1E 0x28 0x32 0x3C 0x46 0x50 0x64 0x78 0x8C 0xA0 68/116 NAND08GAH0A, NAND16GAH0D Device registers 8.4.3 PWR_CL_ff_vvv These fields define the supported power classes by the device. By default, the device has to operate at maximum frequency using 1 bit bus configuration, within the default maximum current consumption, as stated in the table below. If 4 bit/8 bit bus configurations, require increased current consumption, it has to be stated in these registers. By reading these registers the host can determine the power consumption of the device in different bus modes. Bits [7:4] code the current consumption for the 8 bit bus configuration. Bits [3:0] code the current consumption for the 4 bit bus configuration The PWR_52_vvv registers are not defined for 26 MHz MultiMediaCards. Table 52. Voltage Power classes Value 0 1 2 3 4 Max rms current 100 mA 120 mA 150 mA 180 mA 200 mA 220 mA 250 mA 300 mA 350 mA 400 mA 450 mA Max peak current 200 mA 220 mA 250 mA 280 mA 300 mA 320 mA 350 mA 400 mA 450 mA 500 mA 550 mA Reserved for future use 65 mA 70 mA 80 mA 90 mA 100 mA 120 mA 140 mA 160 mA 180 mA 200 mA 250 mA 130 mA 140 mA 160 mA 180 mA 200 mA 220 mA 240 mA 260 mA 280 mA 300 mA 350 mA Reserved for future use Default current consumption for dual voltage devices Comments Default current consumption for high voltage devices 3.6 V 5 6 7 8 9 10 11-15 0 1 2 3 4 1.95 V 5 6 7 8 9 10 11-15 69/116 Device registers NAND08GAH0A, NAND16GAH0D The measurement for maximum rms current is the average of rms current consumption over a period of 100 ms. The maximum peak current is defined as the absolute maximum value not to be exceeded. The conditions under which the power classes are defined are: ● ● ● ● Maximum bus frequency Maximum operating voltage Worst case functional operation Worst case environmental parameters (temperature,...) These registers define the maximum power consumption for any protocol operation in data transfer mode, Ready state and Identification state. 8.4.4 CARD_TYPE This field defines the type of the device. The only currently valid values for this field are 0x01 and 0x03. Table 53. Card type Bit 7:2 1 0 Reserved High speed MultiMediaCard at 52 MHz High speed MultiMediaCard at 26 MHz Card type 8.4.5 CSD_STRUCTURE This field is a continuation of the CSD_STRUCTURE field in the CSD Register. Table 54. CSD Register structure CSD structure version CSD version No. 1.0 CSD version No. 1.1 CSD version No. 1.2 Reserved for future use Valid for system specification version Allocated by MMCA Allocated by MMCA Version 4.1 - 4.2 CSD_STRUCTURE 0 1 2 3-255 8.4.6 EXT_CSD_REV Defines the fixed parameters. related to the EXT_CSD, according to its revision. Table 55. Extended CSD revision EXT_CSD_REV 255-3 2 1 0 Reserved Revision 1.2 Revision 1.1 Revision 1.0 Extended CSD revision 70/116 NAND08GAH0A, NAND16GAH0D Device registers 8.4.7 CMD_SET Contains the binary code of the command set that is currently active in the device. It is set to ‘0’ (Standard MMC) after power up and can be changed by a SWITCH command. Note that while changing the command set with the switch command, values according to the S_CMD_SET Register should be used, for example, bit0 set=0x01 for standard MMC. 8.4.8 CMD_SET_REV Contains a binary number reflecting the revision of the currently active command set. For standard MMC the command set it is: Table 56. Standard MMC command set revisions Code 255-1 0 Reserved v4.0 MMC revision This field, though in the modes segment of the EXT_CSD, is read only. 8.4.9 POWER_CLASS This field contains the 4-bit value of the selected power class for the device. The power classes are defined in Table 57. The host should be responsible of properly writing this field with the maximum power class it allows the device to use. The device uses this information to, internally, manage the power budget and deliver an optimized performance. This field is 0 after power-up or software reset. Table 57. Power class code Bits [7:4] [3:0] Reserved Device power class code (See Table 47) Description 8.4.10 HS_TIMING This field is 0 after power-up, or software reset, thus selecting the backwards compatibility interface timing for the device. If the host writes 1 to this field, the device changes its timing to high speed interface timing (see Table 9). 8.4.11 BUS_WIDTH It is set to ‘0’ (1 bit data bus) after power-up and can be changed by a SWITCH command. Table 58. Bus mode values Value 255-3 2 1 0 Reserved 8 bit data bus 4 bit data bus 1 bit data bus Bus mode 71/116 Device registers NAND08GAH0A, NAND16GAH0D 8.5 RCA (relative card address) register The writable 16-bit relative card address (RCA) register carries the device address assigned by the host during the device identification. This address is used for the addressed host-card communication after the device identification procedure. The default value of the RCA register is 0x0001. The value 0x0000 is reserved to set all cards into the Standby state with CMD7. 8.6 DSR (driver stage register) register The 16-bit driver stage register (DSR) 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 on the bus). The CSD register contains the information concerning the DSR register usage. The default value of the DSR register is ‘0x404’. 8.7 Status register The Status register provides information about the device current state and completion codes for the last host command. The device status can be explicitly read (polled) with the SEND_STATUS command. The MultiMediaCard Status register structure is defined in Section 8.7: Status register. Each of the Status register bit has three attributes: ● Type There are two types of Status register bits: – – Error bit (E): it signals an error condition detected by the device. Error bits are cleared as soon as the response reporting the error is sent back. Status bit (S): it provides information on the device status and do not alter the execution of the command being responded to. Status bits are non-volatile. They are set and cleared according to the device status. ● Detection mode Exceptions can be detected by the device either during the command interpretation and validation phase (Response mode) or during command execution phase (Execution mode). – Response mode (R) exceptions are reported in the response to the command that raised the exception. The command is not executed and the associated state transition does not take place. Execution mode (X) exceptions are reported in the response to a STOP_TRANSMISSION command used to terminate the operation or in the response to a GET_STATUS command issued while the operation is being carried out or after the operation is completed. When an error is detected in X mode, the error will be reported in the response to the next command. Note that ADDRESS_OUT_OF_RANGE and ADDRESS_MISALIGN exceptions may be detected both in Response and Execution modes. The conditions for each one of the modes are explicitly defined in Table 59. – 72/116 NAND08GAH0A, NAND16GAH0D ● Device registers Clear condition Status Register bits clear condition can be of three types: – – – The bit is cleared according to the device current state (A). The bit value is always related to the previous command (B). The bit is cleared at reception of a valid command (with a delay of one command). The bit is cleared by read operation (C). Table 59. Bits Status register Identifier Type Detection mode R Value Description Command argument not allowed ‘0’= no error ‘1’= error Single/multiple block operation attempting to read or write beyond the device address space Command using misaligned address, not matching the block length. Multiple block read/write operation attempting to read or write data block which does not align with the device memory blocks. Transferred block length not allowed, or number of bytes transferred not matching the block length. An error occurred in the erase command sequence. Invalid selection of erase groups during erase operation B Clear condition B B 31 ADDRESS_OUT_OF_ RANGE E X R 30 ADDRESS_MISALIGN E X ‘0’= no error ‘1’= error 29 BLOCK_LEN_ERROR E R ‘0’= no error ‘1’= error ‘0’= no error ‘1’= error ‘0’= no error ‘1’= error B 28 27 ERASE_SEQ_ERROR ERASE_PARAM E E R X B B 26 WP_VIOLATION E X ‘0’= not Attempt to write to a write protected protected block. ‘1’= protected ‘0’ = unlocked This bit is set when the device is ‘1’ = locked locked by the host This bit is set when a sequence or password error has been detected during a Lock/Unlock command or if there was an attempt to access a locked device CRC check of the previous command failed. Illegal command not legal for the current state B 25 CARD_IS_LOCKED S R A 24 LOCK_UNLOCK_ FAILED E X ‘0’= no error ‘1’= error B 23 22 21 20 COM_CRC_ERROR ILLEGAL_COMMAND CARD_ECC_FAILED CC_ERROR E E E E R R X R ‘0’= no error ‘1’= error ‘0’= no error ‘1’= error B B B B ‘0’= success Card internal ECC performed but ‘1’= failure failed to correct the data ‘0’= no error ‘1’= error Internal device controller error 73/116 Device registers Table 59. Bits NAND08GAH0A, NAND16GAH0D Status register (continued) Identifier Type Detection mode X X X Value ‘0’= no error ‘1’= error ‘0’ ‘0’ Can be one of the following errors: - The CID register has been already written and cannot be overwritten - The read only section of the CSD does not match the device content. - An attempt to reverse the copy (set as original) or permanent WP (unprotected) bits was made. Description General or unknown error occurred during operation Clear condition B B B 19 18 17 ERROR UNDERRUN OVERRUN E E E 16 CID/ CSD_OVERWRITE E X ‘0’= no error ‘1’= error B 15 14 13 WP_ERASE_SKIP E X ‘0’=not Partial address space erased due to protected existing write protected blocks ‘1’= protected B Reserved (must be set to 0) ERASE_RESET E R ‘0’= cleared ‘1’= set 0 = idle 1 = ready 2 = ident 3 = stby 4 = tran 5 = data 6 = rcv 7 = prg 8 = dis 9 = btst 10-15 = reserved Erase sequence cleared before executing because an out of erase sequence command was received B 12-9 CURRENT_STATE S R The state of the device when receiving the command. If the command execution causes a state change, it will be visible to the host in the response to the next command. The four bits are interpreted as a binary coded number between 0 and 15. A 8 READY_FOR_DATA S R ‘0’= not ready Corresponds to buffer empty signaling on the bus ‘1’= read ‘0’= not error If set, the device did not switch to the expected mode as requested by ‘1’= error the SWITCH command A 7 6-4 5 SWITCH_ERROR Reserved E X B ‘1’ 3, 2 Reserved for application specific commands 1, 0 Reserved for manufacturer test mode 74/116 NAND08GAH0A, NAND16GAH0D Timings 9 Timings All timing diagrams use the abbreviations shown in Table 60. Bit P is actively driven High by the device respective to the host output driver, while bit Z is driven High by the pull-up resistors RCMD and RDAT. Actively driven P bits are less sensitive to noise superposition. All timing values are shown in Table 61. Table 60. S T P E Z D * CRC Timing symbols Start bit (= 0) Transmitter bit (Host = 1, Device = 0) One-cycle Pull-up (= 1) End bit (=1) High Impedance state Data bits Repeater Cyclic Redundancy Check bits (7 bits) Table 61. Timing NCR NID NAC NRC NCC NWR NST Timing values Min 2 5 2 8 8 2 2 Max 64 5 10(TAAC fOP + 100NSAC) 2 Unit Clock cycles Clock cycles Clock cycles Clock cycles Clock cycles Clock cycles Clock cycles 75/116 Timings NAND08GAH0A, NAND16GAH0D 9.1 Command and response timings Both host command and device response are clocked out with the rising edge of the host clock. 9.1.1 Card identification and card operation conditions The Card Identification (CMD2) and Card Operation Conditions (CMD1) commands are processed in the open-drain mode. The minimum delay between the host command and device response is NID clock cycles. Figure 13 shows the identification timing diagram. Figure 13. Identification timing diagram (Card Identification mode) Host Command CMD ST Content NID Cycles CID or OCR Content CRC E Z * * * * * * Z S T ZZ Z AI13196 9.1.2 Assignment of relative card address The SET_RCA command (CMD 3) is also processed in open-drain mode. The minimum delay between the host command and device response is NCR clock cycles. Figure 14 shows the SET_RCA timing diagram. Figure 14. SET_RCA timing diagram (Card Identification mode) Host Command CMD ST Content NID Cycles Response Content CRC E Z * * * * * * Z S T CRC E Z Z Z AI04333 9.1.3 Data Transfer mode After an RCA has been assigned to the device, it switches to Data Transfer mode. In this mode the CMD line is driven with push-pull drivers. The command is followed by a two Z-bit period to allow direction switching on the bus, and by P bits pushed up by the responding device. This timing diagram shown on Figure 15 applies to all host command responses except for CMD1, CMD2, and CMD3. Figure 15. Command response timing diagram (Data Transfer mode) Host Command CMD ST Content NCRCycles Response Content CRC E Z Z P * * * * * P S T CRC E Z Z Z AI04334 76/116 NAND08GAH0A, NAND16GAH0D Timings 9.1.4 R1b responses Some commands, like CMD6, may assert the busy flag and send back a R1 response. If the busy flag is asserted, this is done two clock cycles after the end bit of the command. The DAT0 line is driven Low, DAT1-DAT7 lines are driven by the device though their values are not relevant. Figure 16. R1b response timing diagram Host Command CMD ST Content CRC E Z Z Z Z Z NST ***************** Card busy ***************** ***************** ZZZZZZ DAT0 Z Z Z Z Z Z Z Z Z Z Z ZSL DAT1-7 Z Z Z Z Z Z Z Z Z Z Z Z X EZZZ XZZZ AI13197 9.1.5 Last device response to Next Host command After receiving the last device response, the host can start the next command transmission after a minimum delay of is NCR clock cycles. The timing diagram shown on Figure 17 applies to all host commands. Figure 17. Last device response to Next Host command timing diagram Response CMD ST Content NRCCycles Host Command Content CRC E Z * * * * * * * * Z S T CRC E Z Z AI13198 9.1.6 Last Host command to Next Host command After the last command has been sent, the host can continue issuing the next command. A minimum delay of NCC clock periods must be respected between the two commands. If the device has not responded to the ALL_SEND_CID command after NID+1 clock periods, the host can conclude that no devices are present on the bus. See Figure 18 for a description of the timing diagram. Figure 18. Command n end to CMD n+1 start timing diagram (all modes) Host Command CMD ST Content NCCCycles Host Command Content CRC E Z * * * * * * * * Z S T CRC E Z Z AI13199 77/116 Timings NAND08GAH0A, NAND16GAH0D 9.2 9.2.1 Data Read timings Single Block Read The host selects one device for data read operation by issuing a CMD7 command. It then sends a CMD16 command to set the valid block length for block oriented data transfer. Figure 19 shows the timing diagram for a Single Block Read operation. The sequence starts with a single block read command (CMD17) which specifies the start address in the argument field. The response is sent on the CMD line as usual. Data transmission starts NAC clock cycles after the end bit of the host command. After the last data bit, the CRC check bits are suffixed to allow the host to check for transmission errors. Figure 19. Single Block Read command timing diagram NCR Cycles Host Command CMD S T Content Card Response Content CRC E Z Z P * * * P S T NAC Cycles CRC E Read Data DAT Z ZZ **** Z Z Z Z Z Z P ********* P S DD D*** AI04330 9.2.2 Multiple Block Read In Multiple Block Read mode, the device sends a continuous flow of data blocks following the initial host read command. The data flow is terminated by a STOP_TRANSMISSION command (CMD12). Figure 20 describes the timing of the data blocks and Figure 21 the response to a STOP_TRANSMISSION command. The data transmission stops two clock cycles after the end bit of the STOP_TRANSMISSION command. Figure 20. Multiple Block Read command timing diagram NCR Cycles Host Command CMD S T Content Card Response Content CRC E Z Z P * P S T NAC Cycles CRC E Z Z P P P P P P P P P P P P P Read Data NAC Cycles Read Data DAT Z ZZ **** Z Z Z Z Z Z P ******** P S DD D *** * D E P ****** P S D DD D D AI04331 78/116 NAND08GAH0A, NAND16GAH0D Timings Figure 21. STOP_TRANSMISSION command timing diagram (CMD12, Data Transfer mode) NCR Cycles Host Command CMD S T Content Card Response Content CRC E Z Z P * * * P S T CRC E DAT D DD ******** D D D E Z Z ******************* AI04329 9.3 9.3.1 Data Write timings Single Block Write Before performing a data write operation, the host must select the device by issuing a CMD7 command, and set the valid block length for block oriented data transfer by issuing a CMD16 command. The timing diagram for Single Block Write operation is given on Figure 22. The sequence starts with a single block write command (CMD24) which determines the start address. The data transfer from the host starts NWR clock cycles after the device response was received. The data is suffixed with CRC check bits to allow the device to check it for transmission errors. The device sends back the CRC check result as a CRC status token on the data line. In the case of transmission error the device sends a negative CRC status (‘101’). In the case of non erroneous transmission the device sends a positive CRC status (‘010’) and starts the data programming procedure. During the write operation, the device notifies the host that it is busy by holding DAT0 Low. The data line goes High as soon as at least one receive buffer becomes free. Figure 22. Single Block Write command timing diagram NCR Cycles Host Cmd CMD Card Response DAT0 E Z Z P * P S T Content CRC E Z Z P * * * * * * * * * * * * * * * * * P P P P P P P P CRC Write Data Busy NWR Status Z Z ****** Z Z Z * * * Z Z P*P S Content CRC E Z Z S Status E S L*L E Z *** Z Z P*P S Content CRC E Z Z X *** XZ AI13600 DAT1-7 Z Z * * * * * * Z Z Z 79/116 Timings NAND08GAH0A, NAND16GAH0D 9.3.2 Multiple Block Write In Multiple Block Write mode, the device is sent a continuous flow of data blocks following the initial host write command. The data flow is terminated by a STOP_TRANSMISSION command (CMD12). See Figure 23 for a description of Multiple Block Write timing diagrams with and without device busy flag. The STOP_TRANSMISSION command works in the same way as for Read operations. The device considers a data block as successfully received and ready for programming only if the CRC data of the block was validated and the CRC status token sent back to the host. Figure 25 is an example of an interrupted attempt to transmit the CRC status block. The end bit of the host command is followed, on the data line, with one more data bit, an end bit and two Z clock for switching the bus direction. In this case the received data block is considered incomplete and will not be programmed. In an open-ended Multiple Block Write case the busy flag between the data blocks should be considered as buffer busy flag. As long as there is no free data buffer available the device should indicate this by pulling down the Dat0 line. The device stops pulling down DAT0 as soon as at least one receive buffer for the defined data transfer block length becomes free. After the device receives the stop command (CMD12), the following busy indication should be considered as programming busy and being directly related to the Programming state. As soon as the device completes the programming, it stops pulling down the Dat0 line. In pre-defined Multiple Block Write case the busy flag between the data blocks should be considered as buffer busy flag similar to the open-ended multiple block case. After the device receives the last data block the following busy indication should be considered as programming busy and being directly related to the Programming state. The meaning of busy flag (from buffer busy to programming busy) changes at the same time with the state change (from rcv to prg). The busy flag remains “low” all the time during the process and is not released by the device between the state change from rcv to prg. As soon as the device completes the programming, it stops pulling down the Dat0 line. See Figure 24 and Figure 25 show examples of timing diagrams corresponding to host stopping the data transmission during an active data transfer, while Figure 26 and Figure 27 describe scenarios of STOP_TRANSMISSION command received between data blocks transmission. In Figure 26 the device is busy programming the last block while in Figure 27 the device is idle. Unprogrammed data blocks remain in the input buffers and will be programmed as soon as the STOP_TRANSMISSION command is received and the device activates the busy flag. Figure 23. Multiple Block Write command timing diagram Card Rsp. E Z Z P ***************** P P P P P ***************** P P PP P P P P P CRC CRC NWR Busy NWR NWR Write Data Write Data Status Status DAT0 Z Z P*P S Data+CRC E Z Z S Status E Z P*P S Data+CRC E Z Z S Status E S L*L E Z P*P DAT1-7 Z Z P*P S Data+CRC E Z Z X * * * * * X Z P*P S Data+CRC E Z Z X * * * * * * * * X Z P*P AI13601 CMD 80/116 NAND08GAH0A, NAND16GAH0D Figure 24. STOP_TRANSMISSION during data transfer from the host timing diagram Timings Host Command CMD NCRCycles Card response Content Host Cmd S T Content CRC E Z Z P P * * * * * *P S T NST CRC E Z Z P P S T Content Card is programming DAT0 D DD DD DD DD DE Z ZS L ********************* E Z Z Z Z Z Z Z Z DAT1-7 D D D D D D D D D D E Z Z S L * * * * * * * * * * * * * * * * * * * * * X Z Z Z Z Z Z Z Z AI13602 Figure 25. STOP_TRANSMISSION during CRC status transfer from the device timing diagram Host Command CMD NCRCycles Card response Host Cmd S T Content CRC E Z Z P P * * * * * *P S T Content CRC E Z Z P P S T Content CRC Card is programming Data Block Status(1) DAT0 Data+CRC E Z Z S CRC E Z Z S L * * * * * * * * * * * * * * * * * * * * * E Z Z Z Z Z Z Z Z DAT1-7 Data+CRC E Z Z X ***** X Z Z X * * * * * * * * * * * * * * * * * * * * * X Z Z Z Z Z Z Z Z AI13603 1. The device CRC status response is interrupted by the host. Figure 26. STOP_TRANSMISSION received after last data block (device busy) Host Command CMD NCRCycles Card response Content Host Cmd S T Content CRC E Z Z P * * * P S T CRC E Z Z P P P P S T Content Card is programming DAT0 DAT1-7 LL **************************************** X X **************************************** LE ZZZ Z ZZZZ XX ZZ Z Z ZZ Z Z AI13604 Figure 27. STOP_TRANSMISSION received after last data block (device becomes busy) Host Command CMD NCRCycles Card response Content Host Cmd S T Content CRC E Z Z P * * * P S T CRC E Z Z P P P P S T Content Card is programming DAT0 ZZZZZZZZZZZSL ********************* ********************* DAT1-7 Z Z Z Z Z Z Z Z Z Z Z X X LE ZZZ Z ZZZZ XE ZZ Z Z ZZ Z Z AI13605 81/116 Timings NAND08GAH0A, NAND16GAH0D 9.3.3 Erase, Set and Clear Write Protect The host must first select the groups to be erased using the ERASE_GROUP_START and ERASE_GROUP_END commands (CMD35, CMD36). Once the ERASE command (CMD38) is issued, all the selected erase groups are erased. Similarly, SET_WRITE_PROT and CLR_WRITE_PROT commands start a write operation as well. The device signals that it is busy by pulling the DAT0 line low for the duration of the erase or program operation. The timing diagrams are identical to the STOP_TRANSMISSION diagrams described in Figure 27. 9.3.4 Reselecting a busy device When a busy device which is currently in the disable state is reselected, it reinstate its busy signalling on the data line DAT0. The timing diagram for the command/response/busy transaction is given in Figure 27. 9.4 Bus test procedure timing When in transfer state, the host can initiate a bus test procedure. This is done by issuing CMD19 command to the device. If there is no response to the CMD19, the host may assume that this function is not supported by the device and should read the status from the device by sending a CMD13 command. Figure 28. 4-bit system bus test procedure CMD CMD19 RSP19 NWR NRC EZ Z EZ Z EZ Z EZ Z CMD14 RSP14 NAC ****** ****** ****** ****** ****** NAC CMD6 RSP6 DAT0 DAT1 DAT2 DAT3 ZZ ZZ ZZ ZZ * * * * * * Z Z Z S 10 XXX * * * * * * Z Z Z S 01 XXX * * * * * * Z Z Z S 10 XXX * * * * * * Z Z Z S 01 XXX Z Z Z S 01 000000 CRC16 E Z Z * * * * * * Z Z Z Z Z Z S 10 000000 CRC16 E Z Z * * * * * * Z Z Z Z Z Z S 01 000000 CRC16 E Z Z * * * * * * Z Z Z Z Z Z S 10 000000 CRC16 E Z Z * * * * * * Z Z Z Z Z Z S 01 000000 CRC16 E Z Z * * * * * * Z Z Z AI13606 DAT4-7 Z Z * * * * * * Z Z Z Z Z *** Z Z Z Z Z 82/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10 Serial peripheral interface (SPI) mode The SPI mode is an optional communications protocol in Flash based MultiMediaCards. It is used to communicate with a microcontroller (host) through an SPI channel. On power-up the MultiMediaCard defaults to the MultiMediaCard mode. The SPI mode is selected by asserting the CS signal during a reset command (CMD0). This may be after power-up but also anytime a reset command is issued. On entering the SPI mode, the device returns the SPI mode R1 response. Once the MultiMediaCard enters SPI mode it remains in this mode until the next power-up. To run, the SPI mode implements a subset of the MultiMediaCard protocol and commands. This mode is intended for systems which require multiple devices, generally one, to operate, and have lower data transfer rates compared to MultiMediaCard protocol based systems. The serial peripheral interface is a general purpose, synchronous interface designed to communicate with SPI hosts through four lines: ● ● ● ● CS: host to device Chip Select line CLK: host to device clock line DataIn, DI: unidirectional host to device data line DataOut, DO: unidirectional device to host data line. 10.1 SPI bus topology The host (master) selects a device (slave) by driving its CS pin Low. The CS pin must then be kept Low during the entire SPI communication process (command, response and data). During device programming, however, the host can de-assert the CS signal without affecting the programming operation. Single block and multiple read and write operations are supported by the SPI channel as DataIn and DataOut are unidirectional. Table 62 shows the MultiMediaCard pin assignment in SPI mode. In SPI mode only the OCR, CSD and CID registers are accessible (see Table 63). 10.2 SPI electrical interface The electrical interface in SPI mode is the same as the MultiMediaCard mode, except for the programmable device output drivers option which is not available in SPI mode. 83/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.3 SPI bus operating conditions The SPI bus operating conditions are the same as for the MultiMediaCard mode. Table 62. SPI interface pin configuration MultiMediaCard mode Name DAT3 CMD VSS1 VCC, VCCQ CLK VSS2 DAT0 DAT1 DAT2 DAT4 DAT5 DAT6 DAT7 Type(1) I/O/PP I/O/PP/ OD S S I S I/O/PP I/O/PP I/O/PP I/O/PP I/O/PP I/O/PP I/O/PP Description Data Command/response Supply voltage ground Supply voltage Clock Supply voltage ground Data Data Data Data Data Data Data CS DI VSS VCC SCLK VSS2 DO Not used Not used Not used Not used Not used Not used Name I I/PP S S I S O/PP SPI mode Type Description Chip Select (active Low) Data In Supply voltage ground Supply voltage Clock Supply voltage ground Data Out 1. S = power supply; I = input; O = output; PP = push-pull; OD = open drain; NC = Not connected (or logical High). Table 63. Name CID RCA DSR CSD OCR MultiMediaCard registers in SPI mode Available Yes No No Yes Yes 16 4 Card specific data, card operation conditions Operation condition register Width (in bytes) 16 Description Card identification data (serial number, manufacturer code, etc.) 84/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.4 SPI bus protocol While the MultiMediaCard channel is based on command and data bit streams which are initiated by a start bit and terminated by a stop bit, the SPI channel is byte oriented. Every command or data block consists of 8-bit bytes and is byte aligned to the CS signal (i.e. the length is a multiple of 8 clock cycles). Like in the MultiMediaCard protocol, the SPI messages consist of command, response and data-block tokens (see Section 4). All communication between host and device is controlled by the host (master). The host starts every bus transaction by asserting the CS signal Low. The response behavior in the SPI mode differs from that in the MultiMediaCard mode in the three following aspects: ● ● ● The selected device always responds to the command Additional (8, 16 & 40 bit) response structures are used When the device encounters a data retrieval problem, it responds with an error response (which replaces the expected data block) instead of a timeout in the MultiMediaCard mode. Only Single and Multiple Block Read/Write operations are supported in SPI mode (sequential mode is not supported). In addition to the command response, a special data response token is returned for every data block sent to the device during write operations. A data block may be as big as one device write block and as small as a single byte. Partial block read/write operations are enabled by device options specified in the CSD Register. 10.4.1 Mode selection The MultiMediaCard wakes up in the MultiMediaCard mode. It enters the SPI mode if the CS signal is asserted (negative) during the reception of the reset command (CMD0). The SPI mode can also be selected from other states than the Idle state (the state the device enters after power-up). Every time the device receives CMD0, even while the device is in the Inactive state, the CS signal is sampled. If the device recognizes that the MultiMediaCard mode is required (CS signal is High), it does not respond to the command and remains in the MultiMediaCard mode. If the SPI mode is required (CS signal is Low), the device switches to the SPI mode and responds with the SPI mode R1 response. The only way to return to the MultiMediaCard mode is by a power-down cycle (turn the power off an on). In SPI mode, the MultiMediaCard protocol state machine is not observed. All the MultiMediaCard commands supported in the SPI mode are always available. 85/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.4.2 Bus transfer protection Every MultiMediaCard token transferred on the bus is protected by CRC (Cyclic Redundancy Check) bits. In SPI mode, the MultiMediaCard offers a non-protected mode which enables systems built with reliable data links to exclude the hardware or firmware required for implementing the CRC generation and verification functions. In the non-protected mode, the CRC bits of the command, response and data tokens are still required in the tokens. However, they are defined as ‘don’t care’ for the transmitter and ignored by the receiver. The SPI interface is initialized in the non-protected mode. However, the RESET command (CMD0), which is used to switch the device to SPI mode, is received by the device while in MultiMediaCard mode and, therefore, must have a valid CRC field. Since CMD0 has no arguments, the content of all the fields, including the CRC field, are constants and need not be calculated in run time. A valid reset command is: 0x40, 0x0, 0x0, 0x0, 0x0, 0x95 The host can turn the CRC option on and off using the CRC_ON_OFF command (CMD59). 10.4.3 Data Read The SPI mode supports Single and Multiple Block Read operations. The main difference between SPI and MultiMediaCard modes is that the data and the response are both transmitted to the host on the DataOut signal (refer to Figure 29 and Figure 30). Therefore the device response to the STOP_COMMAND may cut-short and replace the last data block. Figure 29. SPI Single Block Read operation from host to card from card to host data from card to host next command Data in command command Data out response data block CRC ai08345 86/116 NAND08GAH0A, NAND16GAH0D Figure 30. SPI Multiple Block Read operation from host to card from card to host Serial peripheral interface (SPI) mode data from card to host next command Data in command STOP command Data out response data block CRC data block CRC data b. response ai08346 The basic unit of data transfer is the block whose maximum size is defined in the CSD (READ_BL_LEN).If READ_BL_PARTIAL is set, smaller blocks whose start and end addresses are entirely contained within one physical block (as defined by READ_BL_LEN) may also be transmitted. A CRC is appended to the end of each block to ensure data transfer integrity. CMD17 (READ_SINGLE_BLOCK) initiates a single block read. CMD18 (READ_MULTIPLE_BLOCK) starts a transfer of several consecutive blocks. Two types of Multiple Block Read transactions are defined (the host can use either of them at any time): Open-ended Multiple Block Read The number of blocks for the Multiple Block Read operation is not defined. The device continuously transfers data blocks until a stop transmission command is received. Multiple Block Read with pre-defined block count The device transfers the requested number of data blocks and terminates the transaction. A Stop command is not required at the end of this type of Multiple Block Read, unless it is terminated with an error. In order to start a Multiple Block Read with pre-defined block count the host must use the SET_BLOCK_COUNT command (CMD23) just before issuing the READ_MULTIPLE_BLOCK (CMD18) command. Otherwise the device starts an openended Multiple Block Read that can be stopped using the STOP_TRANSMISION command. The host can abort reading at any time, within a multiple block operation, regardless of the its type. Transaction abort is done by sending the STOP_TRANSMISION command. If the host provides an out-of-range address as an argument to either CMD17 or CMD18, or if the currently defined block length is illegal for a read operation, the device rejects the command and responds with the ADDRESS_OUT_OF_RANGE or BLOCK_LEN_ERROR bit set, respectively. If the host sets the argument of the SET_BLOCK_COUNT command (CMD23) to all 0’s, then the command is accepted, however, a subsequent read follows the open-ended Multiple Block Read protocol (STOP_TRANSMISSION command - CMD12 - is required). In case of a data retrieval error (such as out of range, address misalignment or internal error) detected during data transfer, the device does not transmit any data. Instead (as opposed to MultiMediaCard mode where the device times out), a special data error token is sent to the host. Figure 31 shows a single block read operation terminated with an error token and not a data block. Multiple Block Read operation can be terminated in the same way, with the error token replacing a data block anywhere in the sequence. The host must then abort the operation by sending the STOP_TRANSMISSION command. 87/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D If the host sends a STOP_TRANSMISSION command after the device transmitted the last block of a Multiple Block Read with a pre-defined number of blocks, it is responded to as for an illegal command. If the host uses partial blocks whose accumulated length is not block aligned, and block misalignment is not allowed, the device detects a block misalignment error condition during the transmission of the first misaligned block and the content of the further transferred bits is undefined. As the host sends CMD12, the device responds with the ADDRESS_MISALIGN bit set. Figure 31. SPI Read operation – data error from host to card from card to host data error token from card to host next command Data in command command Data out response data error ai08347b 88/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.4.4 Data Write The SPI mode supports single block and Multiple Block Write commands. Upon reception of a valid write command (CMD24 or CMD25), the device responds with a response token and waits for the host to send a data block. The CRC suffix, block length and start address restrictions are (with the exception of the CSD parameter WRITE_BL_PARTIAL controlling the partial block write option) identical to the read operation (see Figure 29). If a CRC error is detected it is reported in the data-response token and the data block is programmed. Figure 32. SPI Single Block Write operation from host to card from card to host Start block token data from host to card data response new command and busy from from host card to host Data in command data block command Data out response data response busy ai08354b Figure 33. SPI Multiple Block Write operation from host to card from card to host Start Block token data from host to card data response and busy from card Start Block token data from host to card Stop Tran token to card Data in command data block data block Data out response data response busy data response busy busy ai08355b Every data block has a ‘Start block’ token prefix of one byte. After receiving a data block, the device responds with a data-response token. If the data block has been received without errors, it is programmed. As long as the device is busy programming, a continuous stream of busy tokens is sent to the host (effectively holding the DataOut line Low). In Multiple Block Write operations the host stops the transmission by sending the ‘Stop tran’ token instead of the ‘Start block’ token at the beginning of the next block. Two types of Multiple Block Write transactions, identical to the Multiple Block Read, are defined (the host can use either of them at any time): Open-ended Multiple Block Write The number of blocks for the Multiple Block Write operation is not defined. The device accepts and programs all received data blocks until it receives a ‘Stop tran’ token. Multiple Block Write with pre-defined block count The device accepts the requested number of data blocks and then terminates the transaction. The ‘Stop tran’ token is not required at the end of this type of Multiple Block Write operation, unless the operation is terminated with an error. In order to start a Multiple 89/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D Block Write operation with pre-defined block count the host must issue the SET_BLOCK_COUNT command (CMD23) just before sending the WRITE_MULTIPLE_BLOCK (CMD25) command. Otherwise the device starts an openended Multiple Block Write operation that can be stopped using the ‘Stop tran’ token. The host can abort writing at any time, within a Multiple Block Write operation, regardless of its type. Transaction abort is done by sending the ‘Stop tran’ token. If a Multiple Block Write operation with pre-defined block count is aborted, the data in the remaining blocks is not defined. If the host provides an out-of-range address as an argument to either CMD17 or CMD18, or if the currently defined block length is illegal for a read operation, the device rejects the command, remains in Tran state and responds with the ADDRESS_OUT_OF_RANGE or BLOCK_LEN_ERROR bit set, respectively. If the host sets the argument of the SET_BLOCK_COUNT command (CMD23) to all 0’s, then the command is accepted, however, a subsequent write follows the open-ended Multiple Block Write protocol (STOP_TRANSMISSION command - CMD12 - is required). If the device detects a CRC error or a programming error (such as write protect violation, out of range, address misalignment or internal error) during a Multiple Block Write operation (both types) it reports the failure in the data-response token and ignores any further incoming data blocks. The host must than abort the operation by sending the ‘Stop tran’ token. If the host uses partial blocks whose accumulated length is not block aligned, and block misalignment is not allowed (CSD parameter WRITE_BLK_MISALIGN is not set), the device detects the block misalignment error upon reception of the first misaligned block, aborts the write operation, and ignores all further incoming data. The host must abort the operation by sending the ‘Stop tran’ token. The devices then responds by setting the ADDRESS_MISALIGN bit. Once the programming operation has completed (either successfully or with an error), the host must check the results of the programming (or the cause of the error if already reported in the data-response token) using the SEND_STATUS command (CMD13). If the host sends a ‘Stop tran’ token after the device received the last data block of a multiple block operation with pre-defined number of blocks, it is interpreted as the beginning of an illegal command and the device responds accordingly. When the device is busy, resetting the CS signal does not terminate the programming process. The device simply releases the DataOut line (tri-state) and continues with the programming. If the device is reselected before the programming is finished, the DataOut line is forced back to Low and all commands are rejected. Resetting a device (using CMD0) terminates any pending or active programming operations. This may destroy the data formats on the device. It is the responsibility of the host to prevent this. 90/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.4.5 Erase and Write Protect management The Erase and Write Protect management procedures in the SPI mode are identical to those of the MultiMediaCard mode. While the device is erasing or changing the write protection bits of the predefined erase groups list, it is in a busy state and holds the DataOut line Low. Figure 34 illustrates a ‘no data’ bus transaction with and without busy signalling. Figure 34. Erase and Write Protect operations from host to card from card to host from host to card from card to host Data in command command Data out response response busy a 10.4.6 Read the CID and CSD registers Unlike the MultiMediaCard protocol (where the register contents is sent as a command response), reading the contents of the CSD and CID registers in SPI mode is a simple readblock transaction. The device responds with a standard response token (see Figure 31) followed by a data block of 16 bytes suffixed with a 16 bit CRC. The data time out for the CSD command cannot be set to the device TAAC since this value is stored in the CSD. Refer to Table 71 for timing values. For consistency, read CID transaction is identical to read CSD. 10.4.7 Reset sequence The MultiMediaCard requires a defined reset sequence. After power-up reset or CMD0 (software reset) the device enters an idle state. In this state the only legal host commands are CMD1 (SEND_OP_COND) and CMD58 (READ_OCR). The host must poll the device (by repeatedly sending CMD1) until the ‘in-idle-state’ bit in the device response indicates (by being cleared to 0) that the device has completed its initialization processes and is ready for the next command. In SPI mode, as opposed to MultiMediaCard mode, CMD1 has no operands and does not return the contents of the OCR register. Instead, the host may use CMD58 (available in SPI mode only) to read the OCR register. Furthermore, it is of the responsibility of the host to refrain from gaining access to a device that does not support its voltage range. The usage of CMD58 is not restricted to the initializing phase, the command can be issued at any time. The host must poll the device (by repeatedly sending CMD1) until the ‘in-idlestate’ bit in the device response indicates (by being cleared to 0) that the device has completed its initialization processes and is ready for the next command. 91/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.4.8 Clock control The SPI bus clock signal can be used by the SPI host to put the device into energy saving mode or to control the data flow (to avoid under-run or over-run conditions) on the bus. The host is allowed to change the clock frequency or shut it down. There are a few restrictions the SPI host must follow: ● ● The bus frequency can be changed at any time (under the restrictions of maximum data transfer frequency, defined by the MultiMediaCards) The clock must be running for the MultiMediaCard to output data or response tokens. After the last SPI bus transaction, the host must provide 8 (eight) clock cycles for the device to complete the operation before shutting down the clock. Throughout this 8clock period the state of the CS signal is irrelevant, it can be asserted or de-asserted. A command / response sequence, 8 clocks after the device response end bit. The CS signal can be asserted or de-asserted during these 8 clocks A read data transaction, 8 clocks after the end bit of the last data block A write data transaction, 8 clocks after the CRC status token The host is allowed to shut down the clock of a “busy” device. The MultiMediaCard completes the programming operation regardless of the host clock. However, the host must provide a clock edge for the device to turn off its busy flag. Without a clock edge the MultiMediaCard (unless previously disconnected by de-asserting the CS signal) will force the DataOut line Low, permanently. The various SPI bus transactions are listed below: ● ● ● ● 10.4.9 Error conditions CRC and illegal command All commands are (optionally) protected by CRC (cyclic redundancy check) bits. If the addressed MultiMediaCard's CRC check fails, the COM_CRC_ERROR bit is set in the device response. Similarly, if an illegal command has been received the ILLEGAL_COMMAND bit is set in the device response. There are different kinds of illegal commands: ● ● ● Commands that belong to classes not supported by the MultiMediaCard (like interrupt and I/O commands) Commands not allowed in SPI mode Commands that are not defined (like CMD47). 92/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.4.10 Read, Write, Erase and Forced Erase timeout conditions The time period after which a timeout condition for read/write/erase operations occurs are (device independent) 10 times longer than the typical access/program times for the operations listed below. A device must complete the command within this time period, or give up and return an error message. If the host does not get a response within the defined timeout time it must assume that the device is not going to respond and try to recover (e.g. reset the device, power cycle, reject). The typical access and program times are defined as follows: ● Read The read access time is defined as the sum of the two times given by the CSD parameters TAAC and NSAC. These device parameters define the typical delay between the end bit of the read command and the start bit of the data block. This number is device dependent. ● Write The R2W_FACTOR field in the CSD is used to calculate the typical block program time obtained by multiplying the read access time by this factor. It applies to all write/erase commands (e.g. SET(CLEAR)_WRITE_PROTECT, PROGRAM_CSD(CID) and the block write commands). ● Erase The duration of an erase command is (in order of magnitude) the number of write blocks to be erased multiplied by the block write delay. ● ● Forced Erase The Forced Erase timeout is specified in Table 16. Read ahead in Multiple Block Read operation In Multiple Block Read operations, in order to improve the read performance, the device may fetch data from the memory array, ahead of the host. In this case, when the host is reading the last addresses of the memory, the device attempts to fetch data beyond the last physical memory address and generates an ADDRESS_OUT_OF_RANGE error. Therefore, even if the host times the stop transmission command to stop the device immediately after the last byte of data was read, the device may already have generated the error, and it will show in the response to the stop transmission command. The host should ignore this error. 10.4.11 Memory array partitioning It is the same as in the MultiMediaCard mode (see Section 3). 10.4.12 Lock/Unlock commands In SPI mode the Lock and Unlock commands are the same as in MultiMediaCard mode (see Section 5.5.3 and Section 5.5.4). 10.4.13 Application specific commands The only difference between the MultiMediaCard and SPI modes is the APP_CMD status bit which is not available in SPI mode. 93/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.5 SPI mode commands All the SPI commands are 6 bytes long. The command always starts with the left bit of the string, which corresponds to the command code. See Table 64 for details of the command format. The commands in SPI mode are divided into several classes as in MultiMediaCard mode. However, the supported and available classes are different for each mode. See Table 65 for details. Table 66 gives a detailed description of the commands supported in SPI mode. If no argument is required in the command, the value of the field should be set to ‘0’. Reserved commands are reserved in both MultiMediaCard and SPI modes. The contents of the command index field is binary: for example it is ‘000000’ for CMD0 and ‘100111’ for CMD39. Table 64. Command format 47 1 0 Start bit 46 1 1 [45:40] 6 x [39:8] 32 x Argument [7:1] 7 x CRC 0 1 1 End bit Bit position Width (bits) Value Descriptions Transmission bit Command index Table 65. Command classes in SPI mode Card Supported commands CMD Class class description 0 1 6 8 9 10 12 13 16 17 18 23 24 25 27 28 29 30 35 36 38 42 55 56 58 59 (CCC) class 0 Basic +++++ + + + + Not class 1 supported in SPI mode class 2 Block Read Not class 3 supported in SPI mode class 4 Block Write class 5 class 6 class 7 class 8 Erase Write protection Lock Application specific + + + + + + + + + + + + + + + + + + + + Not class 9 supported in SPI mode class 10-11 Reserved 94/116 NAND08GAH0A, NAND16GAH0D Table 66. Commands and arguments Argument None None Response R1 R1 Serial peripheral interface (SPI) mode CMD SPI INDEX mode CMD0 CMD1 CMD2 CMD3 CMD4 CMD5 Yes Yes No No No Reserved Abbreviation GO_IDLE_STATE SEND_OP_COND Command description Resets the device Activates the device Initialization process CMD6 Yes [31:26] Set to ‘0’ [25:24] Access [23:16] Index [15:8] Value [7:3] Set to ‘0’ [2:0] Cmd Set R1b SWITCH Switches the device operating mode or modifies the EXT_CSD register CMD7 CMD8 No Yes [31:0] stuff bits R1 SEND_EXT_CSD Ask the address device to send back its EXT_CSD register as a data block Asks the selected device to send its Card Specific Data (CSD) Asks the selected device to send its Card Identification Data (CID) CMD9 Yes None R1 SEND_CSD CMD10 Yes None R1 SEND_CID CMD12 CMD13 Yes Yes None None R1 R2 STOP_TRANSMISSIO Stops transmission on N Multiple Block Read SEND_STATUS Asks the selected device to send its Status Register CMD14 Illegal command CMD15 No Selects a block length (in Bytes) for all following block commands (read and write)(1) CMD16 Yes [31:0] block length R1 SET_BLOCKLEN CMD17 Yes [31:0] data address (2) R1 Reads a block of the size READ_SINGLE_BLOC selected by the K SET_BLOCKLEN command(3) 95/116 Serial peripheral interface (SPI) mode Table 66. Commands and arguments (continued) Argument Response NAND08GAH0A, NAND16GAH0D CMD SPI INDEX mode Abbreviation Command description CMD18 Yes [31:0] data address R1 Continuously transfers data blocks from device to host READ_MULTIPLE_BLO until interrupted by a stop CK command or the requested number of data blocks have been transmitted CMD19 Illegal command CMD20 No CMD21 Reserved CMD22 Defines the number of blocks which are going to be transferred in the next Multiple Block Read or Write command Writes a block of the size selected by the SET_BLOCKEN command(4) Continuously writes blocks of data until a Stop tran prefix or the requested number of blocks have been received CMD23 Yes [31:16] set to 0 [15:0] number of blocks R1 SET_BLOCK_COUNT CMD24 Yes [31:0] data address R1 WRITE_BLOCK CMD25 Yes [31:0] data address R1 WRITE_MULTIPLE_ BLOCK CMD26 CMD27 No Yes None R1 PROGRAM_CSD Programs the programmable bits of the CSD If the device has write protection features, this command sets the write protection bit of the addressed group. The properties of write protection are coded in the card specific data register (WP_GRP_SIZE) If the device has write protection features, this command clears the write protection bit of the addressed group if the device has the write protection features, this command asks the device to send the status of the write protection bits(6) CMD28 Yes [31:0] data address R1b(5) SET_WRITE_PROT CMD29 Yes [31:0] data address R1b CLR_WRITE_PROT CMD30 Yes [31:0] write protect data address R1 SEND_WRITE_PROT 96/116 NAND08GAH0A, NAND16GAH0D Table 66. Commands and arguments (continued) Argument Response Serial peripheral interface (SPI) mode CMD SPI INDEX mode CMD31 Reserved Abbreviation Command description CMD32 Reserved ... These command indexes cannot be used for reasons of backward compatibility with older versions of the CMD34 MultiMediaCard CMD35 Yes [31:0] data address R1 ERASE_GROUP_ START Sets the address of the first erase group within a range to be selected for erase Sets the address of the last erase group within a continuous range to be selected for erase CMD36 Yes [31:0] data address R1 ERASE_GROUP_ END Reserved CMD37 These command indexes cannot be used for reasons of backward compatibility with older versions of the MultiMediaCard CMD38 CMD39 CMD40 Yes No No [31:0] stuff bits R1b ERASE Erases all previously selected erase groups CMD41 Reserved Used to set/reset the password or Lock/Unlock the device. The size of the data block is defined by the SET_BLOCK_LEN command CMD42 Yes [31:0] stuff bits R1b LOCK_UNLOCK CMD43 ... Reserved CMD54 Notifies the device that the next command is an application specific command rather than a standard command Used either to transfer a data block to the device or to read a data block from the device for general purpose/application specific commands. The size of the data block is defined by the SET_BLOCK_LEN command. CMD55 Yes [31:0] stuff bits R1 APP_CMD CMD56 Yes [31:1] stuff bits [0] RD/WR(7) R1 GEN_CMD CMD57 Reserved 97/116 Serial peripheral interface (SPI) mode Table 66. Commands and arguments (continued) Argument NAND08GAH0A NAND16GAH0D None [31:1] stuff bits [0] CRC option Response R3 NAND08GAH0A, NAND16GAH0D CMD SPI INDEX mode CMD58 Yes Abbreviation READ_OCR Command description Reads the OCR register of a device Turns the CRC option on or off CRC option bit = ‘1’ on CRC option bit = ‘0’ off CMD59 Yes R1 CRC_ON_OFF CMD60 -63 No 1. See Section 8.3: Card specific data register (CSD) for the value of the default block length. 2. Data address on the NAND08GAH0A and the NAND16GAH0D is a 32-bit byte address. 3. The data transferred must not cross a physical block boundary unless READ_BLK_MISALIGN is set in the CSD register. 4. The data transferred must not cross a physical block boundary unless WRITE_BLK_MISALIGN is set in the CSD register. 5. R1b: R1 response with an optional busy flag (see Section 10.6.2). 6. 32 write protection bits (representing 32 write protect groups starting at the specified address) followed by 16 CRC bits are transferred in a payload format via the data line. The last (least significant) bit of the protection bits corresponds to the first addressed group. If the addresses of the last groups are outside the valid range, then the corresponding write protection bits are set to zero. 7. RD/WR is set to ‘1’ if the host receives a data block from the device, and to ‘0’ if the host sends a data block to the device. 98/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.6 SPI mode responses In SPI mode like in MultiMediaCard mode, responses are transmitted most significant bit (MSB) first. There are different types of responses: 10.6.1 R1 format This is the format of the response sent by the device to any command received except for the SEND_STATUS and READ_OCR commands (See R2 and R3, respectively). R1 format responses are one byte long. Their most significant bit is always ‘0’ and the other bits are error bits. Any one of the error bits going High, (set to ‘1’) indicates an error. Refer to Figure 35 for the structure of the R1 response format and to Table 68 for the meaning of the bits. Figure 35. R1 response format 7 (MSB) 0 0 In Idle State Erase Reset Illegal Command/Switch error Communication CRC Error Erase Sequence Error Address misaligned Address out of range/block length error Ai13610 10.6.2 R1b format It consists of the R1 response plus an optional busy flag. The busy flag does not have a fixed number of bytes. When its value is zero, the device is busy. When its value is different from zero, the device is ready. Figure 36. R1b response format 7 (MSB) 0 0 R1 Busy flag AI13609 99/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.6.3 R2 format This is the format of the response sent by the device to the SEND_STATUS command. R2 format responses are two bytes long. The first byte is identical to the R1 response byte. All the bits in the second byte are error bits; any one of them going High, (set to ‘1’) indicates an error. Refer to Figure 37 for the structure of the R2 response format and to Table 68 for the meaning of the bits. Figure 37. R2 response format 7 (MSB) 0 Card is Locked WP Erase Skip Lock/Unlock cmd failed R1 Execution Error Card Error Card ECC failed Write Protect Violation Erase Param Out of Range/ CSD_Overwrite AI13612 Byte 1 0 7 Byte 2 0 10.6.4 R3 format This is the format of the response sent by the device to the READ_OCR command. R3 format responses are five bytes long. The first byte is identical to the R1 response byte. The other four bytes contain the OCR Register. Figure 38 shows the structure of the R3 response format. Figure 38. R3 response format 39 (MSB) 0 Byte 1 32 31 Bytes 2, 3, 4 and 5 0 R1 OCR AI08369 100/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.6.5 Data response format This is the format of the acknowledgement sent by the device for each data block written to it. The data response is one byte long and contains three Status bits. If the Status bits in the data response are: ● ● ● ‘010’, it means that the data is accepted ‘101’, it means that a CRC error occurred and the data is rejected ‘110’, it means that a Write Error occurred and the data is rejected. If the CRC or Write error occurs during a Write Multiple Block operation, the host must abort the operation by sending a Stop tran prefix. Figure 39 shows the structure of the Data response format. Figure 39. Data response format 7 x 6 x 5 x 4 0 Status bits 0 1 AI08370 10.6.6 Data messages Data is transferred in the form of data messages during Read and Write transactions. Data bytes are always transmitted most significant bit (MSB) first. The data messages are 4 to N+3 bytes long, where N is the data block length set using the SET_BLOCK_LENGTH command. The first byte indicates the type of transaction (see Table 67 for details), the bytes 2 to N+1 contain user data and the last two bytes consist of the 16 CRC bits. Table 67. Data message first byte Bit position Transaction type 7 6 1 1 1 1 1 5 1 1 1 1 1 4 1 1 1 1 1 3 1 1 1 1 1 2 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 1 Single Block Read Multiple Block Read Single Block Write Multiple Block Write Multiple Block Write 1 1 1 1 1 Message type Start Block Start Block Start Block Start Block Stop tran 101/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.6.7 Data error messages If a read operation fails, a data error message is returned to the host instead of the requested data. Data Error Messages are one byte long. Refer to Figure 40 for the structure of the data error message format and to Table 68 for the meaning of the bits. Figure 40. Data error message format 7 0 0 0 Execution Error Card Error Card ECC failed Address Out of Range Address misaligned AI13611 0 10.7 Clearing Status Register bits In SPI mode, Error and Status bits are reported to the host in three different formats: ● ● ● Response R1 Response R2 Data error message Note: The same bits may exist in multiple response types (for example Address out of range). All Error bits defined in MultiMediaCard mode, with the exception of Underrun and Overrun, have the same meaning and usage in SPI mode. There are some differences in the Status bits due to the different protocol (for example Current state is not defined in SPI mode). The detection mode and clear condition of Error and Status bits are identical to MultiMediaCard mode, except for Error bits which are cleared when read by the host, regardless of the response format. Not all status bits are meaningful all the time. The relevant bits depend on the classes supported by the device. If all the classes that affect a status/error, are not supported by the device, the bit is not relevant and can be ignored by the host. See Table 68 for details of how the status and error bits are set and cleared in SPI mode, and Table 69 for a description of relevant bits according to classes and commands. 102/116 NAND08GAH0A, NAND16GAH0D Table 68. Status bits definition in SPI mode(1) Response Type Detection mode R Address out of range R1 R2 DataErr E Value Serial peripheral interface (SPI) mode Identifier Description Command argument not allowed X ‘0’= no error A Multiple Block Read/Write operation ‘1’= error attempted to read or write beyond the device capacity (although it started at a valid address) Command using misaligned address, not matching the block length R Address misaligned R1 R2 DataErr E X ‘0’= no error ‘1’= error Multiple block Read/Write operation attempting to read or write data block which does not align with the device memory blocks ‘0’= no error An error occurred in the Erase command ‘1’= error sequence ‘0’= no error Invalid selection of erase groups during erase ‘1’= error operation ‘0’= no error Transferred block length not allowed, or number of bytes transferred not matching the ‘1’= error block length ‘0’= not protected ‘1’= protected Erase sequence error Erase param R1 R2 R2 E E R X Block length error R1 R2 E R WP violation R2 E X Attempt to write to a write protected block Communication CRC error Illegal command R1 R2 R1 R2 E E R R ‘0’= no error CRC check of the previous command failed ‘1’= error ‘0’= no error Illegal command not legal for the current state ‘1’= error ‘0’= not error ‘1’= error ‘0’= success ‘1’= failure If set, the device did not switch to the expected mode as requested by the SWITCH command Internal ECC performed but failed to correct the data Switch error R1 R2 E X Card ECC failed R2 DataErr E X Card error Execution error R2 DataErr R2 DataErr E E R X ‘0’= no error Internal device controller error ‘1’= error ‘0’= no error General or unknown error occurred during ‘1’= error operation ‘0’=not protected ‘1’= protected Partial address space erased due to existing Write protected blocks WP Erase skip R2 S X Lock/Unlock failed R2 E X This bit is set when a sequence or password ‘0’= no error error has been detected during a Lock/Unlock ‘1’= error command or if there was an attempt to access a locked device 103/116 Serial peripheral interface (SPI) mode Table 68. Status bits definition in SPI mode(1) (continued) Response Type Detection mode Value NAND08GAH0A, NAND16GAH0D Identifier Description Card locked R2 S ‘0’ = This bit is set when the device is locked by unlocked the host ‘1’ = locked Erase sequence cleared before executing ‘0’= cleared because an out of erase sequence command ‘1’= set was received The device enters idle state after power-up or ‘0’= Ready reset command. It exits this state and ‘1’= Idle become ready upon completion of the initialization sequence Can be one of the following errors: - The CID register has been already written and cannot be overwritten ‘0’= no error - The read only section of the CSD does ‘1’= error not match the device content. - An attempt to reverse the copy (set as original) or permanent WP (unprotected) bits was made. Erase reset R1 R2 E R In idle state R1 R2 S - CSD overwrite R2 E X 1. ‘R’ or ‘X’ mean the Error/Status bit may be affected by the respective command (using R or X detection mechanism respectively). ‘S’ indicates Status bits. 104/116 NAND08GAH0A, NAND16GAH0D Table 69. Comd/ classes 7 6 Serial peripheral interface (SPI) mode Status bits versus commands and classes (SPI mode) R2 response bits Data Error bit R1 response bits 5 4 3 2 1 0 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 Bit is valid for classes 1, 2, 3, 4, 5, 6 2, 4 5 All All All All All 5 3, 4 1, 3, All All All 2 4 All All 1, 2 All All CMD0 CMD1 CMD6 CMD8 CMD9 CMD10 CMD10 CMD12 CMD13 CMD16 CMD17 CMD18 CMD23 CMD24 CMD25 CMD27 CMD28 CMD29 CMD30 CMD35 CMD36 CMD38 CMD42 CMD55 CMD56 CMD58 CMD59 R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R/ X R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R S S S S S S S S S S S S S S S S S S S S S S S S S S S X X X X X X X R X X S R R R R R R R R R R R R R R R R R R R R R R R R R X X X X X X X X X X X X X X X X X X X X X X X X X X X S S S S S S S S S S S S S S S S S S S S S S S S S X X X X X X R R X X 105/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.8 Device registers In SPI mode, only the OCR, CSD and CID registers are accessible. Their format is identical to the format in MultiMediaCard mode. However, a few fields are irrelevant in SPI mode. 10.9 SPI bus timings Figure 41 illustrates the basic command/response transaction in SPI mode (that is, when the device is ready). Figure 42 describes a command/response transaction when the device is busy (R1b response format). Refer to Table 71 for the timing values. Table 70. S T P E Z D * SPI timing symbols Start bit (= 0) Transmitter bit (Host = 1, Device = 0) One-cycle Pull-up (= 1) End bit (=1) High Impedance state Data bits Repeater Table 71. Timing NCS NCR NCX NRC NAC NWR NEC NDS NBR SPI timing values Min 0 1 0 1 1 1 0 0 1 1 10/8(TAAC fOP + 100NSAC)(1) 8 8 Max Unit 8 clock cycles 8 clock cycles 8 clock cycles 8 clock cycles 8 clock cycles 8 clock cycles 8 clock cycles 8 clock cycles 8 clock cycles 1. fOP is the device clock frequency the host is using for the read operation. 106/116 NAND08GAH0A, NAND16GAH0D Serial peripheral interface (SPI) mode 10.9.1 Command/response timings Figure 41. Host command to device response timing diagram (device ready) CS DataIn HHLLL NCS X X H**H ********************* 6 Byte Command ********* L L L LHHH NEC DataOut Z Z Z H H H H H**H X X X H HHHH ********* NCR H H * * H 1or 2 Byte Response H H H H H Z Z ai08372 Figure 42. Host command to device response timing diagram (device busy) CS DataIn DataOut HL LL NCS X H**H Z Z H HH H ********************* 6 Byte Command ********* L L L L HHHL L L L LLHH NEC NDS NEC H H H H H H H HH H**H X*X HH H H*H X X NCR Busy L Z Z Z Busy H H H H Z H * * H Response ai08373 Figure 43. Device response to Host command timing diagram CS DataIn LLLLL HHHHHH ********************* ********* HHHH NRC H**H 6 Byte Command ********* L LHHH HHHHX X X HHHHH Z Z ai08374 DataOut H H H H H 1 or 2 Byte Response 107/116 Serial peripheral interface (SPI) mode NAND08GAH0A, NAND16GAH0D 10.9.2 Data Read timings The timing diagram for deselecting the device (by de-asserting CS after the last device response) corresponds to a standard command-to-response timing diagram as illustrated in Figure 41. During open-ended Multiple Block Read operations, the STOP_TRANSMISSION command may be sent while the device is transmitting data to the host. In this case, the device stops transmitting the data block within two clock cycles (the bits in the first byte may not all be set to ‘1’) and returns the response message after a time measured in numbers of clock cycles (NCR). Refer to Table 71 for timing values and to Figure 44, Figure 45, Figure 46, and Figure 47 for a description of Data Read timing diagrams. Figure 44. Single Block Read timing diagram CS DataIn HLLL NCS X H**H L L LHHHH NEC H*H X XX X ********************* Read Command H H H H H ************ NCR NAC H * * H Card Response H * * H Data Block H H H H Z Z Z DataOut Z Z H H H H ******* ai08375 Figure 45. STOP_TRANSMISSION between blocks in Multiple Block Read timing diagram CS DataIn HL L NCS X H*H ********************* Read Cmd LLLLL DataOut Z Z H H H **** H H Stop Cmd H H H H H H H HHHH *********** NAC NAC NCR NCR H * H Card Resp H * H Data Block H * H Data Block H H * H Card Resp ai08376 Figure 46. STOP_TRANSMISSION within a block in Multiple Block Read timing diagram CS DataIn DataOut HLL NCS X H*H Z ZHHH Read Cmd ********************* H H HH NCR ******** NAC LLLLL **** H H H Stop Cmd H H H H H H H H H H NCR NAC H * H Card Resp H * H Data Block H * H Data X X H * * H Card Resp ai08377 108/116 NAND08GAH0A, NAND16GAH0D Figure 47. CSD and CID register Read timing diagram CS DataIn HL LL NCS X H**H Serial peripheral interface (SPI) mode ********************* Read Command L L L HHHH NEC DataOut Z Z H H H H ****** HHHH H H*H XX X X ********** NCX NCR H * * H Card Response H * * H Data Block H H H H Z Z Z ai08377 1. The timeout between the device response and the data block is NCX as NAC is not known yet. 10.9.3 Data Write timings The host may deselect a device at any moment during single and Multiple Block Write operations. The device will release the DataOut line one clock cycle after it is deselected (CS High). To check whether the device is still busy, the host must reselect it by reasserting CS Low. The device will then take control of the DataOut line one clock cycle after being reselected. In Multiple Block Write operations, the timings from the command being issued to the first data block being transmitted by the device are the same as for single block Write operations (see Figure 48 and Figure 49 for details). The timing of STOP TRANSMISSION prefixes is the same as that of data blocks. After the Stop tran is received by the device, the data on the DataOut line is undefined for one byte (NBR), then a Busy message may be sent by the device. Refer to Table 71 for timing values. Figure 48. Single Block Write timing diagram CS DataIn DataOut HL NCS ***************** NWR L L L L L L L L LHHH L L L L NDS NEC X H * H Write Command Z ZHHH **** H H H H H H H H * H Data Block H H H H H * H X * X H H H H NCR H * H Card Resp H H H H H H H Data Resp Busy L Z Z Z Busy H ai08379 Figure 49. Multiple Block Write timing diagram CS DataIn L ************ NWR LLL LLLL LLLL LLLL LLLLL NWR H Data Block H H H H H H H H * H Data Block H H H H H H H H * H StopTran H H H H H NBR DataOut H H H H H Data Resp Busy H H H H H H H Data Resp Busy H H H H H H X * X Busy ai08380 109/116 Error protection NAND08GAH0A, NAND16GAH0D 11 Error protection All commands, responses and data transfers are protected against transmission errors by CRC (cyclic redundancy check) codes. One CRC is generated for each command and checked for each response transferred through the CMD line. For data blocks, one CRC per transferred block and per data line is generated. If the addressed device CRC check fails, the device does not respond, and the command is not executed. 11.1 CRC7 The CRC7 check is used for all commands, all responses except responses of R3 type, and for the CSD and CID registers. The CRC7 code is a 7-bit value. It is computed as follows: The generator polynomial is G ( x ) = x + x + 1 M ( x ) = firstbit × x + sec ondb it × x n n–1 7 7 3 0 + …+ lastbit × x C RC [ 6 … ] = Remainder [ ( M ( ( x ) × x ) ) ⁄ ( G ( x ) ) ] 0 All CRC registers are initialized to zero. The first bit is the outmost left bit of the corresponding bit string of the command, response, CID or CSD). The degree n of the polynomial is the number of CRC protected bits decreased by one. The number of bits to be protected is 40 for commands and responses (n = 39), and 120 for the CSD and CID (n = 119). Figure 50. CRC7 generator/checker data out data in AI13107 110/116 NAND08GAH0A, NAND16GAH0D Error protection 11.2 CRC16 The CRC16 is used for payload protection in block transfer mode. The CRC check sum is a 16-bit value. It is computed as follows: The generator polynomial is G( x) = x 16 12 5 +x +x +1 n n–1 M ( x ) = firstbit × x + sec ondb it × x + …+ lastbit × x 0 CRC [ 15 … ] = Remainder [ ( M ( ( x ) × x ) ) ⁄ ( G ( x ) ) 0 16 All CRC registers are initialized to zero. The first bit is the first data bit of the corresponding block. The degree n of the polynomial is the number of bits of the data block decreased by one (e.g. n = 4095 for a block length of 512 bytes). The generator polynomial is a standard CCITT polynomial. The code has a minimal distance d set to 4 and is used for a payload length of up to 2048 bytes (n
NAND16GAH0D 价格&库存

很抱歉,暂时无法提供与“NAND16GAH0D”相匹配的价格&库存,您可以联系我们找货

免费人工找货