## Controller for AND Flash Memory # **HITACHI** ADE-203-988A (Z) Rev. 1.0 Apr. 16, 1999 ### **Description** HN29W6484AH03TE-1 is a controller IC for flash ATA card. This IC is manufactured based on Hitachi 0.5 μm CMOS technology, and integrates control logic with 8 bit micro processor. This IC is able to control maximum 20 pieces of Hitachi 64 Mega bit Flash Memory HN29W6411A and maximum 2 pieces of Hitachi 84 Mega bit Flash Memory HN29W8411, and is used to build Flash ATA Card and CompactFlash<sup>TM</sup>. #### **Features** - Comform to PC-ATA Card and CompactFlash<sup>™</sup> specification standard - Control maximum 20 pieces of Hitachi 64 Mega bit Flash memory HN29W6411A and maximum 2 pieces of Hitachi 84 Mega bit Flash Memory HN29W8411 - Operate by 3.3V or 5V single power supply - Support card density up to 160/20 Mega bytes - $\bullet$ Execute internal self-diagnostic program at $V_{\scriptscriptstyle CC}$ power on - Operate in 3 modes - Memory Card Mode - I/O Card Mode - True-IDE Mode - Assure a high reliability based on the internal ECC (Error Correcting Code) function - Support Auto Sleep Mode - Support interleave operation in 2 bank organization Note: CompactFlash<sup>™</sup> is a trademark of SanDisk Corporation and is licensed royalty-free to the CFA which in turn will license it royalty-free to CFA members. \*CFA: CompactFlash<sup>TM</sup> Association. ## Pin Assignment | | | Memory card | mode | I/O card mode | I/O card mode | | True IDE mode | | | |-----|------------|-------------|------|---------------|---------------|-------------|---------------|-----------|--| | NO. | Controller | Signal name | I/O | Signal name | I/O | Signal name | I/O | Remarks*1 | | | 1 | H_A(2) | A2 | I | A2 | I | A2 | I | PC3B43C | | | 2 | H_INPACK_ | -INPACK | 0 | -INPACK | 0 | -INPACK | 0 | PC3BI3C | | | 3 | H_REG_ | –REG | I | –REG | I | –REG | I | PC3B63VC | | | 4 | DASP_ | BVD2 | I/O | -SPKR | I/O | -DASP | I/O | PC3B43VC | | | 5 | H_STSCHG_ | BVD1 | I/O | -STSCHG | I/O | -PDIAG | I/O | PC3B43VC | | | 6 | H_A(1) | A1 | I | A1 | I | A1 | I | PC3B43C | | | 7 | H_A(0) | A0 | I | A0 | I | A0 | I | PC3B43C | | | 8 | GND | GND | _ | GND | _ | GND | _ | PV0A | | | 9 | H_D(0) | D0 | I/O | D0 | I/O | D0 | I/O | PC3BH3CX | | | 10 | H_D(1) | D1 | I/O | D1 | I/O | D1 | I/O | PC3BH3CX | | | 11 | H_D(2) | D2 | I/O | D2 | I/O | D2 | I/O | PC3BH3CX | | | 12 | H_IOIS16_ | WP | 0 | -IOIS16 | 0 | -IOIS16 | 0 | PC3N03C | | | 13 | H_D(8) | D8 | I/O | D8 | I/O | D8 | I/O | PC3BH3CX | | | 14 | H_D(9) | D9 | I/O | D9 | I/O | D9 | I/O | PC3BH3CX | | | 15 | H_D(10) | D10 | I/O | D10 | I/O | D10 | I/O | РСЗВНЗСХ | | | 16 | VCC | VCC | _ | VCC | _ | VCC | _ | PV3I | | | 17 | TEST4 | _ | 0 | _ | 0 | _ | 0 | PC3BI3C | | | 18 | PORST_ | PORST_ | I | PORST_ | I | PORST_ | Ţ | PC3B63C | | | 19 | TEST1 | _ | I | _ | I | _ | [ | PC3B63C | | | 20 | TEST2 | _ | I | _ | I | _ | I | PC3D21 | | | 21 | GND | GND | _ | GND | _ | GND | _ | PV0I | | | 22 | XIN | XIN | I | XIN | I | XIN | I | PC3X11H | | | 23 | XOUT | XOUT | 0 | XOUT | 0 | XOUT | 0 | PC3X11OH | | | 24 | GND | GND | _ | GND | _ | GND | _ | PV0A | | | 25 | VCC | VCC | _ | VCC | _ | VCC | _ | PV3A | | | 26 | F_WEB_ | F_WEB_ | 0 | F_WEB_ | 0 | F_WEB_ | 0 | PC3B43C | | | 27 | F_SC_B1 | F_SC_B1 | 0 | F_SC_B1 | 0 | F_SC_B1 | 0 | PC3B43C | | | 28 | F_SC_B2 | F_SC_B2 | 0 | F_SC_B2 | 0 | F_SC_B2 | 0 | PC3B43C | | | 29 | F_DB(7) | F_DB(7) | I/O | F_DB(7) | I/O | F_DB(7) | I/O | PC3B42UX | | | 30 | F_DB(6) | F_DB(6) | I/O | F_DB(6) | I/O | F_DB(6) | I/O | PC3B42UX | | | | | | | | | | | | | ## Pin Assignment (cont.) | | | Memory card | mode | I/O card mode | | True IDE mod | | | |-----|------------|-------------|------|---------------|-----|--------------|-----|-----------| | NO. | Controller | Signal name | I/O | Signal name | I/O | Signal name | I/O | Remarks*1 | | 31 | F_DB(5) | F_DB(5) | I/O | F_DB(5) | I/O | F_DB(5) | I/O | PC3B42UX | | 32 | F_DB(4) | F_DB(4) | I/O | F_DB(4) | I/O | F_DB(4) | I/O | PC3B42UX | | 33 | F_DB(3) | F_DB(3) | I/O | F_DB(3) | I/O | F_DB(3) | I/O | PC3B42UX | | 34 | GND | GND | _ | GND | _ | GND | _ | PV0A | | 35 | F_DB(2) | F_DB(2) | I/O | F_DB(2) | I/O | F_DB(2) | I/O | PC3B42UX | | 36 | F_DB(1) | F_DB(1) | I/O | F_DB(1) | I/O | F_DB(1) | I/O | PC3B42UX | | 37 | F_DB(0) | F_DB(0) | I/O | F_DB(0) | I/O | F_DB(0) | I/O | PC3B42UX | | 38 | F_OEB_ | F_OEB_ | 0 | F_OEB_ | 0 | F_OEB_ | 0 | PC3B42C | | 39 | F_CDEB_ | F_CDEB_ | 0 | F_CDEB_ | 0 | F_CDEB_ | 0 | PC3B42C | | 40 | F_RDY_2 | F_RDY_2 | I | F_RDY_2 | I | F_RDY_2 | I | PC3B63UC | | 41 | F_RES_ | F_RES_ | 0 | F_RES_ | 0 | F_RES_ | 0 | PC3O03C | | 42 | F_CEB_1 | F_CEB_1 | 0 | F_CEB_1 | 0 | F_CEB_1 | 0 | PC3B43C | | 43 | F_CEB_2 | F_CEB_2 | 0 | F_CEB_2 | 0 | F_CEB_2 | 0 | PC3B43C | | 44 | F_CEB_3 | F_CEB_3 | 0 | F_CEB_3 | 0 | F_CEB_3 | 0 | PC3B43C | | 45 | TEST3 | _ | I | _ | I | _ | I | @ | | 46 | VCC | VCC | _ | VCC | _ | VCC | _ | PV3I | | 47 | TEST5 | _ | I/O | _ | I/O | _ | I/O | PC3B63UC | | 48 | GND | GND | _ | GND | _ | GND | _ | PV0A | | 49 | F_CEB_4 | F_CEB_4 | 0 | F_CEB_4 | 0 | F_CEB_4 | 0 | PC3B43C | | 50 | F_CEB_5 | F_CEB_5 | 0 | F_CEB_5 | 0 | F_CEB_5 | 0 | PC3B43C | | 51 | GND | GND | _ | GND | _ | GND | _ | PV0I | | 52 | F_CEB_6 | F_CEB_6 | 0 | F_CEB_6 | 0 | F_CEB_6 | 0 | PC3B43C | | 53 | F_CEB_7 | F_CEB_7 | 0 | F_CEB_7 | 0 | F_CEB_7 | 0 | PC3B43C | | 54 | F_CEB_8 | F_CEB_8 | 0 | F_CEB_8 | 0 | F_CEB_8 | 0 | PC3B43C | | 55 | F_CEB_9 | F_CEB_9 | 0 | F_CEB_9 | 0 | F_CEB_9 | 0 | PC3B43C | | 56 | F_CEB_10 | F_CEB_10 | 0 | F_CEB_10 | 0 | F_CEB_10 | 0 | PC3B43C | | 57 | F_CEA_1 | F_CEA_1 | 0 | F_CEA_1 | 0 | F_CEA_1 | 0 | PC3BH3UC | | 58 | F_CEA_2 | F_CEA_2 | 0 | F_CEA_2 | 0 | F_CEA_2 | 0 | PC3BH3UC | | 59 | VCC | VCC | _ | VCC | _ | VCC | _ | PV3A | | 60 | F_SC_A1 | F_SC_A1 | 0 | F_SC_A1 | 0 | F_SC_A1 | 0 | PC3B43C | | | | | | | | | | | ## Pin Assignment (cont.) | | | Memory card | mode | I/O card mode | I/O card mode | | True IDE mode | | | |-----|------------|-------------|------|---------------|---------------|-------------|---------------|-----------|--| | NO. | Controller | Signal name | I/O | Signal name | I/O | Signal name | I/O | Remarks*1 | | | 61 | F_SC_A2 | F_SC_A2 | 0 | F_SC_A2 | 0 | F_SC_A2 | 0 | PC3B43C | | | 62 | GND | GND | _ | GND | _ | GND | _ | PV0A | | | 63 | F_CEA_3 | F_CEA_3 | 0 | F_CEA_3 | 0 | F_CEA_3 | 0 | PC3BH3UC | | | 64 | F_CEA_4 | F_CEA_4 | 0 | F_CEA_4 | 0 | F_CEA_4 | 0 | PC3BH3UC | | | 65 | F_CEA_5 | F_CEA_5 | 0 | F_CEA_5 | 0 | F_CEA_5 | 0 | PC3BH3UC | | | 66 | F_CEA_6 | F_CEA_6 | 0 | F_CEA_6 | 0 | F_CEA_6 | 0 | PC3BH3UC | | | 67 | F_CEA_7 | F_CEA_7 | 0 | F_CEA_7 | 0 | F_CEA_7 | 0 | PC3BH3UC | | | 68 | F_CEA_8 | F_CEA_8 | 0 | F_CEA_8 | 0 | F_CEA_8 | 0 | PC3BH3UC | | | 69 | GND | GND | _ | GND | _ | GND | _ | PV0I | | | 70 | F_CEA_9 | F_CEA_9 | 0 | F_CEA_9 | 0 | F_CEA_9 | 0 | PC3BH3UC | | | 71 | F_CEA_10 | F_CEA_10 | 0 | F_CEA_10 | 0 | F_CEA_10 | 0 | PC3BH3UC | | | 72 | F_WEA_ | F_WEA_ | 0 | F_WEA_ | 0 | F_WEA_ | 0 | PC3B43UC | | | 73 | F_DA(7) | F_DA(7) | I/O | F_DA(7) | I/O | F_DA(7) | I/O | PC3B42UX | | | 74 | F_DA(6) | F_DA(6) | I/O | F_DA(6) | I/O | F_DA(6) | I/O | PC3B42UX | | | 75 | F_DA(5) | F_DA(5) | I/O | F_DA(5) | I/O | F_DA(5) | I/O | PC3B42UX | | | 76 | VCC | VCC | | VCC | _ | VCC | | PV3A | | | 77 | F_DA(4) | F_DA(4) | I/O | F_DA(4) | I/O | F_DA(4) | I/O | PC3B42UX | | | 78 | F_DA(3) | F_DA(3) | I/O | F_DA(3) | I/O | F_DA(3) | I/O | PC3B42UX | | | 79 | F_DA(2) | F_DA(2) | I/O | F_DA(2) | I/O | F_DA(2) | I/O | PC3B42UX | | | 80 | F_DA(1) | F_DA(1) | I/O | F_DA(1) | I/O | F_DA(1) | I/O | PC3B42UX | | | 81 | GND | GND | _ | GND | _ | GND | _ | PV0A | | | 82 | F_DA(0) | F_DA(0) | I/O | F_DA(0) | I/O | F_DA(0) | I/O | PC3B42UX | | | 83 | F_OEA_ | F_OEA_ | I/O | F_OEA_ | I/O | F_OEA_ | I/O | PC3B42UC | | | 84 | F_CDEA_ | F_CDEA_ | I/O | F_CDEA_ | I/O | F_CDEA_ | I/O | PC3B42UC | | | 85 | F_RDY_1 | F_RDY_1 | | F_RDY_1 | I | F_RDY_1 | I | PC3B63UC | | | 86 | TEST6 | _ | 0 | _ | 0 | _ | 0 | PC3BI3C | | | 87 | VCC | VCC | _ | VCC | _ | VCC | _ | PV3I | | | 88 | GND | GND | _ | GND | _ | GND | _ | PV0A | | | 89 | H_D(3) | D3 | I/O | D3 | I/O | D3 | I/O | РС3ВН3СХ | | | 90 | H_D(4) | D4 | I/O | D4 | I/O | D4 | I/O | РС3ВН3СХ | | ## Pin Assignment (cont.) | | | Memory card mode | | I/O card mode | | True IDE mode | | | | |-----|------------|------------------|-----|---------------|-----|---------------|-----|-----------|--| | NO. | Controller | Signal name | I/O | Signal name | I/O | Signal name | I/O | Remarks*1 | | | 91 | H_D(5) | D5 | I/O | D5 | I/O | D5 | I/O | РС3ВН3СХ | | | 92 | H_D(6) | D6 | I/O | D6 | I/O | D6 | I/O | РС3ВН3СХ | | | 93 | H_D(11) | D11 | I/O | D11 | I/O | D11 | I/O | РС3ВН3СХ | | | 94 | H_D(12) | D12 | I/O | D12 | I/O | D12 | I/O | РС3ВН3СХ | | | 95 | H_D(13) | D13 | I/O | D13 | I/O | D13 | I/O | РС3ВН3СХ | | | 96 | GND | GND | _ | GND | _ | GND | _ | PV0A | | | 97 | H_D(14) | D14 | I/O | D14 | I/O | D14 | I/O | РС3ВН3СХ | | | 98 | H_D(7) | D7 | I/O | D7 | I/O | D7 | I/O | РС3ВН3СХ | | | 99 | H_CE1_ | -CE1 | I | –CE1 | I | -CE1 | I | PC3B63VC | | | 100 | H_A(10) | A10 | I | A10 | I | A10 | I | PC3B43C | | | 101 | H_OE_ | –OE | I | –OE | I | -ATASEL | I | PC3B63C | | | 102 | H_D(15) | D15 | I/O | D15 | I | D15 | I | РС3ВН3СХ | | | 103 | H_CE2_ | -CE2 | I | -CE2 | I | -CE2 | I | PC3B63VC | | | 104 | H_IORD_ | -IORD | I | -IORD | I | -IORD | I | PC3B63VC | | | 105 | H_IOWR_ | -IOWR | I | -IOWR | I | -IOWR | I | PC3B63VC | | | 106 | VCC | VCC | _ | VCC | _ | VCC | _ | PV3A | | | 107 | H_A(9) | A9 | I | A9 | I | A9 | I | PC3B43C | | | 108 | H_A(8) | A8 | I | A8 | I | A8 | I | PC3B43C | | | 109 | H_A(7) | A7 | I | A7 | I | A7 | I | PC3B43C | | | 110 | H_A(6) | A6 | I | A6 | I | A6 | I | PC3B43C | | | 111 | GND | GND | I | GND | I | GND | I | PV0A | | | 112 | H_WE_ | -WE | I | -WE | I | -WE | I | PC3B63VC | | | 113 | H_IREQ_ | RDY/-BSY | 0 | –IREQ | 0 | INTRQ | 0 | PC3BI3C | | | 114 | CSEL_ | -CSEL | I | -CSEL | I | -CSEL | I | PT3B43VC | | | 115 | TEST7 | _ | 0 | _ | 0 | _ | 0 | @ | | | 116 | H_RESET | RESET | I | RESET | I | -RESET | I | PT3B43C | | | 117 | H_WAIT_ | -WAIT | 0 | -WAIT | 0 | IORDY | 0 | PC3BI3C | | | 118 | H_A(5) | A5 | I | A5 | I | A5 | I | PC3B43C | | | 119 | H_A(4) | A4 | I | A4 | I | A4 | I | PC3B43C | | | 120 | H_A(3) | A3 | I | A3 | I | A3 | I | PC3B43C | | Note: 1. Type of input/output buffer PC3B42C : CMOS level 3-state input/output (2 mA) PC3B42UC : CMOS level 3-state input/output with pull-up resister (2 mA) PC3B42UX : CMOS level 3-state input/output with pull-up resister (1 mA/2 mA) PC3B43C : CMOS level 3-state input/output (3 mA) PC3B43UC : CMOS level 3-state input/output with pull-up resister (3 mA) PC3B43VC : CMOS level 3-state input/output with pull-up resister 100 k $\Omega$ (3 mA) PC3B63C : CMOS level 3-state input/output with schmitt input (3 mA) PC3B63UC : CMOS level 3-state input/output with schmitt input, pull-up resister (3 mA) PC3B63VC $\,:\,$ CMOS level 3-state input/output with schmitt input, pull-up resister 100 k $\Omega$ (3 mA) PC3BH3CX : CMOS level 3-state input/output with active-LOW input enable (2 mA/3 mA) PC3BH3UC : CMOS level 3-state input/output with active-LOW input enable and pull-up resister (3 mA) PC3BI3C : CMOS level 3-state input/output with 3-state input enable (3 mA) PC3D21 : CMOS level schmitt input only PC3N03C : Open drain output (3 mA) PC3O03C : Topempole output (3 mA) PC3X11H : Crystal OSC input PC3X11OH : Crystal OSC output PT3B43C : TTL level input/output (3 mA) PT3B43VC : TTL level input/output with pull-up resister 100 k $\Omega$ (3 mA) PV0A : I/O GND PV0I : Core and I/O GND PV3A : I/O VCC PV3I : Core and I/O VCC @ : TEST pin only ## **Host Interface Pin Explanation** | Signal name | Direction | Pin No. | Description | |----------------------------------------------------|-----------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | A10 to A0<br>(PC Card Memory mode) | I | 100, 107, 108,<br>109, 110, 118,<br>119, 120, 1, 6, 7 | Address bus is A10 to A0. A10 is MSB and A0 is LSB. | | A10 to A0<br>(PC Card I/O mode) | - | | | | A2 to A0<br>(True IDE mode) | - | 1, 6, 7 | Address bus is A10 to A0. Only A2 to A0 are used, the remaining address lines should be grounded by the host. | | BVD1<br>(PC Card Memory mode) | I/O | 5 | BVD1 outputs the battery voltage status in the card. This output line is constantly driven to a high state since a battery is not required for this product. | | -STSCHG<br>(PC Card I/O mode) | - | | -STSCHG is used for changing the status of Configuration and status register in attribute area. | | -PDIAG<br>(True IDE mode) | - | | -PDIAG is the Pass Diagnostic signal in Master/Slave handshake protocol. | | BVD2<br>(PC Card Memory mode) | I/O | 4 | BVD2 outputs the battery voltage status in the card. This output line is constantly driven to a high state since a battery is not required for this product. | | -SPKR<br>(PC Card I/O mode) | - | | -SPKR outputs speaker signals. This output line is constantly driven to a high state since this product does not support the audio function. | | -DASP<br>(True IDE mode) | - | | -DASP is the Disk Active/Slave Present signal in the Master/Slave handshake protocol. | | -CE1, -CE2<br>(PC Card Memory mode)<br>Card Enable | I | 99, 103 | -CE1 and -CE2 are low active card select signals.<br>Byte/Word/Odd byte mode are defined by<br>combination of -CE1, -CE2 and A0. | | -CE1, -CE2<br>(PC Card I/O mode)<br>Card Enable | - | | | | -CE1, -CE2<br>(True IDE mode) | - | | -CE2 is used for select the Alternate Status Register and the Device Control Register while -CE1 is the chip select for the other task file registers. | | Signal name | Direction | Pin No. | Description | |----------------------------------------------------|-----------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -CSEL<br>(PC Card Memory mode) | I | 114 | This signal is not used. | | -CSEL<br>(PC Card I/O mode) | - | | | | -CSEL<br>(True IDE mode) | - | | This signal is used to configure this device as a Master or a Slave when configured in the True IDE mode. When this pin is grounded, this device is configured as a Master. When the pin is open, this device is configured as a Slave. | | D15 to D0<br>(PC Card Memory mode) | I/O | 102, 97, 95, 94,<br>93, 15, 14, 13,<br>98, 92, 91, 90,<br>89, 11, 10, 9 | Data bus is D15 to D0. D0 is the LSB of the even byte of the word. D8 is the LSB of the odd byte of the word. | | D15 to D0<br>(PC Card I/O mode) | = | | | | D15 to D0<br>(True IDE mode) | - | | | | GND<br>(PC Card Memory mode) | _ | 8, 21, 24, 34, 48,<br>51, 62, 69, 81,<br>88, 96, 111 | Ground | | GND<br>(PC Card I/O mode) | = | | | | GND<br>(True IDE mode) | - | | | | -INPACK<br>(PC Card Memory mode) | 0 | 2 | This signal is not used and should not be connected at the host. | | -INPACK<br>(PC Card I/O mode)<br>Input Acknowledge | - | | This signal is asserted low by this card when the card is selected and responding to an I/O read cycle at the address that is on the address bus during -CE and -IORD are low. This signal is used for the input data buffer control. | | -INPACK<br>(True IDE mode) | - | | This signal is not used and should not be connected at the host. | | -IORD<br>(PC Card Memory mode) | I | 104 | This signal is not used. | | -IORD<br>(PC Card I/O mode) | = | | -IORD is used for control of read data in I/O task file area. This card does not respond to -IORD until I/O card interface setting up. | | -IORD<br>(True IDE mode) | - | | -IORD is used for control of read data in I/O task file area. This card does not respond to -IORD until True IDE interface setting up. | | Signal name | Direction | Pin No. | Description | |----------------------------------------------------------|-----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -IOWR<br>(PC Card Memory mode) | I | 105 | This signal is not used. | | -IOWR<br>(PC Card I/O mode) | = | | -IOWR is used for control of data write in I/O task file area. This card does not respond to -IOWR until I/O card interface setting up. | | -IOWR<br>(True IDE mode) | - | | -IOWR is used for control of data write in I/O task file area. This card does not respond to -IOWR until True IDE interface setting up. | | -OE<br>(PC Card Memory mode) | I | 101 | -OE is used for the control of reading register's data in attribute area or task file area. | | -OE<br>(PC Card I/O mode) | - | | -OE is used for the control of reading register's data in attribute area. | | -ATASEL<br>(True IDE mode) | - | | To enable True IDE mode this input should be grounded by the host. | | RDY/-BSY<br>(PC Card Memory mode) | 0 | 113 | The signal is RDY/-BSY pin. RDY/-BSY pin turns low level during the card internal initialization operation at VCC applied or reset applied, so next access to the card should be after the signal turned high level. | | -IREQ<br>(PC Card I/O mode) | - | | This signal is active low -IREQ pin. The signal of low level indicates that the card is requesting software service to host, and high level indicates that the card is not requesting. | | INTRQ<br>(True IDE mode) | = | | This signal is the active high Interrupt Request to the host. | | -REG<br>(PC Card Memory mode)<br>Attribute memory select | I | 3 | -REG is used during memory cycles to distinguish between task file and attribute memory accesses. High for task file, Low for attribute memory is accessed. | | -REG<br>(PC Card I/O mode) | = | | -REG is constantly low when task file or attribute memory is accessed. | | -REG<br>(True IDE mode) | - | | This input signal is not used and should be connected to VCC. | | Signal name | Direction | Pin No. | Description | |-----------------------------------------------------------|-----------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RESET<br>(PC Card Memory mode) | I | 116 | This signal is active high RESET pin. If this signal is asserted high, the card internal initialization begins to operate. During the card internal initialization RDY/-BSY is low. After the card internal initialization RDY/-BSY is high. | | RESET<br>(PC Card I/O mode) | | | This signal is active high RESET pin. If this signal is asserted high, the card internal initialization begins to operate. In this mode, RDY/-BSY signal can not be used, so using Status Register the Ready/Busy status can be confirmed. | | -RESET<br>(True IDE mode) | _ | | This signal is active low -RESET pin. If this signal is asserted low, all the register's in this card are reset. In this mode, RDY/-BSY signal can not be used, so using status register the Ready/Busy status can be confirmed. | | VCC<br>(PC Card Memory mode)<br>VCC<br>(PC Card I/O mode) | - | 16, 25, 46, 59,<br>76, 87, 106 | +5 V, +3.3 V power. | | VCC<br>(True IDE mode) | - | | | | -WAIT<br>(PC Card Memory mode) | 0 | 117 | This signal is active low -WAIT pin. In this card this signal is constantly high level. | | -WAIT<br>(PC Card I/O mode) | | | | | IORDY<br>(True IDE mode) | - | | This output signal may be used as IORDY. In this card this signal is constantly high impedance. | | -WE<br>(PC Card Memory mode) | I | 112 | -WE is used for the control of writing register's data in attribute memory area or task file area. | | -WE<br>(PC Card I/O mode) | - | | -WE is used for the control of writing register's data in attribute memory area. | | -WE<br>(True IDE mode) | - | | This input signal is not used and should be connected to VCC by the host. | | WP<br>(PC Card Memory mode)<br>Write Protect | 0 | 12 | WP is held low because this card does not have write protect switch. | | -IOIS16<br>(PC Card I/O mode) | - | | -IOIS16 is asserted when task file registers are accessed in 16-bit mode. | | -IOIS16<br>(True IDE mode) | - | | This output signal is asserted low when this device is expecting a word data transfer cycle. Initial mode is 16-bit. If the user issues a Set Feature Command to put the device in Byte access mode, the card permits 8-bit accesses. | ## **Flash Memory Interface Pin Explanation** | Signal name | Direction | Pin No. | Description | |-----------------------------------------|-----------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | F_DA7 to F_DA0,<br>F_DB7 to F_DB0 | I/O | 73, 74, 75, 77,<br>78, 79, 80, 82,<br>29, 30, 31, 32,<br>33, 35, 36, 37 | The Flash bus is F_DA0 to F_DA7 and F_DB0 to F_DB7. This bus is used as command, address and data bus for Flash memory. | | F_CEA10 to F_CEA1,<br>F_CEB10 to F_CEB1 | 0 | 71, 70, 68, 67,<br>66, 65, 64, 63,<br>58, 57, 56, 55,<br>54, 53, 52, 50,<br>49, 44, 43, 42 | Flash chip enable is used to select the Flash memory. | | F_OEA_, F_OEB_ | 0 | 83, 38 | Flash output enable is used to control read data output from the Flash memory. | | F_RDY_1, F_RDY_2 | I | 85, 40 | Flash ready/busy is driven low by Flash memory during program or erase operation. Flash ready/busy becomes high impedance at the completion of the program or erase operation. | | F_WEA_, F_WEB_ | 0 | 72, 26 | Flash write enable is used to strobe command and address. The command and address are latched at the rising edge of the Flash write enable. | | F_SC_A1, F_SC_A2,<br>F_SC_B1, F_SC_B2 | 0 | 60, 61, 27, 28 | Serial clock is used to read memory data and to strobe programming data. The programming data is latched at the rising edge of the Serial clock. | | F_CDEA_, F_CDEB_ | 0 | 84, 39 | Command data enable is used to control the multiplexed Flash bus when Flash write enable is asserted. Command and data are latched when Command data enable is low, and Address is latched when Command data enable is high. | | F_RES_ | 0 | 41 | Flash reset must be kept at $V_{\rm LR}(Vss\pm0.2V)$ while Vcc is turned on and off to prevent Flash memory from unintentional erase or programming. Flash reset must be kept at $V_{\rm HR}(VCC\pm0.2V)$ after VCC becomes stable and while Flash memory is in various operations such as programming, erase and read. | ## Other Pin Explanation | Signal name | Direction | Pin No. | Description | |----------------|--------------|-----------------|------------------------------------------------------------------------| | XIN, XOUT | I/O | 22, 23 | XIN and XOUT are used to connect crystal oscillator. | | PORST_ | I | 18 | This pin is used to connect reset IC for power on reset. | | TEST3 to TEST1 | <del>_</del> | 45, 20, 19 | TEST1 to TEST3 are used for diagnostic test and should be kept at Vcc. | | TEST7 to TEST4 | _ | 115, 86, 47, 17 | TEST4 to TEST7 are used for diagnostic test and should be open. | #### **Card Block Diagram** ### **Controller Block Diagram** Note: The HITACHI Flash controller recover from 2-bit errors of the data field (512-byte) and 1-bit error of control field (16-byte) during read operation. #### Host access specifications #### 1. Attribute access specifications When CIS-ROM region or Configuration register region is accessed, read and write operations are executed under the condition of -REG = "L" as follows. That region can be accessed by Byte/Word/Odd-byte modes which are defined by PC card standard specifications. #### **Attribute Read Access Mode** | Mode | -REG | -CE2 | -CE1 | A0 | -OE | -WE | D8 to D15 | D0 to D7 | |-------------------------|------|------|------|----|-----|-----|-----------|-----------| | Standby mode | × | Н | Н | × | × | × | High-Z | High-Z | | Byte access (8-bit) | L | Н | L | L | L | Н | High-Z | even byte | | | L | Н | L | Н | L | Н | High-Z | invalid | | Word access (16-bit) | L | L | L | × | L | Н | invalid | even byte | | Odd byte access (8-bit) | L | L | Н | × | L | Н | invalid | High-Z | Note: x: L or H #### **Attribute Write Access Mode** | Mode | -REG | -CE2 | -CE1 | A0 | -OE | -WE | D8 to D15 | D0 to D7 | |-------------------------|------|------|------|----|-----|-----|------------|------------| | Standby mode | × | Н | Н | × | × | × | Don't care | Don't care | | Byte access (8-bit) | L | Н | L | L | Н | L | Don't care | even byte | | | L | Н | L | Н | Н | L | Don't care | Don't care | | Word access (16-bit) | L | L | L | × | Н | L | Don't care | even byte | | Odd byte access (8-bit) | L | L | Н | × | Н | L | Don't care | Don't care | Note: x: L or H #### **Attribute Access Timing Example** #### 2. Task File register access specifications There are two cases of Task File register mapping, one is mapped I/O address area, the other is mapped Memory address area. Each case of Task File register read and write operations are executed under the condition as follows. That area can be accessed by Byte/Word/Odd Byte mode which are defined by PC card standard specifications. #### (1) I/O address map #### Task File Register Read Access Mode (1) | Mode | -REG | -CE2 | -CE1 | A0 | -IORD | -IOWR | -OE | -WE | D8 to D15 | D0 to D7 | |-------------------------|------|------|------|----|-------|-------|-----|-----|-----------|-----------| | Standby mode | × | Н | Н | × | × | × | × | × | High-Z | High-Z | | Byte access (8-bit) | L | Н | L | L | L | Н | Н | Н | High-Z | even byte | | | L | Н | L | Н | L | Н | Н | Н | High-Z | odd byte | | Word access (16-bit) | L | L | L | × | L | Н | Н | Н | odd byte | even byte | | Odd byte access (8-bit) | L | L | Н | × | L | Н | Н | Н | odd byte | High-Z | Note: x: L or H #### Task File Register Write Access Mode (1) | Mode | -REG | -CE2 | -CE1 | Α0 | -IORD | -IOWR | -OE | -WE | D8 to D15 | D0 to D7 | |-------------------------|------|------|------|----|-------|-------|-----|-----|------------|------------| | Standby mode | × | Н | Н | × | × | × | × | × | Don't care | Don't care | | Byte access (8-bit) | L | Н | L | L | Н | L | Н | Н | Don't care | even byte | | | L | Н | L | Н | Н | L | Н | Н | Don't care | odd byte | | Word access (16-bit) | L | L | L | × | Н | L | Н | Н | odd byte | even byte | | Odd byte access (8-bit) | L | L | Н | × | Н | L | Н | Н | odd byte | Don't care | Note: x: L or H ### **Task File Register Access Timing Example (1)** ### (2) Memory address map ### Task File Register Read Access Mode (2) | Mode | -REG | -CE2 | -CE1 | Α0 | -OE | -WE | -IORD | -IOWR | D8 to D15 | D0 to D7 | |-------------------------|------|------|------|----|-----|-----|-------|-------|-----------|-----------| | Standby mode | × | Н | Н | × | × | × | × | × | High-Z | High-Z | | Byte access (8-bit) | Н | Н | L | L | L | Н | Н | Н | High-Z | even byte | | | Н | Н | L | Н | L | Н | Н | Н | High-Z | odd byte | | Word access (16-bit) | Н | L | L | × | L | Н | Н | Н | odd byte | even byte | | Odd byte access (8-bit) | Н | L | Н | × | L | Н | Н | Н | odd byte | High-Z | Note: x: L or H ### Task File Register Write Access Mode (2) | Mode | -REG | -CE2 | -CE1 | Α0 | -OE | -WE | -IORD | -IOWR | D8 to D15 | D0 to D7 | |-------------------------|------|------|------|----|-----|-----|-------|-------|------------|------------| | Standby mode | × | Н | Н | × | × | × | × | × | Don't care | Don't care | | Byte access (8-bit) | Н | Н | L | L | Н | L | Н | Н | Don't care | even byte | | | Н | Н | L | Н | Н | L | Н | Н | Don't care | odd byte | | Word access (16-bit) | Н | L | L | × | Н | L | Н | Н | odd byte | even byte | | Odd byte access (8-bit) | Н | L | Н | × | Н | L | Н | Н | odd byte | Don't care | Note: x: L or H ### Task File Register Access Timing Example (2) #### 3. True IDE Mode The card can be configured in a True IDE mode of operation. This card is configured in this mode only when the -OE input signal is asserted GND by the host. In this True IDE mode Attribute Registers are not accessible from the host. Only I/O operation to the task file and data register are allowed. If this card is configured during power on sequence, data register are accessed in word (16-bit). The card permits 8-bit accesses if the user issues a Set Feature Command to put the device in 8-bit mode. #### True IDE Mode Read I/O Function | Mode | -CE2 | -CE1 | A0 to A | 2 -IORD | -IOWR | D8 to D15 | D0 to D7 | |-------------------------|------|------|---------|---------|-------|-----------|------------| | Invalid mode | L | L | × | × | × | High-Z | High-Z | | Standby mode | Н | Н | × | × | × | High-Z | High-Z | | Data register access | Н | L | 0 | L | Н | odd byte | even byte | | Alternate status access | L | Н | 6H | L | Н | High-Z | status out | | Other task file access | Н | L | 1-7H | L | Н | High-Z | data | Note: x: L or H #### **True IDE Mode Write I/O Function** | Mode | -CE2 | -CE1 | A0 to A2 | -IORD | -IOWR | D8 to D15 | D0 to D7 | |-------------------------|------|------|----------|-------|-------|------------|------------| | Invalid mode | L | L | × | × | × | don't care | don't care | | Standby mode | Н | Н | × | × | × | don't care | don't care | | Data register access | Н | L | 0 | Н | L | odd byte | even byte | | Control register access | L | Н | 6H | Н | L | don't care | control in | | Other task file access | Н | L | 1-7H | Н | L | don't care | data | Note: x: L or H #### True IDE Mode I/O Access Timing Example #### **Configuration register specifications** This card supports four Configuration registers for the purpose of the configuration and observation of this card. These registers can be used in memory card mode and I/O card mode. In True IDE mode, these registers can not be used. #### 1. Configuration Option register (Address 200H) This register is used for the configuration of the card configuration status and for the issuing soft reset to the card. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |--------|---------|-------|------|------|------|------|------| | SRESET | LevIREQ | INDEX | | | | | | Note: initial value: 00H | Name | R/W | Function | |---------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SRESET<br>(HOST->) | R/W | Setting this bit to "1", places the card in the reset state (Card Hard Reset). This operation is equal to Hard Reset, except this bit is not cleared. Then this bit set to "0", places the card in the reset state of Hard Reset (This bit is set to "0" by Hard Reset). Card configuration status is reset and the card internal initialized operation starts when Card Hard Reset is executed, so next access to the card should be the same sequence as the power on sequence. | | LevIREQ<br>(HOST->) | R/W | This bit sets to "0" when pulse mode interrupt is selected, and "1" when level mode interrupt is selected. | | INDEX<br>(HOST->) | R/W | This bits is used for select operation mode of the card as follows. When Power on, Card Hard Reset and Soft Reset, this data is "000000" for the purpose of Memory card interface recognition. | #### INDEX bit assignment #### **INDEX** bit | 5 | 4 | 3 | 2 | 1 | 0 | Card mode | Task File register address | Mapping mode | |---|---|---|---|---|---|-------------|----------------------------|-----------------------| | 0 | 0 | 0 | 0 | 0 | 0 | Memory card | 0H to FH, 400H to 7FFH | memory mapped | | 0 | 0 | 0 | 0 | 0 | 1 | I/O card | xx0H to xxFH | contiguous I/O mapped | | 0 | 0 | 0 | 0 | 1 | 0 | I/O card | 1F0H to 1F7H, 3F6H to 3F7H | primary I/O mapped | | 0 | 0 | 0 | 0 | 1 | 1 | I/O card | 170H to 177H, 376H to 377H | secondary I/O mapped | ## 2. Configuration and Status register (Address 202H) This register is used for observing the card state. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-------|--------|-------|------|------|------|------|------| | CHGED | SIGCHG | IOIS8 | 0 | 0 | PWD | INTR | 0 | Note: initial value: 00H | Name | R/W | Function | |--------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CHGED<br>(CARD->) | R | This bit indicates that CRDY/-BSY bit on Pin Replacement register is set to "1". When CHGED bit is set to "1", -STSCHG pin is held "L" at the condition of SIGCHG bit set to "1" and the card configured for the I/O interface. | | SIGCHG<br>(HOST->) | R/W | This bit is set or reset by the host for enabling and disabling the status-change signal (-STSCHG pin). When the card is configured I/O card interface and this bit is set to "1", -STSCHG pin is controlled by CHGED bit. If this bit is set to "0", -STSCHG pin is kept "H". | | IOIS8<br>(HOST->) | R/W | The host sets this field to "1" when it can provide I/O cycles only with on 8 bit data bus (D7 to D0). | | PWD<br>(HOST->) | R/W | When this bit is set to "1", the card enters sleep state (Power Down mode). When this bit is reset to "0", the card transfers to idle state (active mode). RRDY/-BSY bit on Pin Replacement Register becomes BUSY when this bit is changed. RRDY/-BSY will not become Ready until the power state requested has been entered. This card automatically powers down when it is idle, and powers back up when it receives a command. | | INTR<br>(CARD->) | R | This bit indicates the internal state of the interrupt request. This bit state is available whether I/O card interface has been configured or not. This signal remains true until the condition which caused the interrupt request has been serviced. If interrupts are disabled by the -IEN bit in the Device Control Register, this bit is a zero. | #### 3. Pin Replacement register (Address 204H) This register is used for providing the signal state of -IREQ signal when the card configured I/O card interface. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|-----------|------|------|------|-----------|------| | 0 | 0 | CRDY/-BSY | 0 | 1 | 1 | RRDY/-BSY | 0 | Note: initial value: 0CH | Name | R/W | Function | |-----------------------|-----|------------------------------------------------------------------------------------------------------------| | CRDY/-BSY<br>(HOST->) | R/W | This bit is set to "1" when the RRDY/-BSY bit changes state. This bit may also be written by the host. | | RRDY/-BSY<br>(HOST->) | R/W | When read, this bit indicates +READY pin states. When written, this bit is used for CRDY/-BSY bit masking. | ### 4. Socket and Copy register (Address 206H) This register is used for identification of the card from the other cards. Host can read and write this register. This register should be set by host before this card's Configuration Option register set. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|------|------|------|------|------|------| | 0 | 0 | 0 | DRV# | 0 | 0 | 0 | 0 | Note: initial value: 00H | DRV# R/W This fields are used for the configuration of the plural cards. When host co | | |---------------------------------------------------------------------------------------------------------------------------------|---| | (HOST->) Plural cards, written the card's copy number in this field. In this way, host of the card's master/slave organization. | 3 | ### **CIS** informations After the assembled Flash card, CIS information should be programmed into the Flash. For example, CIS information of HITACHI's Flash card is defined as follows. | Address | Data | 7 | 6 | 5 4 | . 3 | 3 2 | 2 ′ | 1 | 0 | Description of contents | CIS function | |---------|------|------------------|-------|------------------|--------|-----|-----------------|------|-------|-------------------------------------------------------------------------------|-------------------------------------| | 000H | 01H | CIST | PL_ | DEV | ICE | | | | | Device info tuple | Tuple code | | 002H | 04H | TPL_ | LIN | IK | | | | | | Link length is 4 byte | Link to next tuple | | 004H | DFH | Devi | ce ty | ype | V<br>F | ) | Dev | rice | speed | Device type = DH: I/O device<br>WPS = 1: No WP<br>Device speed = 7: ext speed | Device type, WPS, speed | | 006H | 4AH | EXT | | eed<br>Intissa | a | | Spe<br>exp | | | 400 ns if no wait | Extended speed | | H800 | 01H | 1x | | | | : | 2k u | ınit | S | 2k byte of address space | Device size | | 00AH | FFH | List 6 | end | mark | er | | | | | End of device | END marker | | 00CH | 1CH | CISTPL_DEVICE_OC | | | | | | | | Other conditions device info tuple | Tuple code | | 00EH | 04H | TPL_ | LIN | IK | | | | | | Link length is 4 bytes | Link to next tuple | | 010H | 02H | EXT | Re | serve | d | , | V <sub>cc</sub> | | MWAIT | 3 V, wait is not used | Other conditions info field | | 012H | D9H | Devi | ce ty | ype | V<br>F | ) | Dev | ice | speed | Device type = DH: I/O device<br>WPS = 1: No WP<br>Device speed = 1: 250 ns | Device type, WPS, speed | | 014H | 01H | 1x | | | | : | 2k u | ınit | S | 2k byte of address space | Device size | | 016H | FFH | List 6 | end | mark | er | | | | | End of device | END marker | | 018H | 18H | CIST | PL_ | _JEDI | EC_ | _C | | | | JEDEC ID common memory | Tuple code | | 01AH | 02H | TPL_ | LIN | IK | | | | | | Link length is 2 bytes | Link to next tuple | | 01CH | DFH | PCM<br>ID co | | 's ma | nuf | act | urei | r's | JEDEC | Manufacturer's ID code | JEDEC ID of PC Card ATA | | 01EH | 01H | PCM | ICIA | JED | EC | de | vice | CC | ode | 2nd byte of JEDEC ID | | | 020H | 20H | CIST | PL_ | _MAN | FIC | ) | | | | Manufacturer's ID code | Tuple code | | 022H | 04H | TPL_ | LIN | IK | | | | | | Link length is 4 bytes | Link to next tuple | | 024H | 07H | | - | e of P<br>turer | | | | | | HITACHI JEDEC manufacturer's ID | Low byte of manufacturer's ID code | | 026H | 00H | _ | • | e of P<br>turer' | | | | | | Code of 0 because other byte is JEDEC 1 byte manufacture's ID | High byte of manufacturer's ID code | | 028H | 00H | Low | byte | of p | odu | uct | cod | le | | HITACHI code for PC CARD<br>ATA | Low byte of product code | | 02AH | 00H | High | byt | e of p | rod | uct | coc | de | | - | High byte of product code | | Address Da | ta 7 6 5 4 3 2 1 0 | Description of contents | CIS function | |------------|-------------------------|------------------------------------------------------------|----------------------------| | 02CH 15I | H CISTPL_VERS_1 | Level 1 version/product info | Tuple code | | 02EH 15I | H TPL_LINK | Link length is 15h bytes | Link to next tuple | | 030H 04I | H TPPLV1_MAJOR | PCMCIA2.0/JEIDA4.1 | Major version | | 032H 01I | H TPPLV1_MINOR | PCMCIA2.0/JEIDA4.1 | Minor version | | 034H 48I | Н | 'H' | Info string 1 | | 036H 49I | Н | 11' | - | | 038H 54I | Н | 'T' | - | | 03AH 41I | Н | ' А ' | - | | 03CH 43I | Н | , С , | - | | 03EH 48I | Н | 'H' | - | | 040H 49I | Н | 11' | - | | 042H 00I | Н | Null terminator | - | | 044H 46I | Н | 'F' | Info string 2 | | 046H 4C | Н | 'L' | - | | 048H 41I | Н | ' А ' | - | | 04AH 53I | Н | 'S' | - | | 04CH 48I | Н | 'H' | - | | 04EH 00I | Н | Null terminator | - | | 050H 34I | Н | ' <b>4</b> ' | Vender specific strings | | 052H 2E | Н | . , | - | | 054H 30I | Н | ' 0 ' | - | | 056H 00I | Н | Null terminator | - | | 058H FF | H List end marker | End of device | END marker | | 05AH 21I | H CISTPL_FUNCID | Function ID tuple | Tuple code | | 05CH 02I | H TPL_LINK | Link length is 2 bytes | Link to next tuple | | 05EH 04I | H TPLFID_FUNCTION = 04H | Disk function, may be silicon, may be removable | PC card function code | | 060H 01I | H Reserved R P | R = 0: No BIOS ROM<br>P = 1: Configure card at<br>power on | System initialization byte | | Address | Data | 7 6 5 4 3 2 1 0 | Description of contents | CIS function | |---------|------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | 062H | 22H | CISTPL_FUNCE | Function extension tuple | Tuple code | | 064H | 02H | TPL_LINK | Link length is 2 bytes | Link to next tuple | | 066H | 01H | Disk function extension tuple type | Disk interface type | Extension tuple type for disk | | 068H | 01H | Disk interface type | PC card ATA interface | Interface type | | 06AH | 22H | CISTPL_FUNCE | Function extension tuple | Tuple code | | 06CH | 03H | TPL_LINK | Link length is 3 bytes | Link to next tuple | | 06EH | 02H | Disk function extension tuple type | Single drive | Extension tuple type for disk | | 070H | 0CH | Reserved D U S V | No $V_{PP}$ , silicon, single drive $V = 0$ : No $V_{PP}$ required $S = 1$ : Silicon $U = 1$ : Unique serial # $D = 0$ : Single drive on card | Basic ATA option parameters byte 1 | | 072H | 0FH | R I E N P3 P2 P1 P0 | P0: Sleep mode supported P1: Standby mode supported P2: Idle mode suppported P3: Drive auto power control N: Some config excludes 3X7 E: Index bit is emulated I: Twin IOIS16# data reg only R: Reserved | Basic ATA option parameters byte 2 | | 074H | 1AH | CISTPL_CONFIG | Configuration tuple | Tuple code | | 076H | 05H | TPL_LINK | Link length is 5 bytes | Link to next tuple | | 078H | 01H | RFS RMS RAS | RFS: Reserved RMS: TPCC_RMSK size - 1 = 0 RAS: TPCC_RADR size - 1 = 1 1 byte register mask 2 byte config base address | Size of fields byte TPCC_SZ | | 07AH | 03H | TPCC_LAST | Entry with config index of 03H is final entry in table | Last entry of config registers | | | | TPCC_RADR (LSB) | Configuration registers are located at 200H in REG space | Location of config registers | | 07EH | 02H | TPCC_RADR (MSB) | | | | 080H | 0FH | Reserved S P C I | I: Configuration index C: Configuration and status P: Pin replacement S: Socket and copy | Configuration registers present mask TPCC_RMSK | | Address | Data | 7 6 5 4 3 2 1 0 | Description of contents | CIS function | |---------|------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | 082H | 1BH | CISTPL_CFTABLE_ENTRY | Configuration table entry tuple | Tuple code | | 084H | 08H | TPL_LINK | Link length is 8 bytes | Link to next tuple | | 086H | C0H | I D Configuration index | Memory mapped I/O configuration I = 1: Interface byte follows D = 1: Default entry Configuration index = 0 | Configuration table index byte TPCE_INDX | | 088H | 40H | W R P B Interface type | W = 0: Wait not used R = 1: Ready active P = 0: WP used B = 0: BVD1 and BVD2 not used IF type = 0: Memory interface | Interface description field TPCE_IF | | 08AH | A1H | M MS IR IO T P | M = 1: Misc info present MS = 01: Memory space info single 2-byte length IR = 0: No interrupt info present IO = 0: No I/O port info present T = 0: No timing info present P = 1: V <sub>cc</sub> only info | Feature selection byte TPCE_FS | | 08CH | 01H | R DIPIAISIHVLVNV | Nominal voltage only follows R: Reserved DI: Power down current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 08EH | 55H | X Mantissa Exponent | Nominal voltage = 5 V | V <sub>cc</sub> nominal value | | 090H | 08H | Length in 256 bytes pages (LSB) | Length of memory space is 2 kB | Memory space description structures (TPCE_MS) | | 092H | 00H | Length in 256 bytes pages (MSB) | _ | | | 094H | 20H | X RPRAT<br>O | X = 0: No more misc fields R: Reserved P = 1: Power down supported RO = 0: Not read only mode A = 0: Audio not supported T = 0: Single drive | Miscellaneous features field TPCE_MI | | Address | s Data | 7 | 6 5 | 4 3 | 2 | 1 0 | Description of contents | CIS function | |---------|--------|------|--------|----------|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 096H | 1BH | CIST | PL_CF | TABLE | _EN | NTRY | Configuration table entry tuple | Tuple code | | 098H | 06H | TPL_ | LINK | | | | Link length is 6 bytes | Link to next tuple | | 09AH | 00H | I | D Co | onfigura | tion | index | Memory mapped I/O configuration I = 0: No Interface byte D = 0: No Default entry Configuration index = 0 | Configuration table index byte TPCE_INDX | | 09CH | 01H | M | MS | IR IO | T | P | M = 0: No Misc info<br>MS = 00: No Memory space<br>info<br>IR = 0: No interrupt info<br>present<br>IO = 0: No I/O port info<br>present<br>T = 0: No timing info present<br>$P = 1$ : $V_{cc}$ only info | Feature selection byte TPCE_FS | | 09EH | 21H | R | DI PI | AI SI | HV | LV NV | Nominal voltage only follows R: Reserved DI: Power down current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 0A0H | В5Н | Х | Mantis | ssa | Ex | oonent | Nominal voltage = 3.0 V | V <sub>cc</sub> nominal value | | 0A2H | 1EH | Х | Exten | sion | | | +0.3 V | Extension byte | | 0A4H | 4DH | Х | Mantis | ssa | Ex | ponent | Max average current over 10 msec is 45 mA | Max. average current | | Address | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Description of contents | CIS function | |---------|------|------|-----|------|-------|------|------|------|-----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | 0A6H | 1BH | CIST | PL_ | CF | ГАВ | LE_ | _ EI | NTF | RY | / | Configuration table entry tuple | Tuple code | | H8A0 | 0AH | TPL_ | LIN | K | | | | | | | Link length is 10 bytes | Link to next tuple | | 0AAH | C1H | I | D | Cor | nfigu | urat | ion | INE | DE | ΣX | Contiguous I/O mapped ATA registers configuration I = 1: Interface byte follows D = 1: Default entry Configuration index = 1 | Configuration table index byte TPCE_INDX | | 0ACH | 41H | W | R | P | В | Inte | erfa | ce t | typ | oe | W = 0: Wait not used R = 1: Ready active P = 0: WP not used B = 0: BVS1 and BVD2 not used IF type = 1: I/O interface | Interface description field TPCE_IF | | OAEH | 99H | M | MS | 1 | IR | IO | T | P | | | M = 1: Misc info present MS = 00: No memory space info IR = 1: Interrupt info present IO = 1: I/O port info present T = 0: No timing info present P = 1: V <sub>cc</sub> only info | Feature selection byte TPCE_FS | | овон | 01H | R | DI | PI | AI | SI | HV | LV | N | IV | Nominal voltage only follows R: Reserved DI: Power down Current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 0B2H | 55H | Χ | Ма | ntis | sa | | Exp | one | er | nt | Nominal voltage = 5 V | V <sub>cc</sub> nominal value | | 0B4H | 64H | R | S | E | IO / | Add | rLir | ne | | | S = 1: 16-bit hosts supported<br>E = 1: 8-bit hosts supported<br>IO AddrLine: 4 lines decoded | I/O space description field TPCE_IO | | ов6Н | F0H | S | P | L | M | V | В | I | N | I | S = 1: Share logic active P = 1: Pulse mode IRQ supported L = 1: Level mode IRQ supported M = 1: Bit mask of IRQs present V = 0: No vender unique IRQ B = 0: No bus error IRQ I = 0: No IO check IRQ N = 0: No NMI | Interrupt request description structure TPCE_IR | | Address | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of contents | CIS function | |---------|------|-----------|--------------|---|--------|--------------|---|---|------|---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | 0B8H | FFH | IRQ<br>7 | IR<br>Q<br>6 | | Q | IR<br>Q<br>3 | | Q | IRQ0 | IRQ level to be routed 0 to 15 recommended | Mask extension byte 1<br>TPCE_IR | | 0BAH | FFH | IRQ<br>15 | Q | Q | Q | | Q | Q | IRQ8 | Recommended routing to any "normal, maskable" IRQ. | Maskextension byte 2<br>TPCE_IR | | 0BCH | 20H | X | R | P | R<br>O | A | T | | | X = 0: Nomore misc fields R: reserved P = 1: Power down supported RO = 0: Not read only mode A = 0: Audio not supported T = 0: Single drive | Miscellaneous features field TPCE_MI | | Address | Data | 7 | 6 5 4 3 | 2 1 | 0 | Description of contents | CIS function | |---------|------|------|-------------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 0BEH | 1BH | CIST | PL_CFTABLE | _ENTF | RY | Configuration table entry tuple | Tuple code | | 0C0H | 06H | TPL_ | _LINK | | | Link length is 6 bytes | Link to next tuple | | 0C2H | 01H | I | D Configura | tion inc | lex | Contiguous I/O mapped ATA registers configuration I = 0: No Interface byte D = 0: No Default entry Configuration index = 1 | Configuration table index byte TPCE_INDX | | 0C4H | 01H | M | MS IR IO | ТР | | M = 0: No Misc info MS = 00: No Memory space info IR = 0: No interrupt info present IO = 0: No I/O port info present T = 0: No timing info present P = 1: V <sub>cc</sub> only info | Feature selection byte TPCE_FS | | 0C6H | 21H | R | DI PI AI SI | HV LV | NV | Nominal voltage only follows R: Reserved DI: Power down current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 0C8H | В5Н | Χ | Mantissa | Expon | ent | Nominal voltage = 3.0 V | V <sub>cc</sub> nominal value | | 0CAH | 1EH | Χ | Extension | | | +0.3 V | Extension byte | | 0CCH | 4DH | X | Mantissa | Expon | ent | Max average current over 10 msec is 45 mA | Max. average current | | Address | S Data | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 | Description of contents | CIS function | |---------|--------|------|-----|-------|-------|-------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | 0CEH | 1BH | CIST | PL_ | _CF1 | ΓAΒΙ | E_E | NTR | Υ | Configuration table entry tuple | Tuple code | | 0D0H | 0FH | TPL_ | LIN | IK | | | | | Link length is 15 bytes | Link to next tuple | | 0D2H | C2H | I | D | Con | nfigu | ratio | n INC | DEX | ATA primary I/O mapped configuration I = 1: Interface byte follow D = 1: default entry follows Configuration index = 2 | | | 0D4H | 41H | W | R | P | ВІ | nterf | ace t | ype | W = 0: Wait not used R = 1: Ready active P = 0: WP not used B = 0: BVS1 and BVD2 not used IF type = 1: I/O interface | Interface description field TPCE_IF ot | | 0D6H | 99H | M | MS | 3 | IR I | ОТ | P | | M = 1: misc info present MS = 00: No memory space info IR = 1: Interrupt info prese IO = 1: I/O port info prese T = 0: No timing info prese P = 1: $V_{cc}$ only info | ent<br>ent | | 0D8H | 01H | R | DI | PI . | AI S | SI H | V LV | NV | Nominal voltage only follow R: Reserved DI: Power down Current in PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | ws Power parameters for $V_{cc}$ | | 0DAH | 55H | Х | Ma | ntiss | sa | Е | xpon | ent | Nominal voltage = 5 V | V <sub>cc</sub> nominal value | | 0DCH | EAH | R | S | E | IO A | .ddrL | ine | | R = 1: Range follows S = 1: 16-bit hosts support E = 1: 8-bit hosts support IO AddrLines: 10 lines decoded | | | 0DEH | 61H | LS | | AS | ١ | N rar | ige | | LS = 1: Size of lengths is byte AS = 2: Size of address is bytes N Range = 1: Address range | s 2 | | Address | s Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of contents | CIS function | |---------|--------|---|---|---|--------|----|------|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | 0E0H | F0H | | | | | | | | | 1st I/O base address (LSB) | 1st I/O range address | | 0E2H | 01H | | | | | | | | | 1st I/O base address (MSB) | _ | | 0E4H | 07H | | | | | | | | | 1st I/O length - 1 | 1st I/O range length | | 0E6H | F6H | | | | | | | | | 2nd I/O base address (LSB) | 2nd I/O range address | | 0E8H | 03H | | | | | | | | | 2nd I/O base address (MSB) | - | | 0EAH | 01H | | | | | | | | | 2nd I/O length - 1 | 2nd I/O range length | | 0ECH | EEH | S | P | L | M | IR | Q le | vel | | S = 1: Share logic active P = 1: Pulse mode IRQ supported L = 1: Level mode IRQ supported M = 0: Bit mask of IRQs present IRQ level is IRQ14 | Interrupt request description structure TPCE_IR | | OEEH | 20H | X | R | P | R<br>O | A | Т | | | X = 0: Nomore misc fields R: reserved P = 1: Power down supported RO = 0: Not read only mode A = 0: Audio not supported T = 0: Single drive | Miscellaneous features field TPCE_MI | | Address | s Data | 7 | 6 5 4 3 | 2 1 0 | Description of contents | CIS function | |---------|--------|------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 0F0H | 1BH | CIST | PL_CFTABLE | _ENTRY | Configuration table entry tuple | Tuple code | | 0F2H | 06H | TPL_ | LINK | | Link length is 6 bytes | Link to next tuple | | 0F4H | 02H | I | D Configura | ition index | ATA primary I/O mapped configuration I = 0: No Interface byte D = 0: No Default entry Configuration index = 2 | Configuration table index byte TPCE_INDX | | 0F6H | 01H | M | MS IR IO | ТР | $M=0$ : No Misc info $MS=00$ : No Memory space info $IR=0$ : No interrupt info present $IO=0$ : No I/O port info present $T=0$ : No timing info present $P=1$ : $V_{cc}$ only info | Feature selection byte TPCE_FS | | 0F8H | 21H | R | DI PI AI SI | HV LV NV | Nominal voltage only follows R: Reserved DI: Power down current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 0FAH | В5Н | Х | Mantissa | Exponent | Nominal voltage = 3.0 V | V <sub>cc</sub> nominal value | | 0FCH | 1EH | Χ | Extension | | +0.3 V | Extension byte | | 0FEH | 4DH | X | Mantissa | Exponent | Max average current over 10 msec is 45 mA | Max. average current | | Address | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of contents | CIS function | |---------|------|------|-----|------|------|------|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 100H | 1BH | CIST | PL_ | _CF | TAE | BLE. | _EN | NTR | Y | Configuration table entry tuple | Tuple code | | 102H | 0FH | TPL_ | LIN | IK | | | | | | Link length is 15 bytes | Link to next tuple | | 104H | СЗН | I | D | Co | nfig | urat | ion | INC | DEX | ATA secondary I/O mapped configuration I = 1: Interface byte follows D = 1: default entry Configuration index = 3 | Configuration table index byte TPCE_INDX | | 106H | 41H | W | R | Р | В | Inte | erfa | ce ty | ype | W = 0: Wait not used R = 1: Ready active P = 0: WP not used B = 0: BVS1 and BVD2 not used IF type = 1: I/O interface | Interface description field TPCE_IF | | 108H | 99H | M | MS | 3 | IR | Ю | Т | P | | M = 1: misc info present MS = 00: No memory space info IR = 1: Interrupt info present IO = 1: I/O port info present T = 0: No timing info present P = 1: V <sub>cc</sub> only info | Feature selection byte TPCE_FS | | 10AH | 01H | R | DI | PI | AI | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Power down Current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 10CH | 55H | Х | Ма | ntis | sa | | Ex | oone | ent | Nominal voltage = 5 V | V <sub>cc</sub> nominal value | | 10EH | EAH | R | S | E | IO. | Add | IrLir | ne | | R = 1: Range follows S = 1: 16-bit hosts supported E = 1: 8-bit hosts supported IO AddrLines: 10 lines decoded | I/O space description field<br>TPCE_IO | | 110H | 61H | LS | | AS | | N ra | ang | е | | LS = 1: Size of lengths is 1<br>byte<br>AS = 2: Size of address is 2<br>bytes<br>N Range = 1: Address range - 1 | I/O range format description | | Address | s Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of contents | CIS function | |---------|--------|---|---|---|--------|----|------|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | 112H | 70H | | | | | | | | | 1st I/O base address (LSB) | 1st I/O range address | | 114H | 01H | | | | | | | | | 1st I/O base address (MSB) | _ | | 116H | 07H | | | | | | | | | 1st I/O length - 1 | 1st I/O range length | | 118H | 76H | | | | | | | | | 2nd I/O base address (LSB) | 2nd I/O range address | | 11AH | 03H | | | | | | | | | 2nd I/O base address (MSB) | _ | | 11CH | 01H | | | | | | | | | 2nd I/O length - 1 | 2nd I/O range length | | 11EH | EEH | S | P | L | M | IR | Q le | vel | | S = 1: Share logic active P = 1: Pulse mode IRQ supported L = 1: Level mode IRQ supported M = 0: Bit mask of IRQs present IRQ level is IRQ14 | Interrupt request description structure TPCE_IR | | 120H | 20H | X | R | P | R<br>O | Α | Т | | | X = 0: Nomore misc fields R: reserved P = 1: Power down supported RO = 0: Not read only mode A = 0: Audio not supported T = 0: Single drive | Miscellaneous features field TPCE_MI | | Address | Data | 7 | 6 5 4 3 | 2 1 0 | Description of contents | CIS function | |---------|------|------|-------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 122H | 1BH | CIST | PL_CFTABLE | _ENTRY | Configuration table entry tuple | Tuple code | | 124H | 06H | TPL_ | LINK | | Link length is 6 bytes | Link to next tuple | | 126H | 03H | I | D Configura | tion index | ATA secondary I/O mapped configuration I = 0: No Interface byte D = 0: No Default entry Configuration index = 3 | Configuration table index byte TPCE_INDX | | 128H | 01H | M | MS IR IO | T P | M = 0: No Misc info MS = 00: No Memory space info IR = 0: No interrupt info present IO = 0: No I/O port info present T = 0: No timing info present P = 1: V <sub>cc</sub> only info | Feature selection byte TPCE_FS | | 12AH | 21H | R | DI PI AI SI | HV LV NV | Nominal voltage only follows R: Reserved DI: Power down current info PI: Peak current info AI: Average current info SI: Static current info HV: Max voltage info LV: Min voltage info NV: Nominal voltage info | Power parameters for V <sub>cc</sub> | | 12CH | В5Н | Χ | Mantissa | Exponent | Nominal voltage = 3.0 V | V <sub>cc</sub> nominal value | | 12EH | 1EH | Χ | Extension | | +0.3 V | Extension byte | | 130H | 4DH | X | Mantissa | Exponent | Max average current over 10 msec is 45 mA | Max. average current | | 132H | 14H | CIST | PL_NO_LINK | | No link control tuple | Tuple code | | 134H | 00H | | | | Link is 0 bytes | Link to next tuple | | 136H | FFH | CIST | PL_END | | End of list tuple | Tuple code | ### Task File register specification These registers are used for reading and writing the storage data in this card. These registers are mapped five types by the configuration of INDEX in Configuration Option register. The decoded addresses are shown as follows. #### Memory map (INDEX = 0) | -REG | A10 | A9 to A | 4 A3 | A2 | <b>A1</b> | A0 | Offset | -OE = L | -WE = L | |------|-----|---------|------|----|-----------|----|--------|-------------------------|-------------------------| | 1 | 0 | × | 0 | 0 | 0 | 0 | 0H | Data register | Data register | | 1 | 0 | × | 0 | 0 | 0 | 1 | 1H | Error register | Feature register | | 1 | 0 | × | 0 | 0 | 1 | 0 | 2H | Sector count register | Sector count register | | 1 | 0 | × | 0 | 0 | 1 | 1 | 3H | Sector number register | Sector number register | | 1 | 0 | × | 0 | 1 | 0 | 0 | 4H | Cylinder low register | Cylinder low register | | 1 | 0 | × | 0 | 1 | 0 | 1 | 5H | Cylinder high register | Cylinder high register | | 1 | 0 | × | 0 | 1 | 1 | 0 | 6H | Drive head register | Drive head register | | 1 | 0 | × | 0 | 1 | 1 | 1 | 7H | Status register | Command register | | 1 | 0 | × | 1 | 0 | 0 | 0 | 8H | Dup. even data register | Dup. even data register | | 1 | 0 | × | 1 | 0 | 0 | 1 | 9H | Dup. odd data register | Dup. odd data register | | 1 | 0 | × | 1 | 1 | 0 | 1 | DH | Dup. error register | Dup. feature register | | 1 | 0 | × | 1 | 1 | 1 | 0 | EH | Alt. status register | Device control register | | 1 | 0 | × | 1 | 1 | 1 | 1 | FH | Drive address register | Reserved | | 1 | 1 | × | × | × | × | 0 | 8H | Even data register | Even data register | | 1 | 1 | × | × | × | × | 1 | 9H | Odd data register | Odd data register | ### **Contiguous I/O map (INDEX = 1)** | -REG | A10 to A4 | A3 | A2 | <b>A</b> 1 | A0 | Offset | -IORD = L | -IOWR = L | |------|-----------|----|----|------------|----|--------|-------------------------|-------------------------| | 0 | × | 0 | 0 | 0 | 0 | 0H | Data register | Data register | | 0 | × | 0 | 0 | 0 | 1 | 1H | Error register | Feature register | | 0 | × | 0 | 0 | 1 | 0 | 2H | Sector count register | Sector count register | | 0 | × | 0 | 0 | 1 | 1 | 3H | Sector number register | Sector number register | | 0 | × | 0 | 1 | 0 | 0 | 4H | Cylinder low register | Cylinder low register | | 0 | × | 0 | 1 | 0 | 1 | 5H | Cylinder high register | Cylinder high register | | 0 | × | 0 | 1 | 1 | 0 | 6H | Drive head register | Drive head register | | 0 | × | 0 | 1 | 1 | 1 | 7H | Status register | Command register | | 0 | × | 1 | 0 | 0 | 0 | 8H | Dup. even data register | Dup. even data register | | 0 | × | 1 | 0 | 0 | 1 | 9H | Dup. odd data register | Dup. odd data register | | 0 | × | 1 | 1 | 0 | 1 | DH | Dup. error register | Dup. feature register | | 0 | × | 1 | 1 | 1 | 0 | EH | Alt. status register | Device control register | | 0 | × | 1 | 1 | 1 | 1 | FH | Drive address register | Reserved | ### Primary I/O map (INDEX = 2) | -REG | A10 | A9 to A4 | А3 | A2 | <b>A1</b> | Α0 | -IORD = L | -IOWR = L | |------|-----|----------|----|----|-----------|----|------------------------|-------------------------| | 0 | × | 1FH | 0 | 0 | 0 | 0 | Data register | Data register | | 0 | × | 1FH | 0 | 0 | 0 | 1 | Error register | Feature register | | 0 | × | 1FH | 0 | 0 | 1 | 0 | Sector count register | Sector count register | | 0 | × | 1FH | 0 | 0 | 1 | 1 | Sector number register | Sector number register | | 0 | × | 1FH | 0 | 1 | 0 | 0 | Cylinder low register | Cylinder low register | | 0 | × | 1FH | 0 | 1 | 0 | 1 | Cylinder high register | Cylinder high register | | 0 | × | 1FH | 0 | 1 | 1 | 0 | Drive head register | Drive head register | | 0 | × | 1FH | 0 | 1 | 1 | 1 | Status register | Command register | | 0 | × | 3FH | 0 | 1 | 1 | 0 | Alt. status register | Device control register | | 0 | × | 3FH | 0 | 1 | 1 | 1 | Drive address register | Reserved | ### Secondary I/O map (INDEX = 3) | -REG | A10 | A9 to A4 | <b>A3</b> | <b>A2</b> | <b>A</b> 1 | A0 | -IORD = L | -IOWR = L | |------|-----|----------|-----------|-----------|------------|----|------------------------|-------------------------| | 0 | × | 17H | 0 | 0 | 0 | 0 | Data register | Data register | | 0 | × | 17H | 0 | 0 | 0 | 1 | Error register | Feature register | | 0 | × | 17H | 0 | 0 | 1 | 0 | Sector count register | Sector count register | | 0 | × | 17H | 0 | 0 | 1 | 1 | Sector number register | Sector number register | | 0 | × | 17H | 0 | 1 | 0 | 0 | Cylinder low register | Cylinder low register | | 0 | × | 17H | 0 | 1 | 0 | 1 | Cylinder high register | Cylinder high register | | 0 | × | 17H | 0 | 1 | 1 | 0 | Drive head register | Drive head register | | 0 | × | 17H | 0 | 1 | 1 | 1 | Status register | Command register | | 0 | × | 37H | 0 | 1 | 1 | 0 | Alt. status register | Device control register | | 0 | × | 37H | 0 | 1 | 1 | 1 | Drive address register | Reserved | ### True IDE Mode I/O map | -CE2 | -CE1 | A2 | <b>A</b> 1 | Α0 | -IORD = L | -IOWR = L | |------|------|----|------------|----|------------------------|-------------------------| | 1 | 0 | 0 | 0 | 0 | Data register | Data register | | 1 | 0 | 0 | 0 | 1 | Error register | Feature register | | 1 | 0 | 0 | 1 | 0 | Sector count register | Sector count register | | 1 | 0 | 0 | 1 | 1 | Sector number register | Sector number register | | 1 | 0 | 1 | 0 | 0 | Cylinder low register | Cylinder low register | | 1 | 0 | 1 | 0 | 1 | Cylinder high register | Cylinder high register | | 1 | 0 | 1 | 1 | 0 | Drive head register | Drive head register | | 1 | 0 | 1 | 1 | 1 | Status register | Command register | | 0 | 1 | 1 | 1 | 0 | Alt. status register | Device control register | | 0 | 1 | 1 | 1 | 1 | Drive address register | Reserved | | | | | | | | | 1. Data register: This register is a 16-bit register that has read/write ability, and it is used for transferring 1 sector data between the card and the host. This register can be accessed in word mode and byte mode. This register overlaps the Error or Feature register. | bit15 bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-------------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------| | | | | | | | D0 t | o D15 | | | | | | | | **2. Error register:** This register is a read only register, and it is used for analyzing the error content at the card accessing. This register is valid when the BSY bit in Status register and Alternate Status register are set to "0" (Ready). | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|------|------|------|------|------|------| | BBK | UNC | "0" | IDNF | "0" | ABRT | "0" | AMNF | | bit | Name | Function | |-----|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | 7 | BBK (Bad BlocK detected) | This bit is set when a Bad Block is detected in requested ID field. | | 6 | UNC (Data ECC error) | This bit is set when Uncorrectable error is occurred at reading the card. | | 4 | IDNF (ID Not Found) | The requested sector ID is in error or cannot be found. | | 2 | ABRT (ABoRTed command) | This bit is set if the command has been aborted because of the card status condition. (Not ready, Write fault, Invalid command, etc.) | | 0 | AMNF (Address Mark Not Found) | This bit is set in case of a general error. | **3. Feature register:** This register is write only register, and provides information regarding features of the drive which the host wishes to utilize. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|--------------|------|------|------|------|------|------| | | Feature byte | | | | | | | **4. Sector count register:** This register contains the numbers of sectors of data requested to be transferred on a read or write operation between the host and the card. If the value of this register is zero, a count of 256 sectors is specified. In plural sector transfer, if not successfully completed, the register contains the number of sectors which need to be transferred in order to complete the request. This register's initial value is "01H". | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-------------------|------|------|------|------|------|------|------| | Sector count byte | | | | | | | | **5. Sector number register:** This register contains the starting sector number which is started by following sector transfer command. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | |--------------------|------|------|------|------|------|------|------|--| | Sector number byte | | | | | | | | | **6. Cylinder low register:** This register contains the low 8-bit of the starting cylinder address which is started by following sector transfer command. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-------------------|------|------|------|------|------|------|------| | Cylinder low byte | | | | | | | | **7. Cylinder high register:** This register contains the high 8-bit of the starting cylinder address which is started by following sector transfer command. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | | |--------------------|------|------|------|------|------|------|------|--| | Cylinder high byte | | | | | | | | | **8. Drive head register:** This register is used for selecting the Drive number and Head number for the following command. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|------|------|-----------|------|------|------| | 1 | LBA | 1 | DRV | Head numb | er | • | | | bit | Name | Function | |--------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | 1 | This bit is set to "1". | | 6 | LBA | LBA is a flag to select either Cylinder / Head / Sector (CHS) or Logical Block Address (LBA) mode. When LBA=0, CHS mode is selected. When LBA=1, LBA mode is selected. In LBA mode, the Logical Block Address is interrupted as follows: LBA07-LBA00: Sector Number Register D7-D0. LBA15-LBA08: Cylinder Low Register D7-D0. LBA23-LBA16: Cylinder High Register D7-D0. LBA27-LBA24: Drive / Head Register bits HS3-HS0. | | 5 | 1 | This bit is set to "1". | | 4 | DRV (DRiVe select) | This bit is used for selecting the Master (Card 0) and Slave (Card 1) in Master/Slave organization. The card is set to be Card 0 or 1 by using DRV# of the Socket and Copy register. | | 3 to 0 | Head number | This bit is used for selecting the Head number for the following command. Bit 3 is MSB. | **9. Status register:** This register is read only register, and it indicates the card status of command execution. When this register is read in configured I/O card mode (INDEX = 1, 2, 3) and level interrupt mode, -IREQ is negated. This register should be accessed in byte mode. In word mode, it is recommended that alternate status register may be used as this register. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|------|------|------|------|------|------| | BSY | DRDY | DWF | DSC | DRQ | CORR | IDX | ERR | | bit | Name | Function | |-----|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | BSY (BuSY) | This bit is set when the card internal operation is executing. When this bit is set to "1", other bits in this register are invalid. | | 6 | DRDY (Drive ReaDY) | If this bit and DSC bit are set to "1", the card is capable of receiving the read or write or seek requests. If this bit is set to "0", the card prohibits these requests. | | 5 | DWF (Drive Write Fault) | This bit is set if this card indicates the write fault status. | | 4 | DSC (Drive Seek Complete) | This bit is set when the drive seek complete. | | 3 | DRQ (Data ReQuest) | This bit is set when the information can be transferred between the host and Data register. This bit is cleared when the card receives the other command. | | 2 | CORR (CORRected data) | This bit is set when a correctable data error has been occurred and the data has been corrected. | | 1 | IDX (InDeX) | This bit is always set to "0". | | 0 | ERR (ERRor) | This bit is set when the previous command has ended in some type of error. The error information is set in the other Status register or Error register. This bit is cleared by the next command. | - 10. Alternate status register: This register is the same as Status register in physically, so the bit assignment refers to previous item of Status register. But this register is different from Status register that -IREQ is not negated when data read. - 11. Command register: This register is write only register, and it is used for writing the command at executing the drive operation. The command code written in the command register, after the parameter is written in the Task File during the card is Ready state. | | | Used parameter | | | | | | | |-----------------------------|--------------|----------------|----|----|----|----|----|-----| | Command | Command code | FR | SC | SN | CY | DR | HD | LBA | | Check power mode | E5H or 98H | N | N | N | N | Υ | N | N | | Execute drive diagnostic | 90H | N | N | N | N | Υ | Ν | N | | Erase sector | C0H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Format track | 50H | N | Υ | N | Υ | Υ | Υ | Υ | | Identify Drive | ECH | N | N | N | N | Υ | N | N | | Idle | E3H or 97H | N | Υ | N | N | Υ | N | N | | Idle immediate | E1H or 95H | N | N | N | N | Υ | N | N | | Initialize drive parameters | 91H | N | Υ | N | N | Υ | Υ | N | | Read buffer | E4H | N | N | N | N | Υ | N | N | | Read multiple | C4H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Read long sector | 22H or 23H | N | N | Υ | Υ | Υ | Υ | Υ | | Read sector | 20H or 21H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Read verify sector | 40H or 41H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Recalibrate | 1XH | N | N | N | N | Υ | N | N | | Request sense | 03H | N | N | N | N | Υ | N | N | | Seek | 7XH | N | N | Υ | Υ | Υ | Υ | Υ | | Set features | EFH | Υ | N | N | N | Υ | N | N | | Set multiple mode | C6H | N | Υ | N | N | Υ | N | N | | Set sleep mode | E6H or 99H | N | N | N | N | Υ | N | N | | Stand by | E2H or 96H | N | N | N | N | Υ | N | N | | Stand by immediate | E0H or 94H | N | N | N | N | Υ | N | N | | Translate sector | 87H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Wear level | F5H | N | N | N | N | Υ | Υ | N | | Write buffer | E8H | N | N | N | N | Υ | N | N | | Write long sector | 32H or 33H | N | N | Υ | Υ | Υ | Υ | Υ | | Write multiple | C5H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Write multiple w/o erase | CDH | N | Υ | Υ | Υ | Υ | Υ | Υ | | Write sector | 30H or 31H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Write sector w/o erase | 38H | N | Υ | Υ | Υ | Υ | Υ | Υ | | Write verify | 3CH | N | Υ | Υ | Υ | Υ | Υ | Υ | Note: FR: Feature register SC: Sector Count register SN: Sector Number register CY: Cylinder register DR: DRV bit of Drive Head register HD: Head Number of Drive Head register LBA: Logical Block Address Mode Supported Y: The register contains a valid parameter for this command. N: The register does not contain a valid parameter for this command. **12. Device control register:** This register is write only register, and it is used for controlling the card interrupt request and issuing an ATA soft reset to the card. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|------|------|------|------|------|------| | × | × | × | × | 1 | SRST | nIEN | 0 | | bit | Name | Function | |--------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 to 4 | 1 × | don't care | | 3 | 1 | This bit is set to "1". | | 2 | SRST (Software ReSeT) | This bit is set to "1" in order to force the card to perform Task File Reset operation. This does not change the Card Configuration registers as a Hardware Reset does. The card remains in Reset until this bit is reset to "0". | | 1 | nIEN (Interrupt ENable) | This bit is used for enabling -IREQ. When this bit is set to "0", -IREQ is enabled. When this bit is set to "1", -IREQ is disabled. | | 0 | 0 | This bit is set to "0". | **13. Drive Address register:** This register is read only register, and it is used for confirming the drive status. This register is provides for compatibility with the AT disk drive interface. It is recommended that this register is not mapped into the host's I/O space because of potential conflicts on bit7. | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |------|------|------|------|------|------|------|------| | × | nWTG | nHS3 | nHS2 | nHS1 | nHS0 | nDS1 | nDS0 | | bit | Name | Function | |--------|---------------------------|-------------------------------------------------------------------------------------------| | 7 | × | This bit is unknown | | 6 | nWTG (WriTing Gate) | This bit is unknown | | 5 to 2 | 2 nHS3-0 (Head Select3-0) | These bits is the negative value of Head Select bits (bit 3 to 0) in Drive/Head register. | | 1 | nDS1 (Idrive Select1) | This bit is unknown | | 0 | nDS0 (Idrive Select0) | This bit is unknown | ### **ATA Command specifications** This table summarizes the ATA command set with the paragraphs. Following shows the support commands and command codes which are written in command registers. #### **ATA Command Set** | No. | Command set | Code | FR | sc | SN | CY | DR | HD | LBA | |-----|-----------------------------|------------|----|----|----|----|----|----|-----| | 1 | Check power mode | E5H or 98H | _ | _ | _ | _ | Υ | _ | _ | | 2 | Execute drive diagnostic | 90H | _ | _ | _ | _ | Υ | _ | _ | | 3 | Erase sector(s) | C0H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 4 | Format track | 50H | _ | Υ | _ | Υ | Υ | Υ | Υ | | 5 | Identify Drive | ECH | _ | _ | _ | _ | Υ | _ | _ | | 6 | Idle | E3H or 97H | _ | Υ | _ | _ | Υ | _ | _ | | 7 | Idle immediate | E1H or 95H | _ | _ | _ | _ | Υ | _ | _ | | 8 | Initialize drive parameters | 91H | _ | Υ | _ | _ | Υ | Υ | _ | | 9 | Read buffer | E4H | _ | _ | _ | _ | Υ | _ | _ | | 10 | Read multiple | C4H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 11 | Read long sector | 22H, 23H | _ | _ | Υ | Υ | Υ | Υ | Υ | | 12 | Read sector (s) | 20H, 21H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 13 | Read verify sector (s) | 40H, 41H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 14 | Recalibrate | 1XH | _ | _ | _ | _ | Υ | _ | _ | | 15 | Request sense | 03H | _ | _ | _ | _ | Υ | _ | _ | | 16 | Seek | 7XH | _ | _ | Υ | Υ | Υ | Υ | Υ | | 17 | Set features | EFH | Υ | _ | _ | _ | Υ | _ | _ | | 18 | Set multiple mode | C6H | _ | Υ | _ | _ | Υ | _ | _ | | 19 | Set sleep mode | E6H or 99H | _ | _ | _ | _ | Υ | _ | _ | | 20 | Stand by | E2H or 96H | _ | _ | _ | _ | Υ | _ | _ | | 21 | Stand by immediate | E0H or 94H | _ | _ | _ | _ | Υ | _ | _ | | 22 | Translate sector | 87H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 23 | Wear level | F5H | _ | _ | _ | _ | Υ | Υ | _ | | 24 | Write buffer | E8H | _ | _ | _ | _ | Υ | _ | _ | | 25 | Write long sector | 32H or 33H | _ | _ | Υ | Υ | Υ | Υ | Υ | | 26 | Write multiple | C5H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 27 | Write multiple w/o erase | CDH | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 28 | Write sector | 30H or 31H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 29 | Write sector(s) w/o erase | 38H | _ | Υ | Υ | Υ | Υ | Υ | Υ | | 30 | Write verify | зсн | _ | Υ | Υ | Υ | Υ | Υ | Υ | Note: FR: Feature Register SC: Sector Count register (00H to FFH) SN: Sector Number register (01H to 20H) CY: Cylinder Low/High register (to) DR: Drive bit of Drive/Head register HD: Head No.(0 to 3) of Drive/Head register NH: No. of Heads Y: Set up —: Not set up - 1. Check Power Mode (code: E5H or 98H): This command checks the power mode. - 2. Execute Drive Diagnostic (code: 90H): This command performs the internal diagnostic tests implemented by the Card. - 3. Erase Sector(s) (code: C0H): This command is used to erase data sectors. - 4. Format Track (code: 50H): This command writes the desired head and cylinder of the selected drive. But selected sector data is not exchange. This card excepts a sector buffer of data from the host to follow the command with same protocol as the Write Sector Command. - 5. Identify Drive (code: ECH): This command enables the host to receive parameter information from the Card. #### **Identify Drive Information** | Word address | Default value | Total bytes | Data field type information | |--------------|---------------|-------------|---------------------------------------------------------------| | 0 | 848AH | 2 | General configuration bit-significant information | | 1 | XXXX | 2 | Default number of cylinders | | 2 | 0000H | 2 | Reserved | | 3 | 00XXH | 2 | Default number of heads | | 4 | 0000H | 2 | Number of unformatted bytes per track | | 5 | XXXX | 2 | Number of unformatted bytes per sector | | 6 | XXXX | 2 | Default number of sectors per track | | 7 to 8 | XXXX | 4 | Number of sectors per card (Word7 = MSW, Word8 = LSW) | | 9 | 0000H | 2 | Reserved | | 10 to 19 | XXXX | 20 | Reserved | | 20 | 0002H | 2 | Buffer type (dual ported) | | 21 | 0002H | 2 | Buffer size in 512 byte increments | | 22 | 0004H | 2 | # of ECC bytes passed on Read/Write Long Commands | | 23 to 46 | XXXX | 48 | Firmware revision in ASCII etc. | | 47 | 0001H | 2 | Maximum of 1 sector on Read/Write Multiple command | | 48 | 0000H | 2 | Double Word not supported | | 49 | 0200H | 2 | Capabilities: DMA NOT Supported (bit 8), LBA supported (bit9) | | 50 | 0000H | 2 | Reserved | | 51 | 0100H | 2 | PIO data transfer cycle timing mode 1 | | 52 | 0000H | 2 | DMA data transfer cycle timing mode not Supported | | 53 to 58 | XXXX | 12 | Reserved | | 59 | 010XH | 2 | Multiple sector setting is valid | | 60 to 61 | XXXX | 4 | Total number of sectors addressable in LBA Mode | | 62 to 127 | 0000H | 138 | Reserved | | 128 to 159 | XXXXH | 64 | Reserved vendor unique bytes | | 160 to 255 | 0000H | 192 | Reserved | - 6. Idle (code: E3H or 97H): This command causes the Card to set BSY, enter the Idle mode, clear BSY and generate an interrupt. If sector count is non-zero, the automatic power down mode is enabled. If the sector count is zero, the automatic power down mode is disabled. - 7. Idle Immediate (code: E1H or 95H): This command causes the Card to set BSY, enter the Idle (Read) mode, clear BSY and generate an interrupt. - 8. Initialize Drive Parameters (code: 91H): This command enables the host to set the number of sectors per track and the number of heads per cylinder. - 9. Read Buffer (code: E4H): This command enables the host to read the current contents of the card's sector buffer. - 10. Read Multiple (code: C4H): This command performs similarly to the Read Sectors command. Interrupts are not generated on each sector, but on the transfer of a block which contains the number of sectors defined by a Set Multiple command. - 11. Read Long Sector (code: 22H or 23H): This command performs similarly to the Read Sector(s) command except that it returns 516 bytes of data instead of 512 bytes. - 12. Read Sector(s) (code: 20H, 21H): This command reads from 1 to 256 sectors as specified in the Sector Count register. A sector count of 0 requests 256 sectors. The transfer begins at the sector specified in the Sector Number register. - 13. Read Verify Sector(s) (code: 40H or 41H): This command is identical to the Read Sectors command, except that DRQ is never set and no data is transferred to the host. - 14. Recalibrate (code: 1XH): This command is effectively a NOP command to the Card and is provided for compatibility purposes. - 15. Request Sense (code: 03H): This command requests an extended error code after command ends with an error. - 16. Seek (code: 7XH): This command is effectively a NOP command to the Card although it does perform a range check. - 17. Set Features (code: EFH): This command is used by the host to establish or select certain features. | Feature | Operation | | | | |--------------------------------------------------------------------------|-----------------------------------------------------------------------|--|--|--| | 01H | Enable 8-bit data transfers. | | | | | 55H | Disable Read Look Ahead. | | | | | 66H | Disable Power on Reset (POR) establishment of defaults at Soft Reset. | | | | | 81H | Disable 8-bit data transfers. | | | | | BBH 4 bytes of data apply on Read/Write Long commands. | | | | | | CCH Enable Power on Reset (POR) establishment of defaults at Soft Reset. | | | | | - 18. Set Multiple Mode (code: C6H): This command enables the Card to perform Read and Write Multiple operations and establishes the block count for these commands. - 19. Set Sleep Mode (code: E6H or 99H): This command causes the Card to set BSY, enter the Sleep mode, clear BSY and generate an interrupt. - 20. Stand By (code: E2H or 96H): This command causes the Card to set BSY, enter the Sleep mode (which corresponds to the ATA "Standby" Mode), clear BSY and return the interrupt immediately. - 21. Stand By Immediate (code: E0H or 94H): This command causes the Card to set BSY, enter the Sleep mode(which corresponds to the ATA "Standby" Mode), clear BSY and return the interrupt immediately. - 22. Translate Sector (code: 87H): This command allows the host a method of determining the exact number of times a user sector has been erased and programmed. - 23. Wear Level (code: F5H): This command effectively a NOP command and only implemented for backward compatibility. The Sector Count Register will always be returned with an 00H indicating Wear Level is not needed. - 24. Write Buffer (code: E8H): This command enables the host to overwrite contents of the Card's sector buffer with any data pattern desired. - 25. Write Long Sector (code: 32H or 33H): This command is provided for compatibility purposes and is similar to the Write Sector(s) command except that it writes 516 bytes instead of 512 bytes. - 26. Write Multiple (code: C5H): This command is similar to the Write Sectors command. Interrupts are not presented on each sector, but on the transfer of a block which contains the number of sectors defined by Set Multiple command. - 27. Write Multiple without Erase (code: CDH): This command is similar to the Write Multiple command with the exception that an implied erase before write operation is not performed. - 28. Write Sector(s) (code: 30H or 31H): This command writes from 1 to 256 sectors as specified in the Sector Count register. A sector count of zero requests 256 sectors. The transfer begins at the sector specified in the Sector Number register. - 29. Write Sector(s) without Erase (code: 38H): This command is similar to the Write Sector(s) command with the exception that an implied erase before write operation is not performed. - 30. Write Verify (code: 3CH): This command is similar to the Write Sector(s) command, except each sector is verified immediately after being written. #### **Sector Transfer Protocol** 1. Sector read: 1 sector read procedure after the card configured I/O interface is shown as follows. 2. Sector write: 1 sector write procedure after the card configured I/O interface is shown as follows. ## **Absolute Maximum Ratings** | Parameter | Symbol | Value | Unit | Note | |-----------------------------|-----------------|--------------------------|------|------| | All input/output voltages | Vin, Vout | $-0.3$ to $V_{cc}$ + 0.3 | V | 1 | | V <sub>cc</sub> voltage | V <sub>cc</sub> | -0.3 to +6.7 | V | | | Operating temperature range | Topr | -40 to +85 | •C | | | Storage temperature range | Tstg | -55 to +125 | •C | | Note: 1. Vin, Vout min = -2.0 V for pulse width • 20 ns. # **Recommended Operating Conditions** | Parameter | Symbol | Min | Тур | Max | Unit | | |-------------------------|-----------------|------|-----|------|------|--| | Operating temperature | Та | 0 | 25 | 70 | •C | | | V <sub>cc</sub> voltage | V <sub>cc</sub> | 4.5 | 5.0 | 5.5 | V | | | | | 3.15 | 3.3 | 3.45 | V | | # **Capacitance** ( $Ta = 25^{\circ}C$ , f = 1MHz) | Parameter | Symbol | Min | Тур | Max | Unit | Test conditions | Note | |--------------------|--------|-----|-----|-----|------|-----------------|------| | Input capacitance | Cin | _ | _ | 15 | pF | Vin = 0 V | 1 | | Output capacitance | Cout | _ | _ | 15 | pF | Vout = 0 V | 1 | Note: 1. This parameter is sampled and not 100% tested. # **Card System performance** | Item | Performance | |-------------------------------------------------|--------------| | Set up times (Reset to ready) | 100 ms (max) | | Set up times (Sleep to idle) | 2 ms (max) | | Data transfer rate to/from host | 8 MB/s burst | | Controller overhead (Command to DRQ) | 2 ms (max) | | Data transfer cycle end to ready (Sector write) | 1.2 ms (typ) | # DC Characteristics-1 (Ta = 0 to +70°C, $V_{cc}$ = 3.3 V ± 5%) | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ | Parameter | Symbol | Min | Тур | Max | Unit | Test conditions | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------|-----------------------|----------|-----------------------|---------|---------------------------------------------------| | $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$ | Input voltage (CMOS level) | V <sub>IHC</sub> | $0.7 \times V_{cc}$ | _ | V <sub>cc</sub> + 0.3 | V | _ | | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ | | V <sub>ILC</sub> | -0.3 | _ | $0.2 \times V_{cc}$ | V | - | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | Input voltage (TTL level) | V <sub>IHC</sub> | 2.0 | _ | V <sub>cc</sub> + 0.3 | V | _ | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | V <sub>ILC</sub> | -0.3 | _ | 0.6 | V | - | | | Schmitt circuit (CMOS level)*1 | | (1.6) | _ | 2.6 | V | V <sub>cc</sub> = 3.3 V | | | | V <sub>TC-</sub> | 0.7 | _ | (1.7) | V | - | | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ | | V <sub>TC</sub> *2 | (0.3) | _ | _ | V | - | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | | V <sub>cc</sub> - 0.4 | _ | _ | V | I <sub>OH</sub> = -2 mA | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | V <sub>oL</sub> | _ | _ | 0.4 | V | I <sub>oL</sub> = 2 mA | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | | V <sub>cc</sub> - 0.4 | _ | _ | V | $I_{OH} = -3 \text{ mA}$ | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | V <sub>OL</sub> | _ | _ | 0.4 | ٧ | I <sub>oL</sub> = 3 mA | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | V <sub>OH</sub> | V <sub>cc</sub> - 0.4 | _ | _ | V | $I_{OH} = -2 \text{ mA}$ | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | V <sub>OL</sub> | _ | _ | 0.4 | ٧ | I <sub>oL</sub> = 3 mA | | $ \begin{array}{ l c c c c c c c } \hline \text{Input leakage current*}^{4} & I_{\text{LO}} & - & - & 1 & \mu\text{A} & - \\ \hline \text{Output leakage current*}^{4} & I_{\text{LO}} & - & - & 1 & \mu\text{A} & V_{\text{out}} = \text{high impedance} \\ \hline \text{Pull-up current/(Resistivity)} & -I_{\text{PU}} & 15/(230) & 80/(41) & 230/(13.7) & \mu\text{A/(k}\Omega) & V_{\text{IN}} = \text{GND} \\ \hline \text{Pull-up current/(Resistivity)*}^{5} & -I_{\text{PU}} & 2/(1800) & 16/(206) & 36/(85) & \mu\text{A/(k}\Omega) & V_{\text{IN}} = \text{GND} \\ \hline \text{Sleep/standby current*}^{8} & I_{\text{SP1}} & - & (0.2) & (0.5) & \text{mA} & \text{CMOS level (control signal = $V_{\text{cc}} - 0.2$)} \\ \hline \text{In Memory card mode and I/O card mode)} \\ \hline \text{Sector read current*}^{6.8} & I_{\text{CCR}}(\text{DC}) & - & (25) & (50) & \text{mA} & \text{CMOS level (control signal = $V_{\text{cc}} - 0.2$)} \\ \hline \text{In Memory card mode and I/O card mode)} \\ \hline \text{Sector write current*}^{7.8} & I_{\text{CCR}}(\text{DC}) & - & (25) & (50) & \text{mA} & \text{CMOS level (control signal = $V_{\text{cc}} - 0.2$)} \\ \hline \text{Sector write current*}^{7.8} & I_{\text{CCW}}(\text{DC}) & - & (25) & (50) & \text{mA} & \text{CMOS level (control signal = $V_{\text{cc}} - 0.2$)} \\ \hline \text{Sector write current*}^{7.8} & I_{\text{CCW}}(\text{DC}) & - & (25) & (50) & \text{mA} & \text{CMOS level (control signal = $V_{\text{cc}} - 0.2$)} \\ \hline \end{array}$ | | V <sub>OH</sub> | V <sub>cc</sub> - 0.4 | _ | _ | V | $I_{OH} = -1 \text{ mA}$ | | Output leakage current** $I_{LO}$ — 1 μA $V_{OUT}$ = high impedance Pull-up current/(Resistivity) $-I_{PU}$ 15/(230) 80/(41) 230/(13.7) μA/(kΩ) $V_{IN}$ = GND Pull-up current/(Resistivity)** $-I_{PU}$ 2/(1800) 16/(206) 36/(85) μA/(kΩ) $V_{IN}$ = GND Sleep/standby current** $I_{SP1}$ — (0.2) (0.5) mA CMOS level (control signal = $V_{CC}$ – 0.2) (In Memory card mode and I/O card mode) Sector read current**6.8 $I_{CCR}$ (DC) — (25) (50) mA CMOS level (control signal = $V_{CC}$ – 0.2) $I_{CCR}$ (Peak) — (50) (80) mA CMOS level (control signal = $V_{CC}$ – 0.2) Sector write current**7.8 $I_{CCW}$ (DC) — (25) (50) mA CMOS level (control signal = $V_{CC}$ – 0.2) | | V <sub>oL</sub> | _ | _ | 0.4 | V | I <sub>oL</sub> = 2 mA | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | Input leakage current*4 | l <sub>u</sub> | _ | _ | 1 | μΑ | _ | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | Output leakage current*4 | I <sub>LO</sub> | _ | _ | 1 | μΑ | V <sub>out</sub> = high impedance | | | Pull-up current/(Resistivity) | -I <sub>PU</sub> | 15/(230) | 80/(41) | 230/(13.7) | μΑ/(kΩ) | V <sub>IN</sub> = GND | | | Pull-up current/(Resistivity)*5 | -I <sub>PU</sub> | 2/(1800) | 16/(206) | 36/(85) | μΑ/(kΩ) | V <sub>IN</sub> = GND | | $\frac{I_{\text{ccR}}(\text{Peak}) - (50) (80) \text{mA}}{I_{\text{ccW}}(\text{DC}) - (25) (50) \text{mA}} = V_{\text{cc}} - \frac{0.2}{0.2}$ Sector write current* <sup>7,8</sup> $I_{\text{ccW}}(\text{DC}) - (25) (50) \text{mA} \text{CMOS level} \\ \text{(control signal = V}_{\text{cc}} - \frac{0.2}{0.2})$ | Sleep/standby current*8 | I <sub>SP1</sub> | _ | (0.2) | (0.5) | mA | signal = $V_{cc} - 0.2$ )<br>(In Memory card mode | | Sector write current* <sup>7,8</sup> $I_{ccw}(DC)$ — (25) (50) mA CMOS level (control signal = $V_{cc}$ — 0.2) | Sector read current*6,8 | I <sub>CCR</sub> (DC) | _ | (25) | (50) | mA | (control signal = V <sub>cc</sub> - | | (control signal = $V_{cc}$ – 0.2) | | I <sub>ccr</sub> (Peak) | _ | (50) | (80) | mA | | | I <sub>ccw</sub> (Peak) — (50) (80) mA | Sector write current*7,8 | I <sub>ccw</sub> (DC) | _ | (25) | (50) | mA | (control signal = V <sub>cc</sub> - | | | | I <sub>ccw</sub> (Peak) | _ | (50) | (80) | mA | | # **DC Characteristics-2** (Ta = 0 to +70°C, $V_{cc}$ = 5 V ± 10%) | Parameter | Symbol | Min | Тур | Max | Unit | Test conditions | |----------------------------------------|--------------------------|-----------------------|----------|-----------------------|---------|------------------------------------------------------------------------------------------| | Input voltage (CMOS level) | V <sub>IHC</sub> | $0.7 \times V_{cc}$ | _ | V <sub>cc</sub> + 0.3 | V | _ | | | V <sub>ILC</sub> | -0.3 | _ | $0.3 \times V_{cc}$ | V | - | | Input voltage (TTL level) | V <sub>IHC</sub> | 2.4 | _ | V <sub>cc</sub> + 0.3 | V | _ | | | V <sub>ILC</sub> | -0.3 | _ | 0.6 | V | - | | Schmitt circuit (CMOS level)*1 | V <sub>TC+</sub> | (2.8) | _ | 4.0 | V | V <sub>cc</sub> = 5 V | | | $V_{TC-}$ | 1.1 | _ | (2.4) | V | - | | | V <sub>TC</sub> *2 | (0.3) | _ | _ | V | - | | Output voltage (CMOS) (2 mA)*3 | V <sub>OH</sub> | V <sub>cc</sub> - 0.4 | _ | _ | V | $I_{OH} = -4 \text{ mA}$ | | | V <sub>oL</sub> | _ | _ | 0.4 | V | I <sub>oL</sub> = 4 mA | | Output voltage (CMOS)<br>(3 mA)*3 | $V_{OH}$ | V <sub>cc</sub> - 0.4 | _ | _ | V | I <sub>OH</sub> = -8 mA | | | V <sub>OL</sub> | _ | _ | 0.4 | V | I <sub>oL</sub> = 8 mA | | Output voltage (CMOS)<br>(2 mA/3 mA)*3 | $V_{\text{OH}}$ | V <sub>cc</sub> - 0.4 | _ | _ | V | $I_{OH} = -6 \text{ mA}$ | | | V <sub>oL</sub> | _ | _ | 0.4 | V | I <sub>oL</sub> = 8 mA | | Output voltage (CMOS)<br>(1 mA/2 mA)*3 | V <sub>OH</sub> | V <sub>cc</sub> - 0.4 | _ | _ | V | $I_{OH} = -3 \text{ mA}$ | | | V <sub>oL</sub> | _ | _ | 0.4 | V | I <sub>oL</sub> = 4 mA | | Input leakage current*4 | l <sub>u</sub> | _ | _ | 1 | μΑ | _ | | Output leakage current*4 | I <sub>LO</sub> | _ | _ | 1 | μΑ | V <sub>out</sub> = high impedance | | Pull-up current/(Resistivity) | -I <sub>PU</sub> | 60/(92) | 220/(23) | 570/(7.9) | μΑ/(kΩ) | V <sub>IN</sub> = GND | | Pull-up current/(Resistivity)*5 | - <b>I</b> <sub>PU</sub> | 10/(550) | 45/(110) | 90/(50) | μΑ/(kΩ) | V <sub>IN</sub> = GND | | Sleep/standby current*8 | I <sub>SP1</sub> | _ | (0.5) | (1.0) | mA | CMOS level (control signal = $V_{cc} - 0.2$ )<br>(In Memory card mode and I/O card mode) | | Sector read current*6,8 | I <sub>CCR</sub> (DC) | _ | (40) | (70) | mA | CMOS level<br>(control signal = V <sub>cc</sub> – 0.2) | | | I <sub>CCR</sub> (Peak) | _ | (80) | (120) | mA | - | | Sector write current*7,8 | I <sub>ccw</sub> (DC) | _ | (45) | (75) | mA | CMOS level<br>(control signal = V <sub>cc</sub> –<br>0.2) | | | I <sub>ccw</sub> (Peak) | ) — | (80) | (120) | mA | = | - Notes : 1. CMOS schmitt input is measured at $V_{IH} = V_{TC+}$ max and $V_{IL} = V_{TC-}$ mim. ( ) is reference value. - 2. $V_{TC}$ is reference value. - 3. Measured for static state. - 4. Except pulled up input/output pin. - 5. Pull-up resister is 100 k $\Omega$ . - 6. Measured during sector read transfer. - 7. Measured during sector write transfer. - 8. Power dissipation is reference value on the assembled flash card, including the flash memory. # **DC Current Waveform** ( $V_{CC} = 5 \text{ V}, \text{ Ta} = 25 \text{ C}$ ) **Power on Operation** (Reference only) #### **Sector Read** ### **Sector Write** AC Characteristics (Ta = 0 to +70 °C, $V_{cc}$ = 5 V $\pm$ 10%, $V_{cc}$ = 3.3 V $\pm$ 5%) ### **Attribute Memory Read AC Characteristics** | | | 250 ns | | | | |---------------------------|----------|--------|-----|-----|------| | Parameter | Symbol | Min | Тур | Max | Unit | | Read cycle time | tCR | 250 | _ | _ | ns | | Address access time | ta(A) | _ | | 250 | ns | | -CE access time | ta(CE) | _ | _ | 250 | ns | | -OE access time | ta(OE) | _ | _ | 125 | ns | | Output disable time (-CE) | tdis(CE) | _ | _ | 100 | ns | | Output disable time (-OE) | tdis(OE) | _ | _ | 100 | ns | | Output enable time (-CE) | ten(CE) | 5 | _ | _ | ns | | Output enable time (-OE) | ten(OE) | 5 | _ | _ | ns | | Data valid time (A) | tv(A) | 0 | _ | _ | ns | | Address setup time | tsu(A) | 30 | _ | _ | ns | | Address hold time | th(A) | 20 | _ | _ | ns | | -CE setup time | tsu(CE) | 0 | _ | _ | ns | | -CE hold time | th(CE) | 20 | _ | _ | ns | ### **Attribute Memory Read Timing** #### **Attribute Memory Write AC Characteristics** | | | 250 ns | | | | |--------------------------------|-------------|--------|-----|-----|------| | Parameter | Symbol | Min | Тур | Max | Unit | | Write cycle time | tCW | 250 | _ | _ | ns | | Write pulse time | tw(WE) | 150 | _ | _ | ns | | Address setup time | tsu(A) | 30 | _ | _ | ns | | Address setup time (-WE) | tsu(A-WEH) | 180 | _ | _ | ns | | -CE setup time (-WE) | tsu(CE-WEH) | 180 | _ | _ | ns | | Data setup time (-WE) | tsu(D-WEH) | 80 | _ | _ | ns | | Data hold time | th(D) | 30 | _ | _ | ns | | Write recover time | trec(WE) | 30 | _ | _ | ns | | Output disable time (-WE) | tdis(WE) | _ | _ | 100 | ns | | Output disable time (-OE) | tdis(OE) | _ | _ | 100 | ns | | Output enable time (-WE) | ten(WE) | 5 | _ | _ | ns | | Output enable time (-OE) | ten(OE) | 5 | _ | _ | ns | | Output enable setup time (-WE) | tsu(OE-WE) | 10 | _ | _ | ns | | Output enable hold time (-WE) | th(OE-WE) | 10 | _ | _ | ns | | -CE setup time | tsu(CE) | 0 | _ | _ | ns | | -CE hold time | th(CE) | 20 | _ | _ | ns | ### **Attribute Memory Write Timing** #### I/O Access Read AC Characteristics | Parameter | Symbol | Min | Тур | Max | Unit | |------------------------------------|-----------------|-----|-----|-----|------| | Data delay after -IORD | td(IORD) | _ | _ | 100 | ns | | Data hold following -IORD | th(IORD) | 0 | _ | _ | ns | | -IORD pulse width | tw(IORD) | 165 | _ | _ | ns | | Address setup before -IORD | tsuA(IORD) | 70 | _ | _ | ns | | Address hold following -IORD | thA(IORD) | 20 | _ | _ | ns | | -CE setup before -IORD | tsuCE(IORD) | 5 | _ | _ | ns | | -CE hold following -IORD | thCE(IORD) | 20 | _ | _ | ns | | -REG setup before -IORD | tsuREG(IORD) | 5 | _ | _ | ns | | -REG hold following -IORD | thREG(IORD) | 0 | _ | _ | ns | | -INPACK delay falling from -IORD | tdfINPCAK(IORD) | 0 | _ | 45 | ns | | -INPACK delay rising from -IORD | tdrINPACK(IORD) | _ | _ | 45 | ns | | -IOIS16 delay falling from address | tdfIOIS16(ADR) | _ | _ | 35 | ns | | -IOIS16 delay rising from address | tdrIOIS16(ADR) | | | 35 | ns | ### I/O Access Read Timing #### I/O Access Write AC Characteristics | ns<br>ns | |----------| | ns | | | | ns | ### I/O Access Write Timing #### **Common Memory Access Read AC Characteristics** | Parameter | Symbol | Min | Тур | Max | Unit | |---------------------------|----------|-----|-----|-----|------| | -OE access time | ta(OE) | _ | _ | 125 | ns | | Output disable time (-OE) | tdis(OE) | _ | _ | 100 | ns | | Address setup time | tsu(A) | 30 | _ | _ | ns | | Address hold time | th(A) | 20 | _ | _ | ns | | -CE setup time | tsu(CE) | 0 | _ | _ | ns | | -CE hold time | th(CE) | 20 | _ | _ | ns | #### **Common Access Read Timing** #### **Common Memory Access Write AC Characteristics** | Parameter | Symbol | Min | Тур | Max | Unit | |------------------------|------------|-----|-----|-----|------| | Data setup time (-WE) | tsu(D-WEH) | 80 | _ | _ | ns | | Data hold time | th(D) | 30 | | | ns | | Write pulse time | tw(WE) | 150 | _ | _ | ns | | Address setup time | tsu(A) | 30 | _ | _ | ns | | -CE setup time | tsu(CE) | 0 | _ | _ | ns | | Write recover time | trec(WE) | 30 | _ | _ | ns | | -CE hold following -WE | th(CE) | 20 | _ | _ | ns | ### **Common Access Write Timing** #### **True IDE Mode Access Read AC Characteristics** | Parameter | Symbol | Min | Тур | Max | Unit | |-----------------------------------|----------------|-----|-----|-----|------| | data delay after IORD | td(IORD) | _ | _ | 100 | ns | | data hold following IORD | th(IORD) | 0 | _ | _ | ns | | IORD width time | tw(IORD) | 165 | _ | _ | ns | | address setup before IORD | tsuA(IORD) | 70 | _ | _ | ns | | address hold following IORD | thA(IORD) | 20 | _ | _ | ns | | CE setup before IORD | tsuCE(IORD) | 5 | _ | _ | ns | | CE hold following IORD | thCE(IORD) | 20 | _ | _ | ns | | IOIS16 delay falling from address | tdfIOIS16(ADR) | _ | _ | 35 | ns | | IOIS16 delay rising from address | tdfIOIS16(ADR) | _ | _ | 35 | ns | #### **True IDE Mode Access Read Timing** #### **True IDE Mode Access Write AC Characteristics** | Parameter | Symbol | Min | Тур | Max | Unit | |-----------------------------------|----------------|-----|-----|-----|------| | Data setup before IOWR | tsu(IOWR) | 60 | _ | _ | ns | | data hold following IOWR | th(IOWR) | 30 | _ | _ | ns | | IORD width time | tw(IOWR) | 165 | _ | _ | ns | | address setup before IOWR | tsuA(IOWR) | 70 | _ | _ | ns | | address hold following IOWR | thA(IOWR) | 20 | _ | _ | ns | | CE setup before IOWR | tsuCE(IOWR) | 5 | _ | _ | ns | | CE hold following IOWR | thCE(IOWR) | 20 | _ | _ | ns | | IOIS16 delay falling from address | tdfIOIS16(ADR) | _ | _ | 35 | ns | | IOIS16 delay rising from address | tdfIOIS16(ADR) | _ | _ | 35 | ns | ### **True IDE Mode Access Write Timing** # **Flash Memory Interface AC Characteristics** (Ta = 0 to +70°C, $V_{\text{CC}}$ = 5 V $\pm$ 10%, 3.3 V $\pm$ 5%) | Parameter | Symbol | Min | Тур | Max | Unit | |-----------------------------|-------------------|-----|-----|-----|------| | Write pulse time | t <sub>wP</sub> | 60 | _ | _ | ns | | Write pulse high time | t <sub>wph</sub> | 40 | _ | _ | ns | | F_CDE_ setup time for F_WE_ | t <sub>cds</sub> | 0 | _ | _ | ns | | Data setup time | t <sub>DS</sub> | 50 | _ | _ | ns | | Data hold time | t <sub>DH</sub> | 10 | _ | _ | ns | | Address setup time | t <sub>AS</sub> | 50 | _ | _ | ns | | Address hold time | t <sub>AH</sub> | 10 | _ | _ | ns | | F_OE_ setup time for F_SC | t <sub>oes</sub> | 0 | _ | _ | ns | | F_OE_ low to output low-z | t <sub>oel</sub> | 0 | _ | _ | ns | | F_CDE_ setup time for F_SC | t <sub>cdss</sub> | 100 | _ | _ | ns | | Serial clock cycle time | t <sub>scc</sub> | 50 | _ | _ | ns | | F_SC pulse width | t <sub>sp</sub> | 20 | _ | _ | ns | | F_SC pulse low time | t <sub>spl</sub> | 20 | _ | _ | ns | | F_SC to output delay | t <sub>sac</sub> | _ | _ | 50 | ns | | F_SC to output hold | t <sub>sh</sub> | 15 | _ | _ | ns | | Data setup time for F_SC | t <sub>sds</sub> | 0 | _ | _ | ns | | Data hold time for F_SC | t <sub>sdh</sub> | 30 | _ | _ | ns | | F_OE_ to output delay | t <sub>oe</sub> | _ | _ | 60 | ns | | F_OE_ high to output flat | t <sub>DF</sub> | _ | _ | 40 | ns | | Time to device busy | t <sub>DB</sub> | _ | _ | 150 | ns | #### Flash Memory Interface timing Reset Characteristics (only Memory Card Mode or I/O Card Mode) ### **Hard Reset Characteristics** | Parameter | Symbol | Min | Тур | Max | Unit | Test conditions | |-----------------------|--------------|------|-----|-----|------|-----------------| | Reset setup time | tsu(RESET) | 100 | _ | _ | ms | | | -CE recover time | trec(VCC) | 1 | _ | _ | μs | | | VCC rising up time | tpr | 0.1 | _ | 100 | ms | | | VCC falling down time | tpf | 3 | _ | 300 | ms | | | Reset pulse width | tw(RESET) | 10 | _ | _ | μs | | | | th(Hi-ZRESE | Γ) 1 | _ | _ | ms | | | | ts(Hi-ZRESET | Γ) 0 | _ | _ | ms | | ### **Hard Reset Timing** #### **Power on Reset Characteristics** Power on reset sequence must need by -PORST at the rising of $V_{cc}$ . | Parameter | Symbol | Min | Тур | Max | Unit | Test conditions | |--------------------|----------|-----|-----|-----|------|-----------------| | -CE setup time | tsu(VCC) | 100 | _ | _ | ms | _ | | VCC rising up time | tpr | 0.1 | _ | 100 | ms | | #### **Power on Reset Timing** #### **Attention for Card Use** - In the reset or power off, all register informations are cleared. - Notice that the card insertion/removal should not be executed during host is active, if the card is used in True IDE mode. - After the card hard reset, soft reset, or power on reset, ATA reset, command applied the card cannot access during +RDY/-BSY pin is "low" level. Flash card can't be operated in this case. - Notice that the card removal should be executed after card internal operations completed. - Before the card insertion $V_{cc}$ can not be supplied to the card. After confirmation that -CD1, -CD2 pins are inserted, supply $V_{cc}$ to the card. - -OE must be kept at the V<sub>cc</sub> level during power on reset in memory card mode and I/O card mode. -OE must be kept constantly at the GND level in True IDE mode. # **Physical Outline** ### **Schematic Flash Card** (Reference only) #### Card density for HN29W6411A | Card defisity for this 250004117A | | | | | | | | |-----------------------------------------------|-----------------|------------------------------|-------------------------|---------------------------|-----------------------|--------------------------|-------------------------| | | Card<br>density | Pieces<br>of flash<br>memory | Used<br>flash<br>memory | Number<br>of<br>cylinders | Number<br>of<br>heads | Number of sectors /track | Number<br>of<br>sectors | | | 160M byte | 20 | A-1 to A-10, | 615 | 16 | 32 | 314,880 | | | | | B-1 to B-10 | | | | | | | (135M byte) | 18 | A-1 to A-10, | 738 | 8 | 48 | 283,392 | | | | | B-1 to B-8 | | | | | | | (144M byte) | 16 | A-1 to A-10, | 984 | 8 | 32 | 251,904 | | ATA card<br>specification | | | B-1 to B-6 | | | | | | | (112M byte) | 14 | A-1 to A-10, | 861 | 8 | 32 | 220,416 | | | | | B-1 to B-4 | | | | | | | 106M byte | 12 | A-1 to A10, | 738 | 8 | 32 | 188,928 | | ₩<br>Sec | | | B-1 to B-2 | | | | | | <u> </u> | 80M byte | 10 | A-1 to A-10 | 615 | 8 | 32 | 157,440 | | | 64M byte | 8 | A-1 to A-8 | 984 | 4 | 32 | 125,952 | | | 48M byte | 6 | A-1 to A-6 | 738 | 4 | 32 | 94,464 | | | 32M byte | 4 | A-1 to A-4 | 492 | 4 | 32 | 62,976 | | | 16M byte | 2 | A-1 to A-2 | 246 | 4 | 32 | 31,488 | | | 8M byte | 1 | A-1 | 246 | 2 | 32 | 15,744 | | ¥ 6 | 48M byte | 6 | A-1 to A-6 | 738 | 4 | 32 | 94,464 | | CompactFlash <sup>TM</sup> card specification | 32M byte | 4 | A-1 to A-4 | 492 | 4 | 32 | 62,976 | | | 16M byte | 2 | A-1 to A-2 | 246 | 4 | 32 | 31,488 | | | 8M byte | 1 | A-1 | 246 | 2 | 32 | 15,744 | | Com | | | | | | | | #### Card density for HN29W8411 | | Card<br>density | Pieces<br>of flash<br>memory | Used<br>flash<br>memory | Number<br>of<br>cylinders | Number<br>of<br>heads | Number of sectors /track | Number<br>of<br>sectors | |-----------------------------------------------|-----------------|------------------------------|-------------------------|---------------------------|-----------------------|--------------------------|-------------------------| | p io | 20M byte | 2 | A-1 to A-2 | 320 | 4 | 32 | 40,960 | | ATA card specification | 10M byte | 1 | A-1 | 320 | 2 | 32 | 20,480 | | CompactFlash <sup>TM</sup> card specification | 20M byte | 2 | A-1 to A-2 | 320 | 4 | 32 | 40,960 | | | 10M byte | 1 | A-1 | 320 | 2 | 32 | 20,480 | #### Sample bill of materials | Campic bill of materials | | | | | |--------------------------|---------------|--|--|--| | Item | Specification | | | | | IC1 | Controller | | | | | IC2 | Flash memory | | | | | Reset IC | _ | | | | | X'tal | 20 MHz | | | | | RRST | 100 kΩ | | | | | RPWR1 | 2 kΩ | | | | | RPWR2 | 100 kΩ | | | | | RXTAL | 1 ΜΩ | | | | | REMODE | 2 kΩ | | | | | ROE | 100 kΩ | | | | | RRCEB1 to RRCEB10 | 100 kΩ | | | | | RHDD0 to RHDD15 | 0 Ω | | | | | CPWR1 | 1 μF | | | | | CPWR2 | 0.1 μF | | | | | CX0 to CX1 | 10 pF | | | | | C0 | 1 μF | | | | | C1 to C23 | 0.1 μF | | | | | | | | | | #### PC card slot pin | Signal name<br>(I/O card mode) | ATA card<br>specification | CompactFlash <sup>TM</sup> card specification | | | |--------------------------------|---------------------------|-----------------------------------------------|--|--| | VCC | 17, 51 | 13, 38 | | | | -SPKR | 62 | 45 | | | | -CSEL | 56 | 39 | | | | A0 | 29 | 20 | | | | | | | | | | A1 | 28 | 19 | | | | A2 | 27 | 18 | | | | A3 | 26 | 17 | | | | A4 | 25 | 16 | | | | A5 | 24 | 15 | | | | A6 | 23 | 14 | | | | A7 | 22 | 12 | | | | A8 | 12 | 11 | | | | A9 | 11 | 10 | | | | A10 | 8 | 8 | | | | D0 | 30 | 21 | | | | D1 | 31 | 22 | | | | D2 | 32 | 23 | | | | D3 | 2 | 2 | | | | D4 | 3 | 3 | | | | D5 | 4 | 4 | | | | D6 | 5 | 5 | | | | D7 | 6 | 6 | | | | D8 | 64 | 47 | | | | D9 | 65 | 48 | | | | D10 | 66 | 49 | | | | D11 | 37 | 27 | | | | D12 | 38 | 28 | | | | D13 | 39 | 29 | | | | D14 | 40 | 30 | | | | D15 | 41 | 31 | | | | -CE1 | 7 | 7 | | | | -OE | 9 | 9 | | | | -WE | 15 | 36 | | | | -IREQ | 16 | 37 | | | | -IOIS16 | 33 | 24 | | | | -CE2 | 42 | 32 | | | | -IORD | 44 | 34 | | | | -IOWR | 45 | 35 | | | | RESET | 58 | 41 | | | | -WAIT | 59 | 42 | | | | -INPACK | 60 | 43 | | | | -REG | 61 | 44 | | | | -STSCHG | 63 | 46 | | | | GND | 1, 34, 35, 68 | 1, 50 | | | | -CD1 | 36 | 26 | | | | -CD2 | 67 | 25 | | | | -VS1 | 43 | 33 | | | | -VS2 | 57 | 40 | | | | 702 | | 1 70 | | | #### Cautions - 1. Hitachi neither warrants nor grants licenses of any rights of Hitachi's or any third party's patent, copyright, trademark, or other intellectual property rights for information contained in this document. Hitachi bears no responsibility for problems that may arise with third party's rights, including intellectual property rights, in connection with use of the information contained in this document. - 2. Products and product specifications may be subject to change without notice. Confirm that you have received the latest product standards or specifications before final design, purchase or use. - 3. Hitachi makes every attempt to ensure that its products are of high quality and reliability. However, contact Hitachi's sales office before using the product in an application that demands especially high quality and reliability or where its failure or malfunction may directly threaten human life or cause risk of bodily injury, such as aerospace, aeronautics, nuclear power, combustion control, transportation, traffic, safety equipment or medical equipment for life support. - 4. Design your application so that the product is used within the ranges guaranteed by Hitachi particularly for maximum rating, operating supply voltage range, heat radiation characteristics, installation conditions and other characteristics. Hitachi bears no responsibility for failure or damage when used beyond the guaranteed ranges. Even within the guaranteed ranges, consider normally foreseeable failure rates or failure modes in semiconductor devices and employ systemic measures such as fail-safes, so that the equipment incorporating Hitachi product does not cause bodily injury, fire or other consequential damage due to operation of the Hitachi product. - 5. This product is not designed to be radiation resistant. - 6. No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without written approval from Hitachi. - Contact Hitachi's sales office for any questions regarding this document or Hitachi semiconductor products. http:semiconductor.hitachi.com/ # ITACH Hitachi, Ltd. Semiconductor & Integrated Circuits. Nippon Bldg., 2-6-2, Ohte-machi, Chiyoda-ku, Tokyo 100-0004, Japan Tel: Tokyo (03) 3270-2111 Fax: (03) 3270-5109 URI NorthAmerica 179 East Tasman Drive, Europe Asia (Singapore) http://www.hitachi-eu.com/hel/ecg http://www.has.hitachi.com.sg/grp3/sicd/index.htm http://www.hitachi.com.tw/E/Product/SICD\_Frame.htm Asia (Taiwan) Asia (HongKóng) http://www.hitachi.com.hk/eng/bo/grp3/index.htm http://www.hitachi.co.jp/Sicd/indx.htm Japan For further information write to: Hitachi Semiconductor Hitachi Europe GmbH (America) Inc. Electronic components Group Dornacher Straße 3 San Jose, CA 95134 D-85622 Feldkirchen, Munich Tel: <1> (408) 433-1990 Germany Fax: <1>(408) 433-0223 Tel: <49> (89) 9 9180-0 Fax: <49> (89) 9 29 30 00 Hitachi Europe Ltd. Electronic Components Group. Whitebrook Park > Lower Cookham Road Maidenhead Berkshire SL6 8YA, United Kingdom Tel: <44> (1628) 585000 Fax: <44> (1628) 778322 Hitachi Asia Pte. Ltd. 16 Collyer Quay #20-00 Hitachi Tower Singapore 049318 Tel: 535-2100 Fax: 535-1533 Hitachi Asia Ltd. Taipei Branch Office 3F, Hung Kuo Building. No.167 Tun-Hwa North Road, Taipei (105) Tel: <886> (2) 2718-3666 Fax: <886> (2) 2718-8180 Hitachi Asia (Hong Kong) Ltd. Group III (Electronic Components) 7/F., North Tower, World Finance Centre, Harbour City, Canton Road, Tsim Sha Tsui, Kowloon, Hong Kong Tel: <852> (2) 735 9218 Fax: <852> (2) 730 0281 Telex: 40815 HITEC HX Copyright © Hitachi, Ltd., 1998. All rights reserved. Printed in Japan. # **Revision Record** | Rev. | Date | Contents of Modification | Drawn by | Approved by | |------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------| | 0.0 | Nov. 27, 1998 | Initial issue | M. Shirai | T. Totsuka | | 1.0 | Apr. 16, 1999 | Correct errors: Change of figures for Flash memory interface timing and Schematic flash card 4. Socket and copy register (Address 206H) Addition of table for DRV# 9. Status register: Addition of description CIS information Change of Address 0A2H, 0CAH, 0FCH and 12EH Change of description for 4. Sector count register Change of description for 17. Set features 81H: Enable 8-bit to Disable 8-bit Change of Identify drive information: Word address "60 to 255" to "62 to 127", "128 to 159" and "160 to 255" Addition of description for 23. Wear level DC Characteristics I <sub>SP1</sub> max: TBD to 0.5 mA Addition of I <sub>SP1</sub> test conditions: CMOS level (control signal = V <sub>CC</sub> - 0.2 V) In Memory card mode and I/O card mode DC Current Waveform Change of figures: Sector read and sector write Addition of figure for Power on operation Power on Reset Characteristics Change of description and figure Attention for Card Use (Notes For Host Interface Design) Change of title and description | | |