SMCxxxAF

16 MByte, 32 MByte, 64 MByte, 128 MByte, 256 MByte, 512 MByte and 1 GByte, 3.3V/5V Supply CompactFlash™ Card

PRELIMINARY DATA

FEATURES SUMMARY

- CUSTOM-DESIGNED, HIGHLY-INTEGRATED MEMORY CONTROLLER
  - Compliant with CompactFlash™ Specification 2.0
  - Compatible with PCMCIA Specification
  - PC Card ATA Interface supported
  - True IDE Mode compatible
- SMALL FORM FACTOR
  - 36.4mm x 42.8mm x 3.3mm
- LOW-POWER CMOS TECHNOLOGY
- 3.3V / 5.0V POWER SUPPLY
- POWER SAVING MODE (WITH AUTOMATIC WAKE-UP)
- HIGH RELIABILITY
  - MTBF > 3,000,000 hours
  - Data Reliability: < 1 Non-Recoverable Error per $10^{14}$ Bits Read
  - Endurance: > 600,000 erase/program cycles
  - Number of Card Insertions/Removals: > 10,000
- HIGH PERFORMANCE
  - Up to 22MB/s transfer rate
  - Sustained Write Performance (Host to Flash Memory): 4.5MB/s
- OPERATING SYSTEM SUPPORT
  - Standard Software Drivers operation
- AVAILABLE DENSITIES (FORMATTED)
  - 16 MBytes to 1 GByte

Figure 1. Package

CompactFlash™
<table>
<thead>
<tr>
<th>Reference</th>
<th>Part Number</th>
<th>Package Form Factor</th>
<th>Operating Voltage Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>SMCxxxAF</td>
<td>SMC016AF</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SMC032AF</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SMC064AF</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SMC128AF</td>
<td>CF Type I</td>
<td>3V to 3.6V or 4.5V to 5.5V</td>
</tr>
<tr>
<td></td>
<td>SMC256AF</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SMC512AF</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>SMC01GAF</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 1. Product List
TABLE OF CONTENTS

FEATURES SUMMARY .......................................................... 1
   Table 1. Product List ......................................................... 2
Related Documentation ......................................................... 5
   Table 2. System Performance ............................................... 5
   Table 3. Current Consumption ........................................... 5
   Table 4. Environmental Specifications ................................. 5
   Table 5. Physical Dimensions ............................................ 5
   Table 6. System Reliability and Maintenance ......................... 6

CARD PHYSICAL ............................................................... 6
   Physical Description ....................................................... 6
      Figure 2. CompactFlash Memory Card Block Diagram .............. 6

ELECTRICAL INTERFACE .................................................. 7
   Electrical Description ..................................................... 7
      Table 7. Pin Assignment and Pin Type .............................. 7
      Table 8. Signal Description .......................................... 9
   Electrical Specification ................................................ 12
      Table 9. Absolute Maximum Conditions ............................ 12
      Table 10. Input Power ................................................ 12
   Current Measurement ..................................................... 13
      Table 11. Input Leakage Current .................................... 13
      Table 12. Input Characteristics .................................... 13
      Table 13. Output Drive Type ........................................ 13
      Table 14. Output Drive Characteristics ............................ 13
   Command Interface ....................................................... 14
      Figure 3. Attribute Memory Read Timing Diagram ............... 14
      Table 15. Attribute Memory Read Timing ........................... 14
      Figure 4. Configuration Register (Attribute Memory) Write Timing Diagram ........................................... 15
      Table 16. Configuration Register (Attribute Memory) Write Timing .................................................. 15
      Figure 5. Common Memory Read Timing Diagram ................... 16
      Table 17. Common Memory Read Timing ............................... 16
      Figure 6. Common Memory Write Timing Diagram .................. 17
      Table 18. Common Memory Write Timing ............................. 17
      Figure 7. I/O Read Timing Diagram .................................. 18
      Table 19. I/O Read Timing ............................................ 18
      Figure 8. I/O Write Timing Diagram ................................ 19
      Table 20. I/O Write Timing ............................................ 19
      Figure 9. True IDE Mode I/O Timing Diagram ....................... 20
      Table 21. True IDE Mode I/O Read/Write Timing Diagram ....... 21
   Card Configuration ........................................................ 22
      Table 22. CompactFlash Memory Card Registers and Memory Space Decoding ........................................ 22
      Table 23. CompactFlash Memory Card Configuration Registers Decoding .............................................. 22
   Configuration Option Register (Base + 00h in Attribute Memory) ........ 23
Table 24. Configuration Option Register (default value: 00h) ............................................. 23
Table 25. CompactFlash Memory Card Configurations ........................................................... 23

Card Configuration and Status Register (Base + 02h in Attribute Memory) ...................... 23
Table 26. Card Configuration and Status Register (default value: 00h) ................................. 23
Pin Replacement Register (Base + 04h in Attribute Memory) ............................................. 24
Table 27. Pin Replacement Register (default value: 0Ch). .................................................... 24
Socket and Copy Register (Base + 06h in Attribute Memory). ........................................... 24
Table 28. Pin Replacement Changed Bit/Mask Bit Values ..................................................... 24

Card Configuration and Status Register (Base + 02h in Attribute Memory) ...................... 23
Table 29. Socket and Copy Register (default value: 00h) .................................................... 24

Attribute Memory Function ................................................................................................. 25
Table 30. Attribute Memory Function. .................................................................................. 25
I/O Transfer Function ........................................................................................................... 26
Table 31. I/O Function. ......................................................................................................... 26
Common Memory Transfer Function. ................................................................................... 26
Table 32. Common Memory Function. .................................................................................. 26
True IDE Mode I/O Function .................................................................................................. 27
Table 33. True IDE Mode I/O Function. .................................................................................. 27

METAFORMAT .................................................................................................................... 28
Metaformat Overview ............................................................................................................ 28
Metaformat Requirements ..................................................................................................... 28

SOFTWARE INTERFACE .................................................................................................. 29
CF-ATA Drive Register Set Definition and Protocol. ............................................................. 29
Table 34. I/O Configurations .................................................................................................. 29
Memory Mapped Addressing (Conf = 0) .............................................................................. 29
Table 35. Memory Mapped Decoding ................................................................................... 30
Contiguous I/O Mapped Addressing (Conf = 1) ................................................................... 31
Table 36. Contiguous I/O Decoding .................................................................................... 31
I/O Primary and Secondary Address Configurations (Conf = 2,3) ...................................... 32
Table 37. Primary and Secondary I/O Decoding ................................................................. 32
True IDE Mode Addressing. .................................................................................................. 32
Table 38. True IDE Mode I/O Decoding ................................................................................ 32

CF-ATA REGISTERS ............................................................................................................ 33
Data Register (Address 1F0h [170h]; Offset 0, 8, 9). ....................................................... 33
Table 39. Data Register Access ............................................................................................ 33
Error Register (Address 1F1h [171h]; Offset 1, 0Dh Read Only). ....................................... 33
Table 40. Error Register ........................................................................................................ 33
Feature Register (Address 1F1h [171h]; Offset 1, 0Dh Write Only) .................................... 33
Sector Count Register (Address 1F2h [172h]; Offset 2) ................................................... 33
Sector Number (LBA 7-0) Register (Address 1F3h [173h]; Offset 3) ............................... 34
Cylinder Low (LBA 15-8) Register (Address 1F4h [174h]; Offset 4) ................................. 34
Cylinder High (LBA 23-16) Register (Address 1F5h [175h]; Offset 5) ............................... 34
Drive/Head (LBA 27-24) Register (Address 1F6h [176h]; Offset 6) ................................. 34
Table 41. Drive/Head Register .............................................................................................. 34
<table>
<thead>
<tr>
<th>Table</th>
<th>Description</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>42</td>
<td>Identify Drive Information</td>
<td>41</td>
</tr>
<tr>
<td>43</td>
<td>Identify Drive</td>
<td>40</td>
</tr>
<tr>
<td>44</td>
<td>Card (Drive) Address Register</td>
<td>35</td>
</tr>
<tr>
<td>45</td>
<td>Device Control Register</td>
<td>35</td>
</tr>
<tr>
<td>46</td>
<td>Check Power Mode</td>
<td>38</td>
</tr>
<tr>
<td>47</td>
<td>Execute Drive Diagnostic</td>
<td>38</td>
</tr>
<tr>
<td>48</td>
<td>Diagnostic Codes</td>
<td>39</td>
</tr>
<tr>
<td>49</td>
<td>Erase Sector(s)</td>
<td>39</td>
</tr>
<tr>
<td>50</td>
<td>NOP (00h)</td>
<td>43</td>
</tr>
<tr>
<td>51</td>
<td>NOP (01h)</td>
<td>43</td>
</tr>
<tr>
<td>52</td>
<td>Idle (97h or E3h)</td>
<td>42</td>
</tr>
<tr>
<td>53</td>
<td>Idle (95h or E1h)</td>
<td>42</td>
</tr>
<tr>
<td>54</td>
<td>Initialize Drive Parameters (91h)</td>
<td>42</td>
</tr>
<tr>
<td>55</td>
<td>Initialize Drive Parameters (90h)</td>
<td>42</td>
</tr>
</tbody>
</table>
Read Buffer (E4h) ......................................................... 43
Table 56. Read Buffer .................................................. 43
Read Multiple (C4h) ..................................................... 44
Table 57. Read Multiple ................................................. 44
Read Sector(s) (20h or 21h) .......................................... 45
Table 58. Read Sector(s) .................................................. 45
Read Verify Sector(s) (40h or 41h) ................................. 45
Table 59. Read Verify Sector(s) ....................................... 45
Recalibrate (1Xh) .......................................................... 46
Table 60. Recalibrate ..................................................... 46
Request Sense (03h) ...................................................... 46
Table 61. Request Sense .................................................. 46
Table 62. Extended Error Codes ..................................... 47
Seek (7Xh) ................................................................. 47
Table 63. Seek ............................................................ 47
Set Features (EFh) ........................................................ 48
Table 64. Set Features .................................................... 48
Table 65. Features Supported ......................................... 48
Table 66. Transfer Mode Values ..................................... 49
Set Multiple Mode (C6h) .............................................. 49
Table 67. Set Multiple Mode .......................................... 49
Set Sleep Mode (99h or E6h) ......................................... 49
Table 68. Set Sleep Mode ............................................... 49
Standby (96h or E2) ..................................................... 50
Table 69. Standby ......................................................... 50
Standby Immediate (94h or E0h) .................................... 50
Table 70. Standby Immediate .......................................... 50
Translate Sector (87h) ................................................... 51
Table 71. Translate Sector .............................................. 51
Table 72. Translate Sector Information ................................ 51
Wear Level (F5h) .......................................................... 52
Table 73. Wear Level ..................................................... 52
Write Buffer (E8h) ........................................................ 52
Table 74. Write Buffer .................................................... 52
Write Multiple Command (C5h) .................................... 53
Table 75. Write Multiple .................................................. 53
Write Multiple without Erase (CDh) .............................. 54
Table 76. Write Multiple without Erase .......................... 54
Write Sector(s) (30h or 31h) ......................................... 54
Table 77. Write Sector(s) .................................................. 54
Write Sector(s) without Erase (38h) .............................. 55
Table 78. Write Sector(s) without Erase ......................... 55
Write Verify (3Ch) ......................................................... 55
Table 79. Write Verify .................................................... 55

PACKAGE MECHANICAL ................................................. 56
SUMMARY DESCRIPTION

The CompactFlash is a small form factor non-volatile memory card which provides high capacity data storage. Its aim is to capture, retain and transport data, audio and images, facilitating the transfer of all types of digital information between a large variety of digital systems.

The Card operates in three basic modes,

- PCMCIA I/O mode
- PCMCIA memory mode
- True IDE mode

It conforms to the PC Card Specification when operating in the PCMCIA I/O mode and PCMCIA memory mode (Personal Computer Memory Card International Association standard, JEIDA in Japan) and to the ATA specification when operating in True IDE Mode. CompactFlash Cards can be used with passive adapters in a PC-Card Type II or Type III socket.

The Card has an internal intelligent controller which manages interface protocols, data storage and retrieval as well as Error Correcting Code (ECC), defect handling, diagnostics and clock control. Once the Card has been configured by the host, it behaves as a standard ATA (IDE) disk drive.

The specification has been realized and approved by the CompactFlash Association (CFA). This non-proprietary specification enables users to develop CF products that function correctly and are compatible with future CF design.

The system highlights are shown in Tables 2, 3, 4, 5 and 6.

Related Documentation

- PCMCIA PC Card Standard, 1995
- PCMCIA PC Card ATA Specification, 1995
- AT Attachment Interface Document, American National Standards Institute, X3.221-1994
- CF+ and CompactFlash Specification Revision 2.0

Table 2. System Performance

<table>
<thead>
<tr>
<th>System Performance</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sleep to write</td>
<td>1.6</td>
<td></td>
<td>ms</td>
</tr>
<tr>
<td>Sleep to read</td>
<td>1.8</td>
<td></td>
<td>ms</td>
</tr>
<tr>
<td>Power up to Ready</td>
<td>58</td>
<td></td>
<td>ms</td>
</tr>
<tr>
<td>Data transfer Rate (burst)</td>
<td>$22 (150X)^{(1)}$</td>
<td>MB/s</td>
<td></td>
</tr>
<tr>
<td>Sustained Read</td>
<td>$6.2 (42X)^{(1)}$</td>
<td>MB/s</td>
<td></td>
</tr>
<tr>
<td>Sustained Write</td>
<td>$4.5 (30X)^{(1)}$</td>
<td>MB/s</td>
<td></td>
</tr>
<tr>
<td>Command to DRQ</td>
<td>Read</td>
<td>150</td>
<td>µs</td>
</tr>
<tr>
<td></td>
<td>Write</td>
<td>30</td>
<td></td>
</tr>
</tbody>
</table>

Note: 1. 150X, 42X and 18X, speed grade markings where 1X = 150 KBytes/s. These values refer to the 256 MByte CompactFlash Card.

Table 3. Current Consumption

<table>
<thead>
<tr>
<th>Current Consumption (max)</th>
<th>3.3V±10%</th>
<th>5V±10%</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>56</td>
<td>60</td>
<td>mA</td>
</tr>
<tr>
<td>Write</td>
<td>65</td>
<td>69</td>
<td>mA</td>
</tr>
<tr>
<td>Standby</td>
<td>2</td>
<td>5</td>
<td>mA</td>
</tr>
<tr>
<td>Sleep Mode</td>
<td>2</td>
<td>5</td>
<td>mA</td>
</tr>
</tbody>
</table>

Table 4. Environmental Specifications

<table>
<thead>
<tr>
<th>Environmental Specifications</th>
<th>Operating</th>
<th>Non-Operating</th>
</tr>
</thead>
<tbody>
<tr>
<td>Temperature</td>
<td>−40 to 85°C</td>
<td>−50 to 100°C</td>
</tr>
<tr>
<td>Humidity (non-condensing)</td>
<td>N/A</td>
<td>85% RH, at 85°C</td>
</tr>
<tr>
<td>Salt Water Spray</td>
<td>N/A</td>
<td>3% NaCl at 35°C&lt;sup&gt;(1)&lt;/sup&gt;</td>
</tr>
<tr>
<td>Vibration (peak -to-peak)</td>
<td>N/A</td>
<td>30Gmax.</td>
</tr>
<tr>
<td>Shock</td>
<td>N/A</td>
<td>3,000Gmax.</td>
</tr>
</tbody>
</table>

Note: 1. MIL STD METHOD 1009

Table 5. Physical Dimensions

<table>
<thead>
<tr>
<th>Physical Dimensions</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Width</td>
<td>42.8 mm</td>
</tr>
<tr>
<td>Height</td>
<td>36.4 mm</td>
</tr>
<tr>
<td>Thickness</td>
<td>3.3 mm</td>
</tr>
<tr>
<td>Weight (typ.)</td>
<td>10 g</td>
</tr>
</tbody>
</table>
Table 6. System Reliability and Maintenance

<p>| | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>MTBF (at 25°C)</td>
<td>&gt; 3,000,000 hours</td>
</tr>
<tr>
<td>Insertions/Removals</td>
<td>&gt; 10,000</td>
</tr>
<tr>
<td>Preventive Maintenance</td>
<td>None</td>
</tr>
<tr>
<td>Data Reliability</td>
<td>&lt; 1 Non-Recoverable Error per $10^{14}$ bits Read</td>
</tr>
<tr>
<td>Endurance</td>
<td>&gt; 600,000 Erase/Program Cycles$^{(1)}$</td>
</tr>
</tbody>
</table>

Note: 1. Dependent on final system qualification data.

CARD PHYSICAL

Physical Description
The CompactFlash Memory Card contains a single chip controller and Flash memory module(s). The controller interfaces with a host system allowing data to be written to and read from the Flash memory module(s). Figure 2. shows the Block Diagram of the CompactFlash Memory Card.

The Card is offered in a Type I package with a 50-pin connector consisting of two rows of 25 female contacts on 50 mil (1.27mm) centers. Figure 10. shows Type I Card Dimensions.

Figure 2. CompactFlash Memory Card Block Diagram
ELECTRICAL INTERFACE

Electrical Description
The CompactFlash Memory Card operates in three basic modes:
- PC Card ATA using I/O Mode,
- PC Card ATA using Memory Mode,
- True IDE Mode, which is compatible with most disk drives.

The signal/pin assignments are listed in Table 7. Low active signals have a ‘–’ prefix. Pin types are Input, Output or Input/Output.

Table 7. Pin Assignment and Pin Type

<table>
<thead>
<tr>
<th>Pin Num</th>
<th>Signal Name</th>
<th>Pin Type</th>
<th>In, Out Type</th>
<th>Signal Name</th>
<th>Pin Type</th>
<th>In, Out Type</th>
<th>Signal Name</th>
<th>Pin Type</th>
<th>In, Out Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>GND</td>
<td>Ground</td>
<td></td>
<td>GND</td>
<td>Ground</td>
<td></td>
<td>GND</td>
<td>Ground</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>D03</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D03</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D03</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>3</td>
<td>D04</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D04</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D04</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>4</td>
<td>D05</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D05</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D05</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>5</td>
<td>D06</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D06</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D06</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>6</td>
<td>D07</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D07</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D07</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>7</td>
<td>–CE1</td>
<td>I</td>
<td>I3U</td>
<td>–CE1</td>
<td>I</td>
<td>I3U</td>
<td>–CS0</td>
<td>I</td>
<td>I3Z</td>
</tr>
<tr>
<td>8</td>
<td>A10</td>
<td>I</td>
<td>I1Z</td>
<td>A10</td>
<td>I</td>
<td>I1Z</td>
<td>A10(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>9</td>
<td>–OE</td>
<td>I</td>
<td>I3U</td>
<td>–OE</td>
<td>I</td>
<td>I3U</td>
<td>–ATASEL</td>
<td>I</td>
<td>I3U</td>
</tr>
<tr>
<td>10</td>
<td>A09</td>
<td>I</td>
<td>I1Z</td>
<td>A09</td>
<td>I</td>
<td>I1Z</td>
<td>A09(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>11</td>
<td>A08</td>
<td>I</td>
<td>I1Z</td>
<td>A08</td>
<td>I</td>
<td>I1Z</td>
<td>A08(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>12</td>
<td>A07</td>
<td>I</td>
<td>I1Z</td>
<td>A07</td>
<td>I</td>
<td>I1Z</td>
<td>A07(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>13</td>
<td>VCC</td>
<td>Power</td>
<td></td>
<td>VCC</td>
<td>Power</td>
<td></td>
<td>VCC</td>
<td>Power</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>A06</td>
<td>I</td>
<td>I1Z</td>
<td>A06</td>
<td>I</td>
<td>I1Z</td>
<td>A06(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>15</td>
<td>A05</td>
<td>I</td>
<td>I1Z</td>
<td>A05</td>
<td>I</td>
<td>I1Z</td>
<td>A05(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>16</td>
<td>A04</td>
<td>I</td>
<td>I1Z</td>
<td>A04</td>
<td>I</td>
<td>I1Z</td>
<td>A04(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>17</td>
<td>A03</td>
<td>I</td>
<td>I1Z</td>
<td>A03</td>
<td>I</td>
<td>I1Z</td>
<td>A03(2)</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>18</td>
<td>A02</td>
<td>I</td>
<td>I1Z</td>
<td>A02</td>
<td>I</td>
<td>I1Z</td>
<td>A02</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>19</td>
<td>A01</td>
<td>I</td>
<td>I1Z</td>
<td>A01</td>
<td>I</td>
<td>I1Z</td>
<td>A01</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>20</td>
<td>A00</td>
<td>I</td>
<td>I1Z</td>
<td>A00</td>
<td>I</td>
<td>I1Z</td>
<td>A00</td>
<td>I</td>
<td>I1Z</td>
</tr>
<tr>
<td>21</td>
<td>D00</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D00</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D00</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>22</td>
<td>D01</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D01</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>D01</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
</tbody>
</table>

The configuration of the Card is controlled using the standard PCMCIA configuration registers starting at address 200h in the Attribute Memory space of the memory card. For True IDE Mode, pin 9 is grounded.

Table 8. describes the I/O signals. Inputs are signals sourced from the host while Outputs are signals sourced from the Card. The signals are described for each of the three operating modes. All outputs from the card are totem pole except the data bus signals that are bi-directional tri-state. Refer to the section titled “Electrical Specifications” for definitions of Input and Output type.
<table>
<thead>
<tr>
<th>Pin Num</th>
<th>Signal Name</th>
<th>Pin Type</th>
<th>In, Out Type</th>
<th>Pin Num</th>
<th>Signal Name</th>
<th>Pin Type</th>
<th>In, Out Type</th>
<th>Pin Num</th>
<th>Signal Name</th>
<th>Pin Type</th>
<th>In, Out Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>23</td>
<td>D02</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>24</td>
<td>WP</td>
<td>O</td>
<td>OT3</td>
<td>25</td>
<td>–CD2</td>
<td>O</td>
<td>Ground</td>
</tr>
<tr>
<td>26</td>
<td>–CD1</td>
<td>O</td>
<td>Ground</td>
<td>27</td>
<td>D11(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>28</td>
<td>D12(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>29</td>
<td>D13(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>30</td>
<td>D14(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>31</td>
<td>D15(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>32</td>
<td>–CE2(1)</td>
<td>I</td>
<td>I3U</td>
<td>33</td>
<td>–VS1</td>
<td>O</td>
<td>Ground</td>
<td>34</td>
<td>–IORD</td>
<td>I</td>
<td>I3U</td>
</tr>
<tr>
<td>35</td>
<td>–IOWR</td>
<td>I</td>
<td>I3U</td>
<td>36</td>
<td>–WE</td>
<td>I</td>
<td>I3U</td>
<td>37</td>
<td>READY</td>
<td>O</td>
<td>OT1</td>
</tr>
<tr>
<td>38</td>
<td>VCC</td>
<td>Power</td>
<td></td>
<td>39</td>
<td>–CSEL</td>
<td>I</td>
<td>I2Z</td>
<td>40</td>
<td>–VS2</td>
<td>O</td>
<td>OPEN</td>
</tr>
<tr>
<td>41</td>
<td>RESET</td>
<td>I</td>
<td>I2Z</td>
<td>42</td>
<td>–WAIT</td>
<td>O</td>
<td>OT1</td>
<td>43</td>
<td>–INPACK</td>
<td>O</td>
<td>OT1</td>
</tr>
<tr>
<td>44</td>
<td>–REG</td>
<td>I</td>
<td>I3U</td>
<td>45</td>
<td>BVD2</td>
<td>I/O</td>
<td>I1U,OT1</td>
<td>46</td>
<td>BVD1</td>
<td>I/O</td>
<td>I1U,OT1</td>
</tr>
<tr>
<td>47</td>
<td>D08(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>48</td>
<td>D09(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
<td>49</td>
<td>D10(1)</td>
<td>I/O</td>
<td>I1Z,OZ3</td>
</tr>
<tr>
<td>50</td>
<td>GND</td>
<td>Ground</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

PC Card Memory Mode | PC Card I/O Mode | True IDE Mode

Note: 1. These signals are required only for 16 bit accesses and not required when installed in 8 bit systems. Devices should allow for 3-state signals not to consume current.
2. The signal should be grounded by the host.
3. The signal should be tied to VCC by the host.
4. The mode is optional for CF+ Cards, but required for CompactFlash Memory Cards.
5. The -CSEL signal is ignored by the card in PC Card modes. However, because it is not pulled up on the card in these modes it should not be left floating by the host in PC Card modes. In these modes, the pin is normally connected by the host to PC Card A25 or grounded by the host.
6. The signal should be held High or tied to VCC by the host.
7. RFU is Reserved for Future Use.
Table 8. Signal Description

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Dir.</th>
<th>Pin</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>A10 to A0</td>
<td>I</td>
<td>8,10,11,12, 14,15,16,17, 18,19,20</td>
<td>Used (with –REG) to select: the I/O port address registers, the memory mapped port address registers, a Byte in the card's information structure and its configuration control and status registers.</td>
</tr>
<tr>
<td>A10 to A0</td>
<td>I/O</td>
<td>46</td>
<td>Same as PC Card Memory Mode</td>
</tr>
<tr>
<td>A2 to A0</td>
<td>I/O</td>
<td>45</td>
<td>Only A2 to A0 are used to select the one of eight registers in the Task File, the remaining lines should be grounded.</td>
</tr>
<tr>
<td>BVD1</td>
<td>I/O</td>
<td>46</td>
<td>The battery voltage status of the card, as no battery is required it is asserted High.</td>
</tr>
<tr>
<td>–STSCHG</td>
<td>I/O</td>
<td>45</td>
<td>Alerts the host to changes in the READY and Write Protect states. Its use is controlled by the Card Configuration and Status Register.</td>
</tr>
<tr>
<td>–PDIAG</td>
<td>I/O</td>
<td>45</td>
<td>The Pass Diagnostic signal in the Master/Slave handshake protocol.</td>
</tr>
<tr>
<td>BVD2</td>
<td>I/O</td>
<td>45</td>
<td>The battery voltage status of the card, as no battery is required it is asserted High.</td>
</tr>
<tr>
<td>–SPKR</td>
<td>I/O</td>
<td>45</td>
<td>The Binary Audio output from the Card. It is asserted High as audio functions are not supported.</td>
</tr>
<tr>
<td>–DASP</td>
<td>I/O</td>
<td>45</td>
<td>This input/output is the Disk Active/Slave Present signal in the Master/Slave handshake protocol.</td>
</tr>
<tr>
<td>D15-D00</td>
<td>I/O</td>
<td>31,30,29,28, 27,49,48,47, 6,5,4,3,2, 23,22,21</td>
<td>Carry the Data, Commands and Status information between the host and the controller. D00 is the LSB of the Even Byte of the Word. D08 is the LSB of the Odd Byte of the Word.</td>
</tr>
<tr>
<td>D15-D00</td>
<td>I/O</td>
<td>1,50</td>
<td>Same as PC Card Memory Mode.</td>
</tr>
<tr>
<td>D15-D00</td>
<td>I/O</td>
<td>1,50</td>
<td>All Task File operations occur in Byte mode on D00 to D07 while all data transfers are 16 bit using D00 to D15.</td>
</tr>
<tr>
<td>GND</td>
<td>I/O</td>
<td>1,50</td>
<td>Ground.</td>
</tr>
<tr>
<td>GND</td>
<td>I/O</td>
<td>1,50</td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>GND</td>
<td>I/O</td>
<td>1,50</td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>–INP ACK</td>
<td>I/O</td>
<td>43</td>
<td>Not used, should not be connected to the host.</td>
</tr>
<tr>
<td>–INP ACK</td>
<td>I/O</td>
<td>43</td>
<td>The Input Acknowledge is asserted when the Card is selected and responding to an I/O read cycle at the current address on the bus. It is used by the host to control the enable of any input data buffers between the Card and CPU.</td>
</tr>
<tr>
<td>Reserved</td>
<td>O</td>
<td>43</td>
<td>Not used, should not be connected to the host.</td>
</tr>
<tr>
<td>Signal Name</td>
<td>Dir.</td>
<td>Pin</td>
<td>Description</td>
</tr>
<tr>
<td>-------------------------</td>
<td>------</td>
<td>-----</td>
<td>-----------------------------------------------------------------------------</td>
</tr>
<tr>
<td>–IORD (PC Card Memory Mode)</td>
<td>I</td>
<td>34</td>
<td>Not used.</td>
</tr>
<tr>
<td>–IORD (PC Card I/O Mode)</td>
<td>I</td>
<td>34</td>
<td>I/O Read strobe generated by the host. It gates I/O data onto the bus.</td>
</tr>
<tr>
<td>–IORD (True IDE Mode)</td>
<td>I</td>
<td>34</td>
<td>Same as PC Card I/O Mode.</td>
</tr>
<tr>
<td>–CD1, –CD2 (PC Card Memory Mode)</td>
<td>O</td>
<td>26,25</td>
<td>These are connected to ground on the Card. They are used by the host to determine that the Card is fully inserted into its socket.</td>
</tr>
<tr>
<td>–CD1, –CD2 (PC Card I/O Mode)</td>
<td>O</td>
<td>26,25</td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>–CD1, –CD2 (True IDE Mode)</td>
<td>O</td>
<td>26,25</td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>–CE1, –CE2 (PC Card Memory Mode)</td>
<td>I</td>
<td>7,32</td>
<td>Used to select the Card and to indicate whether a Byte or a Word operation is being performed. –CE2 accesses the odd Byte, –CE1 accesses the even Byte or the odd Byte depending on A0 and –CE2. A multiplexing scheme based on A0; –CE1, –CE2 allows 8 bit hosts to access all data on D0 to D7.</td>
</tr>
<tr>
<td>–CE1, –CE2 (PC Card I/O Mode)</td>
<td>I</td>
<td>7,32</td>
<td>Same as PC Card Memory Mode.</td>
</tr>
<tr>
<td>–CS0, –CS1 (True IDE Mode)</td>
<td>I</td>
<td>26,25</td>
<td>CS0 is the chip select for the task file registers, while CS1 selects the Alternate Status Register and the Device Control Register.</td>
</tr>
<tr>
<td>–CSEL (PC Card Memory Mode)</td>
<td>I</td>
<td>39</td>
<td>Not used.</td>
</tr>
<tr>
<td>–CSEL (PC Card I/O Mode)</td>
<td>I</td>
<td>39</td>
<td>Not used.</td>
</tr>
<tr>
<td>–CSEL (True IDE Mode)</td>
<td>I</td>
<td>39</td>
<td>This internally pulled up signal is used to configure the Card as a Master or Slave. When grounded it is configured as a Master, when open it is configured as a Slave.</td>
</tr>
<tr>
<td>–IOWR (PC Card Memory Mode)</td>
<td>I</td>
<td>35</td>
<td>Not used.</td>
</tr>
<tr>
<td>–IOWR (PC Card I/O Mode)</td>
<td>I</td>
<td>35</td>
<td>The I/O Write strobe pulse is used to clock I/O data on the bus into the Card controller registers. Clocking occurs on the rising edge.</td>
</tr>
<tr>
<td>–IOWR (True IDE Mode)</td>
<td>I</td>
<td>35</td>
<td>Same as PC Card I/O Mode.</td>
</tr>
<tr>
<td>–OE (PC Card Memory Mode)</td>
<td>I</td>
<td>9</td>
<td>This is an Output Enable strobe generated by the host interface. It reads data and the CIS and configuration registers.</td>
</tr>
<tr>
<td>–OE (PC Card I/O Mode)</td>
<td>I</td>
<td>9</td>
<td>Reads the CIS and configuration registers.</td>
</tr>
<tr>
<td>–ATASEL (True IDE Mode)</td>
<td>I</td>
<td>9</td>
<td>Grounded by the host.</td>
</tr>
<tr>
<td>Signal Name</td>
<td>Dir.</td>
<td>Pin</td>
<td>Description</td>
</tr>
<tr>
<td>--------------------------</td>
<td>------</td>
<td>------</td>
<td>--------------------------------------------------------------------------------------------------------------------------------------------</td>
</tr>
<tr>
<td>READY</td>
<td>O</td>
<td>37</td>
<td>Indicates whether the Card is busy (Low), or ready to accept a new data transfer operation (High). The Host socket must provide a pull-up resistor. At power up and Reset, the READY signal is held Low until the commands are completed. No access should be made during this time. The READY signal is held High whenever the Card has been powered up with RESET continuously disconnected or asserted.</td>
</tr>
<tr>
<td>–IREQ</td>
<td></td>
<td></td>
<td>Interrupt Request. It is strobed Low to generate a pulse mode interrupt or held Low for a level mode interrupt.</td>
</tr>
<tr>
<td>INTRQ</td>
<td></td>
<td></td>
<td>Active High Interrupt Request to the host.</td>
</tr>
<tr>
<td>–REG</td>
<td>I</td>
<td>44</td>
<td>Used to distinguish between Common Memory and Register (Attribute) Memory accesses. High for Common Memory, Low for Attribute Memory.</td>
</tr>
<tr>
<td>–REG</td>
<td>I</td>
<td></td>
<td>Must be Low during I/O Cycles when the I/O address is on the Bus.</td>
</tr>
<tr>
<td>Reserved</td>
<td></td>
<td></td>
<td>Not used, should be connected to VCC by the host.</td>
</tr>
<tr>
<td>RESET</td>
<td>I</td>
<td>41</td>
<td>Resets the Card (active High). The Card is Reset at power up only if this pin is left High or unconnected.</td>
</tr>
<tr>
<td>–RESET</td>
<td>I</td>
<td></td>
<td>Same as PC Card Memory Mode.</td>
</tr>
<tr>
<td>–RESET</td>
<td>I</td>
<td></td>
<td>Hardware Reset from the host (active Low).</td>
</tr>
<tr>
<td>VCC</td>
<td>I</td>
<td></td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>VCC</td>
<td>I</td>
<td></td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>–VS1, –VS2</td>
<td>O</td>
<td>33,40</td>
<td>Voltage Sense Signals.–VS1 is grounded so that the CIS can be read at 3.3 volts and –VS2 is reserved by PCMCIA for a secondary voltage.</td>
</tr>
<tr>
<td>–VS1, –VS2</td>
<td>O</td>
<td></td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>–VS1, –VS2</td>
<td>O</td>
<td></td>
<td>Same for all modes.</td>
</tr>
<tr>
<td>–WAIT</td>
<td>O</td>
<td>42</td>
<td>Signals the host to delay completion of a memory or I/O cycle that is in progress (active Low).</td>
</tr>
<tr>
<td>IORDY</td>
<td>O</td>
<td></td>
<td>Use as IORDY.</td>
</tr>
</tbody>
</table>
Electrical Specification

Table 9. defines the DC Characteristics for the CompactFlash Memory Card. Unless otherwise stated, conditions are:

- $V_{CC} = 5V \pm 10\%$

$V_{CC} = 3.3V \pm 10\%$

$-40 \text{ °C} \text{ to } 85 \text{ °C}$

The Card operates correctly in both the voltage ranges shown in Table 9. To comply with this specification, current requirements must not exceed the maximum limit shown in Table 10.

### Table 9. Absolute Maximum Conditions

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Input Power</td>
<td></td>
<td>$V_{CC}$</td>
</tr>
<tr>
<td>Voltage on any pin except $V_{CC}$ with respect to GND</td>
<td>V</td>
<td>$-0.5V$ to $V_{CC} + 0.5V$</td>
</tr>
</tbody>
</table>

### Table 10. Input Power

<table>
<thead>
<tr>
<th>Voltage</th>
<th>Maximum Average RMS Current</th>
<th>Measurement Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>3.3V ± 10%</td>
<td>65mA</td>
<td>3.3V at 25°C</td>
</tr>
<tr>
<td>5V ± 10%</td>
<td>70mA</td>
<td>5.0V at 25°C</td>
</tr>
</tbody>
</table>
Current Measurement
The current is measured by connecting an ammeter in series with the VCC supply. The meter should be set to the 2A scale range, and have a fast current probe with an RC filter with a time constant of 0.1 ms. Current measurements are taken while looping on a data transfer command with a sector count of 128. Current consumption values for both read and write commands are not to exceed the Maximum Average RMS Current specified in Table 10. Table 11 shows the Input Leakage Current, Table 12 the Input Characteristics, Table 13 the Output Drive Type and Table 14 the Output Drive Characteristics.

Table 11. Input Leakage Current

<table>
<thead>
<tr>
<th>Type</th>
<th>Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>IxZ</td>
<td>Input Leakage Current</td>
<td>IL</td>
<td>$V_{IH} = V_{CC}$</td>
<td>$V_{IL} = GND$</td>
<td>$-1$</td>
<td>$1$</td>
<td>$\mu A$</td>
</tr>
<tr>
<td>IxU</td>
<td>Pull Up Resistor</td>
<td>RPU1</td>
<td>$V_{CC} = 5.0V$</td>
<td>$50$</td>
<td>$500$</td>
<td>$k\Omega$</td>
<td></td>
</tr>
<tr>
<td>IxD</td>
<td>Pull Down Resistor</td>
<td>RPD1</td>
<td>$V_{CC} = 5.0V$</td>
<td>$50$</td>
<td>$500$</td>
<td>$k\Omega$</td>
<td></td>
</tr>
</tbody>
</table>

Note: x refers to the characteristics described in Table 12. For example, I1U indicates a pull up resistor with a type 1 input characteristic.

Table 12. Input Characteristics

<table>
<thead>
<tr>
<th>Type</th>
<th>Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Input Voltage</td>
<td>$V_{IH}$</td>
<td>$V_{CC} = 3.3V$</td>
<td>2.4</td>
<td>2.4</td>
<td>$V$</td>
<td></td>
</tr>
<tr>
<td></td>
<td>CMOS</td>
<td>$V_{IL}$</td>
<td>$V_{CC} = 5.0V$</td>
<td>0.6</td>
<td>0.8</td>
<td>$V$</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Input Voltage</td>
<td>$V_{IH}$</td>
<td>$V_{CC} = 3.3V$</td>
<td>1.5</td>
<td>2.0</td>
<td>$V$</td>
<td></td>
</tr>
<tr>
<td></td>
<td>CMOS</td>
<td>$V_{IL}$</td>
<td>$V_{CC} = 5.0V$</td>
<td>0.6</td>
<td>0.8</td>
<td>$V$</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Input Voltage</td>
<td>$V_{TH}$</td>
<td>$V_{CC} = 3.3V$</td>
<td>1.8</td>
<td>2.8</td>
<td>$V$</td>
<td></td>
</tr>
<tr>
<td></td>
<td>CMOS Schmitt Trigger</td>
<td>$V_{TL}$</td>
<td>$V_{CC} = 5.0V$</td>
<td>1.0</td>
<td>2.0</td>
<td>$V$</td>
<td></td>
</tr>
</tbody>
</table>

Table 13. Output Drive Type

<table>
<thead>
<tr>
<th>Type</th>
<th>Output Type</th>
<th>Valid Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>OTx</td>
<td>Totem pole</td>
<td>$I_{OH} &amp; I_{OL}$</td>
</tr>
<tr>
<td>OZx</td>
<td>Tri-State N-P Channel</td>
<td>$I_{OH} &amp; I_{OL}$</td>
</tr>
<tr>
<td>OPx</td>
<td>P-Channel Only</td>
<td>$I_{OH}$ Only</td>
</tr>
<tr>
<td>ONx</td>
<td>N-Channel Only</td>
<td>$I_{OL}$ Only</td>
</tr>
</tbody>
</table>

Table 14. Output Drive Characteristics

<table>
<thead>
<tr>
<th>Type</th>
<th>Parameter</th>
<th>Symbol</th>
<th>Conditions</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Output Voltage</td>
<td>$V_{OH}$</td>
<td>$I_{OH} = -4mA$</td>
<td>$V_{CC} = 0.8V$</td>
<td>$V_{OL}$</td>
<td>$I_{OL} = 4mA$</td>
<td>$Gnd + 0.4V$</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>$V_{OL}$</td>
<td>$I_{OL} = 4mA$</td>
<td>$V_{CC} = 0.8V$</td>
<td>$Gnd + 0.4V$</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Output Voltage</td>
<td>$V_{OH}$</td>
<td>$I_{OH} = -8mA$</td>
<td>$V_{CC} = 0.8V$</td>
<td>$V_{OL}$</td>
<td>$I_{OL} = 8mA$</td>
<td>$Gnd + 0.4V$</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>$V_{OL}$</td>
<td>$I_{OL} = 8mA$</td>
<td>$V_{CC} = 0.8V$</td>
<td>$Gnd + 0.4V$</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Output Voltage</td>
<td>$V_{OH}$</td>
<td>$I_{OH} = -8mA$</td>
<td>$V_{CC} = 0.8V$</td>
<td>$V_{OL}$</td>
<td>$I_{OL} = 8mA$</td>
<td>$Gnd + 0.4V$</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>$V_{OL}$</td>
<td>$I_{OL} = 8mA$</td>
<td>$V_{CC} = 0.8V$</td>
<td>$Gnd + 0.4V$</td>
<td></td>
</tr>
<tr>
<td>X</td>
<td>Tri-State Leakage Current</td>
<td>$I_{OZ}$</td>
<td>$V_{OL} = Gnd$</td>
<td>$V_{OH} = V_{CC}$</td>
<td>$-10$</td>
<td>10</td>
<td>$\mu A$</td>
</tr>
</tbody>
</table>
Command Interface
There are two types of bus cycles and timing sequences that occur in the PCMCIA type interface, direct mapped I/O transfer and memory access. Tables 15, 16, 17, 18, 19, 20 and 21 show the read and write timing parameters. Figures 3, 4, 5, 6, 7, 8 and 9 show the read and write timing diagrams. Note, the Wait Width time is intentionally less than the PCMCIA Specification of 12µs. Its maximum value can be determined from the Card Information Structure.

Figure 3. Attribute Memory Read Timing Diagram

Table 15. Attribute Memory Read Timing

<table>
<thead>
<tr>
<th>Symbol</th>
<th>IEEE Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>tc(R)</td>
<td>tAVAV</td>
<td>Read Cycle Time</td>
<td>300</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>ta(A)</td>
<td>tAVQV</td>
<td>Address Access Time</td>
<td>300</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>ta(CE)</td>
<td>tELQV</td>
<td>CE Access Time</td>
<td>300</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>ta(OE)</td>
<td>tGLOV</td>
<td>OE Access Time</td>
<td>150</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tdis(CE)</td>
<td>tEHQZ</td>
<td>Output Disable Time from CE</td>
<td>100</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tdis(OE)</td>
<td>tGHQZ</td>
<td>Output Disable Time from OE</td>
<td>100</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>ten(CE)</td>
<td>tELQNZ</td>
<td>Output Enable Time from CE</td>
<td>5</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>ten(OE)</td>
<td>tGLQNZ</td>
<td>Output Enable Time from OE</td>
<td>5</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tv(A)</td>
<td>tAXQX</td>
<td>Data Valid from Address Change</td>
<td>0</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tsu(A)</td>
<td>tAVGL</td>
<td>Address Setup Time</td>
<td>30</td>
<td></td>
<td>ns</td>
</tr>
</tbody>
</table>
Figure 4. Configuration Register (Attribute Memory) Write Timing Diagram

Table 16. Configuration Register (Attribute Memory) Write Timing

<table>
<thead>
<tr>
<th>Symbol</th>
<th>IEEE Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>tc(W)</td>
<td>tAVAV</td>
<td>Write Cycle Time</td>
<td>250</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tw(WE)</td>
<td>tWLWH</td>
<td>Write Pulse Width</td>
<td>150</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tsu(A)</td>
<td>tAVWL</td>
<td>Address Setup Time</td>
<td>30</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tsu(D-WEH)</td>
<td>tDWH</td>
<td>Data Setup Time from WE</td>
<td>80</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>th(D)</td>
<td>tWMDX</td>
<td>Data Hold Time</td>
<td>30</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>trec(WE)</td>
<td>tWMAX</td>
<td>Write Recovery Time</td>
<td>30</td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

Note: D_IN signifies data provided by the system to the CompactFlash Card or CF+ Card.
Figure 5. Common Memory Read Timing Diagram

Table 17. Common Memory Read Timing

<table>
<thead>
<tr>
<th>Symbol</th>
<th>IEEE Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>ta(OE)</td>
<td>tGLQV</td>
<td>Output Enable Access Time</td>
<td>125</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tdis(OE)</td>
<td>tGHQZ</td>
<td>Output Disable Time from OE</td>
<td>100</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tsu(A)</td>
<td>tAVGL</td>
<td>Address Setup Time</td>
<td>30</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>th(A)</td>
<td>tGHAH</td>
<td>Address Hold Time</td>
<td>20</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tsu(CE)</td>
<td>tELGL</td>
<td>CE Setup Time</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>th(CE)</td>
<td>tGHEH</td>
<td>CE Hold Time</td>
<td>20</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tv(WT-OE)</td>
<td>tGLWTv</td>
<td>Wait Delay Falling from OE</td>
<td>35</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tv(WT)</td>
<td>tQVWTH</td>
<td>Data Setup for Wait Release</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>tw(WT)</td>
<td>tWTLWTH</td>
<td>Wait Width Time</td>
<td>350  (3000 for CF+)</td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

Note: The maximum load on -WAIT is 1 LSTTL with 50pF total load. The -WAIT signal may be ignored if the -OE cycle to cycle time is greater than the Wait Width time. The Max Wait Width time can be determined from the Card Information Structure. The Wait Width time meets the PCMCIA specification of 12µs but is intentionally less in this specification.
Figure 6. Common Memory Write Timing Diagram

Table 18. Common Memory Write Timing

<table>
<thead>
<tr>
<th>Symbol</th>
<th>IEEE Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>tsu(D-WEH)</td>
<td>tDVWH</td>
<td>Data Setup Time from WE</td>
<td>80 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>th(D)</td>
<td>tWMDX</td>
<td>Data Hold Time</td>
<td>30 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>tw(WE)</td>
<td>tWLWH</td>
<td>WE Pulse Width</td>
<td>150 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>tsu(A)</td>
<td>tAVGL</td>
<td>Address Setup Time</td>
<td>30 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>tsu(CE)</td>
<td>tELWL</td>
<td>CE Setup Time before WE</td>
<td>0 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>trec(WE)</td>
<td>tWMAX</td>
<td>Write Recovery Time</td>
<td>30 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>th(CE)</td>
<td>tGHEH</td>
<td>CE Hold following WE</td>
<td>20 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>tv(WT-WE)</td>
<td>tWLWTv</td>
<td>Wait Delay Falling from WE</td>
<td>35 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>tv(WT)</td>
<td>tWTHWH</td>
<td>WE High from Wait Release</td>
<td>0 ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>tw(WT)</td>
<td>tWLWTH</td>
<td>Wait Width Time</td>
<td>350 ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Note: The maximum load on -WAIT is 1 LSTTL with 50 pF total load. The -WAIT signal may be ignored if the -WE cycle to cycle time is greater than the Wait Width time. The Max Wait Width time can be determined from the Card Information Structure. The Wait Width time meets the PCMCIA specification of 12µs but is intentionally less in this specification.
Figure 7. I/O Read Timing Diagram

![I/O Read Timing Diagram](image)

Note: D\textsubscript{OUT} signifies data provided by the CompactFlash Memory Card or CF+ Card to the system.

Table 19. I/O Read Timing

<table>
<thead>
<tr>
<th>Symbol</th>
<th>IEEE Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>td(IORD)</td>
<td>t\textsubscript{DHQV}</td>
<td>Data Delay after IORD</td>
<td>100</td>
<td>100</td>
<td>ns</td>
</tr>
<tr>
<td>th(IORD)</td>
<td>t\textsubscript{DHQX}</td>
<td>Data Hold following IORD</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>tw(IORD)</td>
<td>t\textsubscript{DGLIGH}</td>
<td>IORD Width Time</td>
<td>165</td>
<td>165</td>
<td>ns</td>
</tr>
<tr>
<td>tsuA(IORD)</td>
<td>t\textsubscript{AVGCL}</td>
<td>Address Setup before IORD</td>
<td>70</td>
<td>70</td>
<td>ns</td>
</tr>
<tr>
<td>thA(IORD)</td>
<td>t\textsubscript{DGHAX}</td>
<td>Address Hold following IORD</td>
<td>20</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>tsuCE(IORD)</td>
<td>t\textsubscript{ELGCL}</td>
<td>CE Setup before IORD</td>
<td>5</td>
<td>5</td>
<td>ns</td>
</tr>
<tr>
<td>thCE(IORD)</td>
<td>t\textsubscript{DGHHE}</td>
<td>CE Hold following IORD</td>
<td>20</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>tsuREG(IORD)</td>
<td>t\textsubscript{GLGCL}</td>
<td>REG Setup before IORD</td>
<td>5</td>
<td>5</td>
<td>ns</td>
</tr>
<tr>
<td>thREG(IORD)</td>
<td>t\textsubscript{DHGRI}</td>
<td>REG Hold following IORD</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>td\textsubscript{INPACK}(IORD)</td>
<td>t\textsubscript{DHLAL}</td>
<td>INPACK Delay Falling from IORD</td>
<td>0</td>
<td>45</td>
<td>ns</td>
</tr>
<tr>
<td>td\textsubscript{INPACK}(IORD)</td>
<td>t\textsubscript{DHIAH}</td>
<td>INPACK Delay Rising from IORD</td>
<td>45</td>
<td>45</td>
<td>ns</td>
</tr>
<tr>
<td>t\textsubscript{dIISO16}(A)</td>
<td>t\textsubscript{AVSL}</td>
<td>IOIS16 Delay Falling from Address</td>
<td>35</td>
<td>35</td>
<td>ns</td>
</tr>
<tr>
<td>t\textsubscript{dIISO16}(A)</td>
<td>t\textsubscript{AVSH}</td>
<td>IOIS16 Delay Rising from Address</td>
<td>35</td>
<td>35</td>
<td>ns</td>
</tr>
<tr>
<td>td\textsubscript{WT}(IORD)</td>
<td>t\textsubscript{DLWTCL}</td>
<td>Wait Delay Falling from IORD</td>
<td>35</td>
<td>35</td>
<td>ns</td>
</tr>
<tr>
<td>td(WT)</td>
<td>t\textsubscript{WHTOV}</td>
<td>Data Delay from Wait Rising</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>tw(WT)</td>
<td>t\textsubscript{WTLWTH}</td>
<td>Wait Width Time</td>
<td>350 (3000 for CF+)</td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

Note: Maximum load on -WAIT, -INPACK and -IISO16 is 1 LSTTL with 50 pF total load. Minimum time from -WAIT High to -IORD High is 0 ns, but minimum -IORD width must still be met. Wait Width time meets PCMCIA specification of 12 µs but is intentionally less in this spec.
Figure 8. I/O Write Timing Diagram

Table 20. I/O Write Timing

<table>
<thead>
<tr>
<th>Symbol</th>
<th>IEEE Symbol</th>
<th>Parameter</th>
<th>Min. (ns)</th>
<th>Max. (ns)</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>tsu(IOWR)</td>
<td>tQVIWH</td>
<td>Data Setup before IOWR</td>
<td>60</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>th(IOWR)</td>
<td>tIWHQX</td>
<td>Data Hold following IOWR</td>
<td>30</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tw(IOWR)</td>
<td>tIWLIWH</td>
<td>IOWR Width Time</td>
<td>165</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tsuA(IOWR)</td>
<td>tAVIWL</td>
<td>Address Setup before IOWR</td>
<td>70</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>thA(IOWR)</td>
<td>tIWHAX</td>
<td>Address Hold following IOWR</td>
<td>20</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tsuCE(IOWR)</td>
<td>tELIWL</td>
<td>CE Setup before IOWR</td>
<td>5</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>thCE(IOWR)</td>
<td>tIWHEH</td>
<td>CE Hold following IOWR</td>
<td>20</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tsuREG(IOWR)</td>
<td>tIQLIWL</td>
<td>REG Setup before IOWR</td>
<td>5</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>thREG(IOWR)</td>
<td>tIWHRGH</td>
<td>REG Hold following IOWR</td>
<td>0</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tdfIOIS16(A)</td>
<td>tAVISL</td>
<td>IOIS16 Delay Falling from Address</td>
<td>35</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tdrIOIS16(A)</td>
<td>tAVISH</td>
<td>IOIS16 Delay Rising from Address</td>
<td>35</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tdWT(IOWR)</td>
<td>tIWLWTL</td>
<td>Wait Delay Falling from IOWR</td>
<td>35</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tdrIOWR(WT)</td>
<td>tWTHIWH</td>
<td>IOWR High from Wait High</td>
<td>0</td>
<td></td>
<td>ns</td>
</tr>
<tr>
<td>tw(WT)</td>
<td>tWTLWTH</td>
<td>Wait Width Time</td>
<td>350 (3000 for CF+)</td>
<td></td>
<td>ns</td>
</tr>
</tbody>
</table>

Note: The maximum load on -WAIT, -INPACK, and -IOIS16 is 1 LS1TL with b16F total load. Minimum time from -WAIT High to -IOWR High is 0 ns, but minimum -IOWR width must still be met. The Wait Width time meets the PCMCIA specification of 12 µs but is intentionally less in this specification.
The timing diagram for True IDE mode of operation in this section is drawn using the conventions in the ATA-4 specification, which are different than the conventions used in the PCMCIA specification and earlier versions of this specification. Signals are shown with their asserted state as High regardless of whether the signal is actually negative or positive true. Consequently, the -IORD, the -IOWR and the -IOCS16 signals are shown in the diagram inverted from their electrical states on the bus.

Figure 9. True IDE Mode I/O Timing Diagram

Note: 1. The device addresses consists of −CS0, −CS1, and A2-A0.
2. The Data I/O consist of D15-D0 (16-bit) or D7-D0 (8 bit).
3. −IOCS16 is shown for PIO modes 0, 1 and 2. For other modes, this signal is ignored.
4. The device drives IORDY Low to extend the PIO cycle. The determination of whether the cycle is to be extended is made by the host tA after −IORD or −IOWR has been asserted. IORDY can be asserted and de-asserted as described in the following three cases:
   (4-1) The device never drives IORDY Low (IORDY remains asserted): No wait is generated.
   (4-2) The device starts to drive IORDY Low before/during tA, but re-asserts IORDY before tA has elapsed. No wait is generated.
   (4-3) The device drives IORDY Low before/during tA and IORDY remains Low after tA has elapsed: a wait is generated. The cycle completes after IORDY is re-asserted. For cycles where a wait is generated and −IORD is asserted, the device must place the read data on D15-D0 tRD before re-asserting IORDY.
Table 21. True IDE Mode I/O Read/Write Timing Diagram

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter(1)</th>
<th>Mode 0</th>
<th>Mode 1</th>
<th>Mode 2</th>
<th>Mode 3</th>
<th>Mode 4</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>t_0(2)</td>
<td>Cycle time (min)</td>
<td>600</td>
<td>383</td>
<td>240</td>
<td>180</td>
<td>120</td>
<td>ns</td>
</tr>
<tr>
<td>t_1</td>
<td>Address Valid to -IORD/-IOWR setup (min)</td>
<td>70</td>
<td>50</td>
<td>30</td>
<td>30</td>
<td>25</td>
<td>ns</td>
</tr>
<tr>
<td>t_2(2)</td>
<td>-IORD/-IOWR (min)</td>
<td>165</td>
<td>125</td>
<td>100</td>
<td>80</td>
<td>70</td>
<td>ns</td>
</tr>
<tr>
<td>t_2(2)</td>
<td>-IORD/-IOWR (min) Register (8 bit)</td>
<td>290</td>
<td>290</td>
<td>290</td>
<td>80</td>
<td>70</td>
<td>ns</td>
</tr>
<tr>
<td>t_3</td>
<td>-IORD data setup (min)</td>
<td>60</td>
<td>45</td>
<td>30</td>
<td>30</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>t_4</td>
<td>-IOWR data hold (min)</td>
<td>30</td>
<td>20</td>
<td>15</td>
<td>10</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td>t_5</td>
<td>-IORD data setup (min)</td>
<td>50</td>
<td>35</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>t_6</td>
<td>-IORD data hold (min)</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>ns</td>
</tr>
<tr>
<td>t_6Z(3)</td>
<td>-IORD data tri-state (max)</td>
<td>30</td>
<td>30</td>
<td>30</td>
<td>30</td>
<td>30</td>
<td>ns</td>
</tr>
<tr>
<td>t_7(5)</td>
<td>Address valid to -IOCS16 assertion (max)</td>
<td>90</td>
<td>50</td>
<td>40</td>
<td>N/A</td>
<td>N/A</td>
<td>ns</td>
</tr>
<tr>
<td>t_8(5)</td>
<td>Address valid to -IOCS16 released (max)</td>
<td>60</td>
<td>45</td>
<td>30</td>
<td>N/A</td>
<td>N/A</td>
<td>ns</td>
</tr>
<tr>
<td>t_9</td>
<td>-IORD/-IOWR to address valid hold</td>
<td>20</td>
<td>15</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td>t_RD</td>
<td>Read Data Valid to IORDY active (min), if IORDY initially Low after t_A</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>ns</td>
</tr>
<tr>
<td>t_A(4)</td>
<td>IORDY Setup time</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>35</td>
<td>ns</td>
</tr>
<tr>
<td>t_B</td>
<td>IORDY Pulse Width (max)</td>
<td>1250</td>
<td>1250</td>
<td>1250</td>
<td>1250</td>
<td>1250</td>
<td>ns</td>
</tr>
<tr>
<td>t_C</td>
<td>IORDY assertion to release (max)</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>5</td>
<td>ns</td>
</tr>
</tbody>
</table>

Note: 1. The maximum load on -IOCS16 is 1 LSTTL with a 50pF total load. Minimum time from -IORDY High to -IORD High is 0ns, but minimum -IORD width must still be met.
2. t_0 is the minimum total cycle time, t_2 is the minimum command active time, and t_3 is the minimum command recovery time or command inactive time. The actual cycle time equals the sum of the actual command active time and the actual command inactive time. The three timing requirements of t_0, t_2, and t_3 have to be met. The minimum total cycle time requirement is greater than the sum of t_2 and t_3. This means a host implementation can lengthen either or both t_2 or t_3 to ensure that t_0 is equal to or greater than the value reported in the device’s identify drive data. A CompactFlash Memory Card implementation should support any legal host implementation.
3. This parameter specifies the time from the falling edge of -IORD to the moment when the data bus is no longer driven by the CompactFlash Memory Card (tri-state).
4. The delay from the activation of -IORD or -IOWR to the first time the state of IORDY is sampled. If IORDY is inactive then the host will have to wait until IORDY is active before the PIO cycle can be completed. If the CompactFlash Memory Card is not driving IORDY Low during t_4 after the activation of -IORD or -IOWR, then t_5 shall be met and t_5 is not applicable. If the CompactFlash Memory Card is driving IORDY Low during t_4 after the activation of -IORD or -IOWR, then t_5 shall be met and t_5 is not applicable.
5. t_7 and t_8 apply only to modes 0, 1 and 2. This signal is not valid for other modes.
Card Configuration

The CompactFlash Memory Card is identified by information in the Card Information Structure (CIS). The Card has four configuration registers (Tables 22 and 23).

- Configuration Option Register
- Pin Replacement Register
- Card Configuration and Status Register
- Socket and Copy Register

They are used to coordinate the I/O spaces and the interrupt level of cards that are located in the system. In addition, in I/O card mode these registers provide a method for accessing status information that would normally appear on dedicated pins in memory card mode. The location of the card configuration registers should always be read from the CIS. These registers cannot be used in True IDE mode.

No writes should be performed to the attribute memory except to the configuration register addresses. All other attribute memory locations are reserved. See the section 'Attribute Memory Function'.

### Table 22. CompactFlash Memory Card Registers and Memory Space Decoding

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>Standby</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>0</td>
<td>Configuration Registers Read</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>Common Memory Read (D7 to D0)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
<td>Common Memory Read (D15 to D8)</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td>Common Memory Read (D15 to D0)</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>0</td>
<td>Configuration Registers Write</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td>Common Memory Write (D7 to D0)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td>Common Memory Write (D15 to D8)</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td>Common Memory Write (D15 to D0)</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>0</td>
<td>Card Information Structure Read</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td>Invalid Access (CIS Write)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>Invalid Access (Odd Attribute Read)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td>Invalid Access (Odd Attribute Write)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td>Invalid Access (Odd Attribute Read)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>XXX</td>
<td>XX</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td>Invalid Access (Odd Attribute Write)</td>
</tr>
</tbody>
</table>

### Table 23. CompactFlash Memory Card Configuration Registers Decoding

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>00</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Configuration Option Register Read</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>00</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Configuration Option Register Write</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>00</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Card Status Register Read</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>00</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Card Status Register Write</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>00</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Pin Replacement Register Read</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>00</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Pin Replacement Register Write</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>00</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Socket and Copy Register Read</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>00</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Socket and Copy Register Write</td>
</tr>
</tbody>
</table>
Configuration Option Register (Base + 00h in Attribute Memory)
The Configuration Option Register is used to configure the Card’s interface, address decoding and interrupt to the Card (see Table 24.).

Conf5 - Conf0 (Configuration Index). These bits are used to select the operation mode of the Card as shown in Table 25. This bit is set to ‘0’ by Reset.

Table 24. Configuration Option Register (default value: 00h)

<table>
<thead>
<tr>
<th>Operation</th>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>R/W</td>
<td>x</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>LevIREQ</td>
<td>Conf5</td>
<td>Conf4</td>
<td>Conf3</td>
<td>Conf2</td>
<td>Conf1</td>
<td>Conf0</td>
</tr>
</tbody>
</table>

Table 25. CompactFlash Memory Card Configurations

<table>
<thead>
<tr>
<th>Conf5</th>
<th>Conf4</th>
<th>Conf3</th>
<th>Conf2</th>
<th>Conf1</th>
<th>Conf0</th>
<th>Mapping Mode</th>
<th>Card Mode</th>
<th>Task File Register Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Memory</td>
<td>Memory</td>
<td>0h - Fh, 400h - 7FFh</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Contiguous I/O</td>
<td>I/O</td>
<td>xx0h - xxFh</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Primary I/O</td>
<td>I/O</td>
<td>1F0h - 1F7h, 3F6h - 3F7h</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Secondary I/O</td>
<td>I/O</td>
<td>170h - 177h, 376h - 377h</td>
</tr>
</tbody>
</table>

Card Configuration and Status Register (Base + 02h in Attribute Memory)
The Card Configuration and Status Register contains information about the Card’s status (see Table 26.).

Changed. Indicates that one or both of the Pin Replacement register (CRDY, or CWProt) bits are set to ‘1’. When the Changed bit is set, –STSCHG (Pin 46) is held Low and if the SigChg bit is ‘1’ the Card is configured for the I/O interface.

SigChg. This bit is set and reset by the host to enable and disable a state-change signal from the Status Register (issued on Status Changed pin 46). If no state change signal is desired, this bit should be set to ‘0’ and pin 46 (~STSCHG) will be held High while the Card is configured for I/O.

IOIs8. The host sets this bit to ‘1’ if the Card is to be configured in 8 bit I/O Mode. The Card is always configured for both 8 and 16 bit I/O, so this bit is ignored.

-XE. This bit is set and reset by the host to disable and enable Power Level 1 commands in CF+ cards. In the Compact Flash Card this bit has value ‘0’ and is not writable.

Audio. This bit is set and reset by the host to enable and disable audio information on -SPKR when the CF+ card is configured. This bit should always be ‘0’ for CompactFlash Memory Cards.

PwrDwn. This bit indicates whether the Card is in the power saving mode or active mode. When the PwrDwn bit is set to ‘1’, the Card enters power down mode. When set to ‘0’, the Card enters active mode. The READY value on Pin Replacement Register becomes BUSY when this bit is changed. READY will not become Ready until the power state requested has been entered. The Card automatically powers down when it is idle and powers back up when it receives a command.

Int. This bit represents the internal state of the interrupt request. It is available whether or not the I/O interface has been configured. It remains valid 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 ‘0’.

Table 26. Card Configuration and Status Register (default value: 00h)

<table>
<thead>
<tr>
<th>Operation</th>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>Changed</td>
<td>SigChg</td>
<td>IOIs8</td>
<td>-XE</td>
<td>Audio</td>
<td>PwrDwn</td>
<td>Int</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>SigChg</td>
<td>IOIs8</td>
<td>-XE</td>
<td>Audio</td>
<td>PwrDwn</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>
Pin Replacement Register (Base + 04h in Attribute Memory)

This register contains information on the state of the READY signal when configured in memory mode and the IREQ signal in I/O mode. See Tables 27 and 28.

CReady. This bit is set to ‘1’ when the bit RReady changes state. This bit can also be written by the host.

CWProt. This bit is set to ‘1’ when the bit RWProt changes state. This bit can also be written by the host.

RReady. This bit is used to determine the internal state of the Ready signal. In I/O mode it is used as an interrupt request. When written, this bit acts as a mask (MReady) for writing the corresponding CReady.

WProt. This bit is always ‘0’ since the Compact-Flash Memory Card or CF+ Card does not have a Write Protect switch. When written, this bit acts as a mask for writing the corresponding CWProt bit.

MReady. This bit acts as a mask for writing the corresponding CReady bit.

MWProt. This bit when written acts as a mask for writing the corresponding CWProt bit.

Table 27. Pin Replacement Register (default value: 0Ch)

<table>
<thead>
<tr>
<th>Operation</th>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>0</td>
<td>0</td>
<td>CReady</td>
<td>CWProt</td>
<td>1</td>
<td>1</td>
<td>RReady</td>
<td>WProt</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>CReady</td>
<td>CWProt</td>
<td>0</td>
<td>0</td>
<td>RReady</td>
<td>MWProt</td>
</tr>
</tbody>
</table>

Table 28. Pin Replacement Changed Bit/Mask Bit Values

<table>
<thead>
<tr>
<th>Initial Value of ‘C’ Status</th>
<th>Written by Host</th>
<th>Final ‘C’ Bit</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>‘C’ Bit</td>
<td>‘M’ Bit</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>X</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>X</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

Socket and Copy Register (Base + 06h in Attribute Memory)

This register contains additional configuration information which identifies the Card from other cards. This register is always written by the system before writing the Configuration Option Register (see Table 29.).

Drive # This value can be used to address two different cards in the case of twin card configuration. X, the socket number is ignored by the card.

Table 29. Socket and Copy Register (default value: 00h)

<table>
<thead>
<tr>
<th>Operation</th>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>Reserved</td>
<td>0</td>
<td>0</td>
<td>Drive #</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Write</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Drive #</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
</tbody>
</table>
Attribute Memory Function
Attribute memory is a space where identification and configuration information are stored, and is limited to 8 bit wide accesses at even addresses. The card configuration registers are also located here, the base address of the configuration registers is 200h. For the Attribute Memory Read function, signals –REG and –OE must be active and –WE inactive during the cycle. As in the Main Memory Read functions, the signals –CE1 and –CE2 control the even and odd Byte address, but only the even Byte data is valid during the Attribute Memory access. Refer to Table 30. for signal states and bus validity.

Table 30. Attribute Memory Function

<table>
<thead>
<tr>
<th>Function Mode</th>
<th>–REG</th>
<th>–CE2</th>
<th>–CE1</th>
<th>A10</th>
<th>A9</th>
<th>A0</th>
<th>–OE</th>
<th>–WE</th>
<th>D15 to D8</th>
<th>D7 to D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standby</td>
<td>X</td>
<td>H</td>
<td>H</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>High-Z</td>
<td>High-Z</td>
</tr>
<tr>
<td>Read Byte Access CIS (8 bits)</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>High-Z</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Write Byte Access CIS (8 bits)</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>Don’t Care</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Write Byte Access Configuration (8 bits)</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>High-Z</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Read Byte Access Configuration CF+ (8 bits)</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>X</td>
<td>X</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>High-Z</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Write Byte Access Configuration CF+ (8 bits)</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>X</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>Don’t Care</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Read Word Access CIS (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Not Valid</td>
<td>Even Byte</td>
<td></td>
</tr>
<tr>
<td>Write Word Access CIS (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>H</td>
<td>L</td>
<td>Don’t Care</td>
<td>Even Byte</td>
<td></td>
</tr>
<tr>
<td>Read Word Access Configuration (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Not Valid</td>
<td>Even Byte</td>
<td></td>
</tr>
<tr>
<td>Write Word Access Configuration (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>X</td>
<td>H</td>
<td>L</td>
<td>Don’t Care</td>
<td>Even Byte</td>
<td></td>
</tr>
<tr>
<td>Read Word Access Configuration CF+ (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Not Valid</td>
<td>Even Byte</td>
<td></td>
</tr>
<tr>
<td>Write Word Access Configuration CF+ (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>H</td>
<td>L</td>
<td>Don’t Care</td>
<td>Even Byte</td>
</tr>
</tbody>
</table>

Note: The –CE signal or both the –OE signal and the –WE signal must be de-asserted between consecutive cycle operations.
I/O Transfer Function
The I/O transfer to or from the Card can be either 8 or 16 bits. When a 16 bit accessible port is addressed, the –IOIS16 signal is asserted by the Card, otherwise it is de-asserted. When a 16 bit transfer is attempted, and the –IOIS16 signal is not asserted, the system must generate a pair of 8 bit references to access the Word’s even and odd Bytes. The Card permits both 8 and 16 bit accesses to all of its I/O addresses, so –IOIS16 is asserted for all addresses. The Card may request the host to extend the length of an input cycle until data is ready by first asserting –WAIT (see Table 31.).

Table 31. I/O Function

<table>
<thead>
<tr>
<th>Function Code</th>
<th>–REG</th>
<th>–CE2</th>
<th>–CE1</th>
<th>A0</th>
<th>–IORD</th>
<th>–IOWR</th>
<th>D15 to D8</th>
<th>D7 to D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standby Mode</td>
<td>X</td>
<td>H</td>
<td>H</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>High Z</td>
<td>High Z</td>
</tr>
<tr>
<td>Byte Input Access (8 bits)</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>High Z</td>
<td>Even Byte Odd Byte</td>
</tr>
<tr>
<td>Byte Output Access (8 bits)</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>H</td>
<td>H</td>
<td>L</td>
<td>Don’t Care Odd Byte</td>
</tr>
<tr>
<td>Word Input Access (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>Odd Byte</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Word Output Access (16 bits)</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>H</td>
<td>Odd Byte</td>
<td>Even Byte</td>
</tr>
<tr>
<td>I/O Read Inhibit</td>
<td>H</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Don’t Care Don’t Care</td>
<td></td>
</tr>
<tr>
<td>I/O Write Inhibit</td>
<td>H</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>H</td>
<td>L</td>
<td>High Z</td>
<td>High Z</td>
</tr>
<tr>
<td>High Byte Input Only (8 bits)</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Od even Byte High Z</td>
<td></td>
</tr>
<tr>
<td>High Byte Output Only (8 bits)</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Odd Byte</td>
<td>Don’t Care</td>
</tr>
</tbody>
</table>

Common Memory Transfer Function
The Common Memory transfer to or from the Card permits both 8 or 16 bit access to all of the Common Memory addresses. The Card may request the host to extend the length of a memory read or write cycle by first asserting –WAIT (see Table 32.).

Table 32. Common Memory Function

<table>
<thead>
<tr>
<th>Function Code</th>
<th>–REG</th>
<th>–CE2</th>
<th>–CE1</th>
<th>A0</th>
<th>–OE</th>
<th>–WE</th>
<th>D15 to D8</th>
<th>D7 to D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standby Mode</td>
<td>X</td>
<td>H</td>
<td>H</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>High Z</td>
<td>High Z</td>
</tr>
<tr>
<td>Byte Read Access (8 bits)</td>
<td>H</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>High Z</td>
<td>Even Byte Odd Byte</td>
</tr>
<tr>
<td>Byte Write Access (8 bits)</td>
<td>H</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>Don’t Care Odd Byte</td>
<td></td>
</tr>
<tr>
<td>Word Read Access (16 bits)</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Odd Byte</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Word Write Access (16 bits)</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>H</td>
<td>L</td>
<td>Odd Byte</td>
<td>Even Byte</td>
</tr>
<tr>
<td>Odd Byte Read Only (8 bits)</td>
<td>H</td>
<td>L</td>
<td>H</td>
<td>X</td>
<td>L</td>
<td>H</td>
<td>Odd Byte</td>
<td>High Z</td>
</tr>
<tr>
<td>Odd Byte Write Only (8 bits)</td>
<td>H</td>
<td>L</td>
<td>H</td>
<td>X</td>
<td>H</td>
<td>L</td>
<td>Odd Byte</td>
<td>Don’t Care</td>
</tr>
</tbody>
</table>
**True IDE Mode I/O Function**

The Card can be configured in a True IDE Mode of operation. It is configured in this mode only when the –OE signal is grounded by the host during the power off to power on cycle. In this True IDE Mode the PCMCIA protocol and configuration are disabled and only I/O operations to the Task File and Data Register are allowed. No Memory or Attribute Registers are accessible to the host. The Set Feature Command can be used to put the device in 8 bit Mode (see Table 33.).

Removing and reinserting the Card while the host computer’s power is on will reconfigure the Card to PC Card ATA mode.

**Table 33. True IDE Mode I/O Function**

<table>
<thead>
<tr>
<th>Function Code</th>
<th>–CE2</th>
<th>–CE1</th>
<th>A2 to A0</th>
<th>–IORD</th>
<th>–IOWR</th>
<th>D15 to D8</th>
<th>D7 to D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Invalid Mode</td>
<td>L</td>
<td>L</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>High Z</td>
<td>High Z</td>
</tr>
<tr>
<td>Standby Mode</td>
<td>H</td>
<td>H</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>High Z</td>
<td>High Z</td>
</tr>
<tr>
<td>Task File Write</td>
<td>H</td>
<td>L</td>
<td>1h-7h</td>
<td>H</td>
<td>L</td>
<td>Don’t Care</td>
<td>Data In</td>
</tr>
<tr>
<td>Task File Read</td>
<td>H</td>
<td>L</td>
<td>1h-7h</td>
<td>L</td>
<td>H</td>
<td>High Z</td>
<td>Data Out</td>
</tr>
<tr>
<td>Data Register Write</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>L</td>
<td>Odd-Byte In</td>
<td>Even-Byte In</td>
</tr>
<tr>
<td>Data Register Read</td>
<td>H</td>
<td>L</td>
<td>L</td>
<td>H</td>
<td>H</td>
<td>Odd-Byte Out</td>
<td>Even-Byte Out</td>
</tr>
<tr>
<td>Control Register Write</td>
<td>L</td>
<td>H</td>
<td>6h</td>
<td>H</td>
<td>L</td>
<td>Don’t Care</td>
<td>Control In</td>
</tr>
<tr>
<td>Alternate Status Read</td>
<td>L</td>
<td>H</td>
<td>6h</td>
<td>L</td>
<td>H</td>
<td>High Z</td>
<td>Status Out</td>
</tr>
<tr>
<td>Drive Address</td>
<td>L</td>
<td>H</td>
<td>7h</td>
<td>L</td>
<td>H</td>
<td>High Z</td>
<td>Data Out</td>
</tr>
</tbody>
</table>
METAFORMAT

Overview
The goal of the Metaformat is to describe the requirements and capabilities of the CompactFlash Memory Card and CF+ Card as thoroughly as possible. This includes describing the power requirements, IO requirements, memory requirements, manufacturer information and details about the services provided.

The Metaformat is a hierarchy of layers where each layer is numbered with a number that increases with the level of abstraction.

Layers are also provided to describe the data recording format and data organization, for memory and ATA cards that wish to adhere to the CFA/PCMCIA specification.

Below the Metaformat there is the physical layer, which describes the electrical and physical characteristics of CF+ Cards.

The CF+ Metaformat conforms directly to the PCMCIA Metaformat Specification. Refer to that document for a detailed description of the Metaformat.

Requirements
CF+ Cards have the following Card Information Structure (CIS) requirements:

- All CF+ Cards have a CIS that describes the functionality and characteristics of the card.
- It should be possible to read the CIS of a CF+ Card whenever the card is powered, READY is being asserted and the card has been reset by the host after power-up in accordance with the CompactFlash Standard. This includes after the CF+ Card is configured and when the PwrDwn bit is set in the Card Configuration and Status Register. (See the Electrical Specification section.)
- All CF+ Cards should provide at least the mandatory Tuples as described in the PCMCIA Metaformat Specification, Tuple Summary Table.
- All linear memory CF+ Cards should describe how they are partitioned, even if the entire CF+ Card is used as a single partition.
SOFTWARE INTERFACE

CF-ATA Drive Register Set Definition and Protocol

The CompactFlash Memory Card can be configured as a high performance I/O device through:

- Standard PC-AT disk I/O address spaces
  - 1F0h-1F7h, 3F6h-3F7h (primary);
  - 170h-177h, 376h-377h (secondary) with IRQ 14 (or other available IRQ).
- Any system decoded 16 Byte I/O block using any available IRQ.
- Memory space.

Communication to or from the Card is done using the Task File registers which provide all the necessary registers for control and status information. The PCMCIA interface connects peripherals to the host using four-register mapping methods. Table 33. is a detailed description of these methods:

Table 34. I/O Configurations

<table>
<thead>
<tr>
<th>Config Index</th>
<th>I/O or Memory</th>
<th>Address</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Memory</td>
<td>0h-Fh, 400h-7FFh</td>
<td>Memory Mapped</td>
</tr>
<tr>
<td>1</td>
<td>I/O</td>
<td>xx0h-xxFh</td>
<td>I/O Mapped 16 Continuous Registers</td>
</tr>
<tr>
<td>2</td>
<td>I/O</td>
<td>1F0-1F7h, 3F6h-3F7h</td>
<td>Primary I/O Mapped</td>
</tr>
<tr>
<td>3</td>
<td>I/O</td>
<td>170-177h, 376h-377h</td>
<td>Secondary I/O Mapped</td>
</tr>
</tbody>
</table>

Memory Mapped Addressing (Conf = 0)

When the Card registers are accessed via memory references, the registers appear in the common memory space window: 0-2KBytes as shown in Table 35. This window accesses the Data Register FIFO. It does not allow random access to the data buffer within the Card.

Register 0 is accessed with –CE1 and –CE2 Low, as a Word register on the combined Odd and Even Data Bus (D15 to D0). It can also be accessed with –CE1 Low and –CE2 High, by a pair of Byte accesses to offset 0. The address space of this Word register overlaps the address space of the Error and Feature Bytewide registers at offset 1. When accessed twice as Byte register with –CE1 Low, the first Byte is the even Byte of the Word and the second is the odd Byte. A Byte access to address 0 with –CE1 High and –CE2 Low accesses the Error (read) or Feature (write) register.

Registers at offset 8, 9 and D are non-overlapping duplicates of the registers at offset 0 and 1. Register 8 is equivalent to register 0, while register 9 accesses the odd Byte. Therefore, if the registers are Byte accessed in the order 9 then 8 the data will be transferred odd Byte then even Byte. Repeated Byte accesses to register 8 or 0 will access consecutive (even then odd) Bytes from the data buffer. Repeated Word accesses to register 8, 9 or 0 will access consecutive Words from the data buffer, however repeated Byte accesses to register 9 are not supported. Repeated alternating Byte accesses to registers 8 then 9 will access consecutive (even then odd) Bytes from the data buffer.

Accesses to even addresses between 400h and 7FFh access register 8. Accesses to odd addresses between 400h and 7FFh access register 9. This 1 KByte memory window to the data register is provided so that hosts can perform memory-to-memory block moves to the data register when the register lies in memory space. Some hosts, such as the X86 processors, must increment both the source and destination addresses when executing the memory-to-memory block move instruction. Some PCMCIA socket adapters also have an embedded auto incrementing address logic.

A Word access to address at offset 8 will provide even data on the least significant Byte of the data bus, along with odd data at offset 9 on the most significant Byte of the data bus.
### Table 35. Memory Mapped Decoding

<table>
<thead>
<tr>
<th>REG</th>
<th>A10</th>
<th>A9 to A4</th>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
<th>Offset</th>
<th>−OE=0</th>
<th>−WE=0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0h</td>
<td>Even Data Register</td>
<td>Even Data Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1h</td>
<td>Error Register</td>
<td>Feature Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>2h</td>
<td>Sector Count Register</td>
<td>Sector Count Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>3h</td>
<td>Sector Number Register</td>
<td>Sector Number Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>4h</td>
<td>Cylinder Low Register</td>
<td>Cylinder Low Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>5h</td>
<td>Cylinder High Register</td>
<td>Cylinder High Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>6h</td>
<td>Select Card/Head Register</td>
<td>Select Card/Head Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>7h</td>
<td>Status Register</td>
<td>Command Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>8h</td>
<td>Dup. Even Data Register</td>
<td>Dup. Even Data Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>9h</td>
<td>Dup. Odd Data Register</td>
<td>Dup. Odd Data Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Dh</td>
<td>Dup. Error Register</td>
<td>Dup. Feature Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Eh</td>
<td>Alternate Status Register</td>
<td>Device Control Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Fh</td>
<td>Drive Address Register</td>
<td>Reserved</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>0</td>
<td>8h</td>
<td>Even Data Register</td>
<td>Even Data Register</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>9h</td>
<td>Odd Data Register</td>
<td>Odd Data Register</td>
</tr>
</tbody>
</table>
Contiguous I/O Mapped Addressing (Conf = 1)

When the system decodes a contiguous block of I/O registers to select the Card, the registers are accessed in the block of I/O space decoded by the system as shown in Table 36.

As for the Memory Mapped Addressing, register 0 is accessed with –CE1 Low and –CE2 Low (and A0 don’t Care) as a Word register on the combined Odd and Even Data Bus (D15 to D0). This register may also be accessed with –CE1 Low and –CE2 High, by a pair of Byte accesses to offset 0. The address space of this Word register overlaps the address space of the Error and Feature Bytewide registers at offset 1. When accessed twice as Byte register with –CE1 Low, the first Byte is the even Byte of the Word and the second is the odd Byte. A Byte access to register 0 with –CE1 High and –CE2 Low accesses the error (read) or feature (write) register.

Registers at offset 8, 9 and D are non-overlapping duplicates of the registers at offset 0 and 1. Register 8 is equivalent to register 0, while register 9 accesses the odd Byte. Therefore, if the registers are Byte accessed in the order 9 then 8 the data will be transferred odd Byte then even Byte. Repeated Byte accesses to register 8 or 0 will access consecutive (even than odd) Bytes from the data buffer. Repeated Word accesses to register 8, 9 or 0 will access consecutive Words from the data buffer, however repeated Byte accesses to register 9 are not supported. Repeated alternating Byte accesses to registers 8 then 9 will access consecutive (even then odd) Bytes from the data buffer.

Table 36. Contiguous I/O Decoding

<table>
<thead>
<tr>
<th>REG</th>
<th>A10 to A4</th>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
<th>Offset</th>
<th>IORD=0</th>
<th>IOWR=0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0h</td>
<td>Even Data Register</td>
<td>Even Data Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1h</td>
<td>Error Register</td>
<td>Feature Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>2h</td>
<td>Sector Count Register</td>
<td>Sector Count Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>3h</td>
<td>Sector Number Register</td>
<td>Sector Number Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>4h</td>
<td>Cylinder Low Register</td>
<td>Cylinder Low Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>5h</td>
<td>Cylinder High Register</td>
<td>Cylinder High Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>6h</td>
<td>Select Card/Head Register</td>
<td>Select Card/Head Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>7h</td>
<td>Status Register</td>
<td>Command Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>8h</td>
<td>Dup. Even Data Register</td>
<td>Dup. Even Data Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>9h</td>
<td>Dup. Odd Data Register</td>
<td>Dup. Odd Data Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Dh</td>
<td>Dup. Error Register</td>
<td>Dup. Feature Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Eh</td>
<td>Alternate Status Register</td>
<td>Device Control Register</td>
</tr>
<tr>
<td>0</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Fh</td>
<td>Drive Address Register</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
I/O Primary and Secondary Address Configurations (Conf = 2,3)
When the system decodes the Primary and Secondary Address Configurations, the registers are accessed in the block of I/O space as shown in Table 37.
As for the Memory Mapped Addressing, register 0 is accessed with –CE1 Low and –CE2 Low (and A0 don’t Care) as a Word register on the combined Odd and Even Data Bus (D15 to D0). This register may also be accessed with –CE1 Low and –CE2 High, by a pair of Byte accesses to offset 0. The address space of this Word register overlaps the address space of the Error and Feature ByteWide registers at offset 1. When accessed twice as Byte register with –CE1 Low, the first Byte is the even Byte of the Word and the second is the odd Byte. A Byte access to register 0 with –CE1 High and –CE2 Low accesses the error (read) or feature (write) register.

Table 37. Primary and Secondary I/O Decoding

<table>
<thead>
<tr>
<th>REG</th>
<th>A9 to A4</th>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
<th>—IORD=0</th>
<th>—IOWR=0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Even Data Register</td>
<td>Even Data Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Error Register</td>
<td>Feature Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Sector Count Register</td>
<td>Sector Count Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Sector Number Register</td>
<td>Sector Number Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Cylinder Low Register</td>
<td>Cylinder Low Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Cylinder High Register</td>
<td>Cylinder High Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Select Card/Head Register</td>
<td>Select Card/Head Register</td>
</tr>
<tr>
<td>0</td>
<td>1F(17)h</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Status Register</td>
<td>Command Register</td>
</tr>
<tr>
<td>0</td>
<td>3F(37)h</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Alternate Status Register</td>
<td>Device Control Register</td>
</tr>
<tr>
<td>0</td>
<td>3F(37)h</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Drive Address Register</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

True IDE Mode Addressing
When the Card is configured in the True IDE Mode, the I/O decoding is as shown in Table 38.

Table 38. True IDE Mode I/O Decoding

<table>
<thead>
<tr>
<th>—CE2</th>
<th>—CE1</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
<th>—IORD=0</th>
<th>—IOWR=0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Data Register</td>
<td>Data Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Error Register</td>
<td>Feature Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Sector Count Register</td>
<td>Sector Count Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Sector Number Register</td>
<td>Sector Number Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Cylinder Low Register</td>
<td>Cylinder Low Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Cylinder High Register</td>
<td>Cylinder High Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Select Card/Head Register</td>
<td>Select Card/Head Register</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Status Register</td>
<td>Command Register</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Alternate Status Register</td>
<td>Device Control Register</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Drive Address</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
SMCxxxAF

CF-ATA REGISTERS

The following section describes the hardware registers used by the host software to issue commands to the Card. These registers are collectively referred to as the ‘task file’.

Data Register (Address 1F0h [170h]; Offset 0, 8, 9)

The Data Register is a 16 bit register used to transfer data blocks between the Card data buffer and the Host. This register overlaps the Error Register. Table 39 describes the combinations of Data register access and explains the overlapped Data and Error/Feature Registers. Because of the overlapped registers, access to the 1F1h, 171h or offset 1 are not defined for Word (–CE2 and –CE1 set to ‘0’) operations, and are treated as accesses to the Word Data Register. The duplicated registers at offsets 8, 9 and Dh have no restrictions on the operations that can be performed.

Table 39. Data Register Access

<table>
<thead>
<tr>
<th>Data Register</th>
<th>–CE2</th>
<th>–CE1</th>
<th>A0</th>
<th>Offset</th>
<th>Data Bus</th>
</tr>
</thead>
<tbody>
<tr>
<td>Word Data Register</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>0, 8, 9</td>
<td>D15 to D0</td>
</tr>
<tr>
<td>Even Data Register</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0, 8</td>
<td>D7 to D0</td>
</tr>
<tr>
<td>Odd Data Register</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>9</td>
<td>D7 to D0</td>
</tr>
<tr>
<td>Odd Data Register</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>8, 9</td>
<td>D15 to D8</td>
</tr>
<tr>
<td>Error/Feature Register</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1, Dh</td>
<td>D7 to D0</td>
</tr>
<tr>
<td>Error/Feature Register</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>1</td>
<td>D15 to D8</td>
</tr>
<tr>
<td>Error/Feature Register</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>Dh</td>
<td>D15 to D8</td>
</tr>
</tbody>
</table>

Error Register (Address 1F1h [171h]; Offset 1, 0Dh Read Only)

This read only register contains additional information about the source of an error when an error is indicated in bit 0 of the Status register. The bits are defined in Table 40. This register is accessed on data bits D15 to D8 during a write operation to offset 0 with –CE2 Low and –CE1 High.

Bit 7 (BBK). This bit is set when a Bad Block is detected.

Bit 6 (UNC). This bit is set when an Uncorrectable Error is encountered.

Table 40. Error Register

<table>
<thead>
<tr>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>BBK</td>
<td>UNC</td>
<td>0</td>
<td>IDNF</td>
<td>0</td>
<td>ABRT</td>
<td>0</td>
<td>AMNF</td>
</tr>
</tbody>
</table>

Feature Register (Address 1F1h [171h]; Offset 1, 0Dh Write Only)

This write-only register provides information on features that the host can utilize. It is accessed on data bits D15 to D8 during a write operation to Offset 0 with –CE2 Low and –CE1 High.

Sector Count Register (Address 1F2h [172h]; Offset 2)

This register contains the number of sectors of data to be transferred on a read or write operation between the host and Card. If the value in this register is zero, a count of 256 sectors is specified. If the command was successful, this register is zero at completion. If not successfully completed, the register contains the number of sectors that need to be transferred in order to complete the request. The default value is 01h.
Sector Number (LBA 7-0) Register (Address 1F3h [173h]; Offset 3)
This register contains the starting sector number or bits 7 to 0 of the Logical Block Address (LBA), for any data access for the subsequent sector transfer command.

Cylinder Low (LBA 15-8) Register (Address 1F4h [174h]; Offset 4)
This register contains the least significant 8 bits of the starting cylinder address or bits 15 to 8 of the Logical Block Address.

Cylinder High (LBA 23-16) Register (Address 1F5h [175h]; Offset 5)
This register contains the most significant bits of the starting cylinder address or bits 23 to 16 of the Logical Block Address.

Drive/Head (LBA 27-24) Register (Address 1F6h [176h]; Offset 6)
The Drive/Head register is used to select the drive and head. It is also used to select LBA addressing instead of cylinder/head/sector addressing. The bits are defined in Table 41.

Bit 7. This bit is set to ‘1’.
Bit 6 (LBA). LBA is a flag to select either Cylinder/Head/Sector (CHS) or Logical Block Address Mode (LBA). When LBA is set to ‘0’, Cylinder/Head/Sector mode is selected. When LBA is set to ‘1’, Logical Block Address is selected. In Logical Block Mode, the Logical Block Address is interpreted as follows:
LBA7-LBA0: Sector Number Register D7 to D0.
LBA15-LBA8: Cylinder Low Register D7 to D0.
LBA23-LBA16: Cylinder High Register D7 to D0.
LBA27-LBA24: Drive/Head Register bits HS3 to HS0.

Bit 5. This bit is set to ‘1’.
Bit 4 (DRV). DRV is the drive number. When DRV is ‘0’, drive/card 0 is selected (Master). When DRV is ‘1’, drive/card 1 is selected (Slave). The Card is set to Card 0 or 1 using the copy field (Drive #) of the PCMCIA Socket & Copy configuration register.

Bit 3 (HS3). When operating in the Cylinder, Head, Sector mode, this is bit 3 of the head number. It is bit 27 in the Logical Block Address mode.

Bit 2 (HS2). When operating in the Cylinder, Head, Sector mode, this is bit 2 of the head number. It is bit 26 in the Logical Block Address mode.

Bit 1 (HS1). When operating in the Cylinder, Head, Sector mode, this is bit 1 of the head number. It is bit 25 in the Logical Block Address mode.

Bit 0 (HS0). When operating in the Cylinder, Head, Sector mode, this is bit 0 of the head number. It is Bit 24 in the Logical Block Address mode.

Table 41. Drive/Head Register

<table>
<thead>
<tr>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>DRV</td>
<td>HS3</td>
<td>HS2</td>
<td>HS1</td>
<td>HS0</td>
</tr>
</tbody>
</table>

Status & Alternate Status Registers (Address 1F7h [177h] & 3F6h [376h]; Offsets 7 & Eh)
These registers return the Card status when read by the host.

Reading the Status Register clears a pending interrupt. Reading the Auxiliary Status Register does not clear a pending interrupt.

The Status Register should be accessed in Byte mode; in Word mode it is recommended that Alternate Status Register is used. The status bits are described as follows.

Bit 7 (BUSY). The busy bit is set when only the Card can access the command register and buffer. The host is denied access. No other bits in this register are valid when this bit is set to ‘1’.

Bit 6 (RDY). This bit indicates whether the device is capable of performing CompactFlash Memory Card operations. This bit is cleared at power up and remains cleared until the Card is ready to accept a command.

Bit 5 (DWF). When set this bit indicates a Write Fault has occurred.

Bit 4 (DSC). This bit is set when the Card is ready.

Bit 3 (DRQ). The Data Request is set when the Card requires information be transferred either to or from the host through the Data register. The bit is cleared by the next command.

Bit 2 (CORR). This bit is set when a Correctable data error has been encountered and the data has been corrected. This condition does not terminate a multi-sector read operation.

Bit 1 (IDX). This bit is always set to ‘0’.

Bit 0 (ERR). This bit is set when the previous command has ended in some type of error. The bits in the Error register contain additional information describing the error. In case of read or write access commands that end with an error, the address of the first sector with an error is in the command block registers. This bit is cleared by the next command.
Table 42. Status & Alternate Status Register

<p>| | | | | | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>D7</td>
<td>D6</td>
<td>D5</td>
<td>D4</td>
<td>D3</td>
<td>D2</td>
<td>D1</td>
<td>D0</td>
<td></td>
</tr>
<tr>
<td>BUSY</td>
<td>RDY</td>
<td>DWF</td>
<td>DSC</td>
<td>DRQ</td>
<td>CORR</td>
<td>0</td>
<td>ERR</td>
<td></td>
</tr>
</tbody>
</table>

**Device Control Register (Address 3F6h [376h]; Offset Eh)**

This write-only register is used to control the CompactFlash Memory Card interrupt request. This register can be written even if the device is BUSY. The bits are defined as follows:

**Bit 7 to 2.** Don't care. The host should reset this bit to ‘0’.

**Bit 1 (–IEn).** When the Interrupt Enable bit is set to ‘0’, –IREQ interrupts are enabled. When the bit is set to ‘1’, interrupts from the Card are disabled. This bit also controls the Int bit in the and Status Register. It is set to ‘0’ at power on and Reset.

**Bit 0.** This bit is set to ‘0’.

Table 43. Device Control Register

<p>| | | | | | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>D7</td>
<td>D6</td>
<td>D5</td>
<td>D4</td>
<td>D3</td>
<td>D2</td>
<td>D1</td>
<td>D0</td>
<td></td>
</tr>
<tr>
<td>X(0)</td>
<td>X(0)</td>
<td>X(0)</td>
<td>X(0)</td>
<td>X(0)</td>
<td>X(0)</td>
<td>–IEn</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**Card (Drive) Address Register (Address 3F7h [377h]; Offset Fh)**

This read-only register is provided for compatibility with the AT disk drive interface and can be used for confirming the drive status. It is recommended that this register is not mapped into the host’s I/O space because of potential conflicts on Bit 7. The bits are defined as follows:

**Bit 7.** This bit is don’t care.

**Bit 6 (–WTG).** This bit is ‘0’ when a write operation is in progress, otherwise, it is ‘1’.

**Bit 5 (–HS3).** This bit is the negation of bit 3 in the Drive/Head register.

**Bit 4 (–HS2).** This bit is the negation of bit 2 in the Drive/Head register.

**Bit 3 (–HS1).** This bit is the negation of bit 1 in the Drive/Head register.

**Bit 2 (–HS0).** This bit is the negation of bit 0 in the Drive/Head register.

**Bit 1 (–nDS1).** This bit is ‘0’ when drive 1 is active and selected.

**Bit 0 (–nDS0).** This bit is ‘0’ when the drive 0 is active and selected.

Table 44. Card (Drive) Address Register

<p>| | | | | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>D7</td>
<td>D6</td>
<td>D5</td>
<td>D4</td>
<td>D3</td>
<td>D2</td>
<td>D1</td>
<td>D0</td>
</tr>
<tr>
<td>X</td>
<td>–WTG</td>
<td>–HS3</td>
<td>–HS2</td>
<td>–HS1</td>
<td>–HS0</td>
<td>–nDS1</td>
<td>–nDS0</td>
</tr>
</tbody>
</table>
CF-ATA COMMAND DESCRIPTION

This section defines the software requirements and the format of the commands the Host sends to the Card. Commands are issued to the Card by loading the required registers in the command block with the supplied parameters, and then writing the command code to the Command Register. There are three classes of command acceptance, all dependent on the host not issuing commands unless the Card is not busy (BSY is ‘0’).

- **Class 1.** Upon receipt of a Class 1 command, the Card sets BSY within 400ns.
- **Class 2.** Upon receipt of a Class 2 command, the Card sets BSY within 400ns, sets up the sector buffer for a write operation, sets DRQ within 700µs, and clears BSY within 400ns of setting DRQ.
- **Class 3.** Upon receipt of a Class 3 command, the Card sets BSY within 400ns, sets up the sector buffer for a write operation, sets DRQ within 20ms (assuming no re-assignments), and clears BSY within 400ns of setting DRQ.

For reasons of backward compatibility some commands are implemented as ‘no operation’ NOP.

Table 45. summarizes the CF-ATA command set with the paragraphs that follow describing the individual commands and the task file for each.
Table 45. CF-ATA Command Set

<table>
<thead>
<tr>
<th>Class</th>
<th>Command</th>
<th>Code</th>
<th>FR</th>
<th>SC</th>
<th>SN</th>
<th>CY</th>
<th>DH</th>
<th>LBA</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Check Power Mode</td>
<td>E5h or 98h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Execute Drive Diagnostic</td>
<td>90h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Erase Sector(s)</td>
<td>C0h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>1</td>
<td>Identify Drive</td>
<td>ECh</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Idle</td>
<td>E3h or 97h</td>
<td>Y</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Idle Immediate</td>
<td>E1h or 95h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Initialize Drive Parameters</td>
<td>91h</td>
<td>Y</td>
<td></td>
<td>Y</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>NOP</td>
<td>00h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Read Buffer</td>
<td>E4h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Read Multiple</td>
<td>C4h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Read Sector(s)</td>
<td>20h or 21h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Read Verify Sector(s)</td>
<td>40h or 41h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Recalibrate</td>
<td>1Xh</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Request Sense</td>
<td>03h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Seek</td>
<td>7Xh</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Set Features</td>
<td>EFh</td>
<td>Y</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Set Multiple Mode</td>
<td>C6h</td>
<td>Y</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Set Sleep Mode</td>
<td>E6h or 99h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Stand By</td>
<td>E2h or 96h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Stand By Immediate</td>
<td>E0h or 94h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Translate Sector</td>
<td>87h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>Wear Level</td>
<td>F5h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Write Buffer</td>
<td>E8h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Write Multiple</td>
<td>C5h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>Write Multiple w/o Erase</td>
<td>CDh</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>Write Sector(s)</td>
<td>30h or 31h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>2</td>
<td>Write Sector(s) w/o Erase</td>
<td>38h</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>3</td>
<td>Write Verify</td>
<td>3Ch</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
<td>Y</td>
</tr>
</tbody>
</table>

Note: FR = Features Register, SC = Sector Count Register, SN = Sector Number Register, CY = Cylinder Registers, DH = Card/Drive/Head Head Register, LBA = Logical Block Address Mode Supported (see command descriptions for use).

Y - The register contains a valid parameter for this command. For the Drive/Head Register Y means both the Compact Flash Memory Card and head parameters are used.

D - only the Compact Flash Memory Card parameter is valid and not the head parameter

C - the register contains command specific data (see command descriptors for use).
Check Power Mode (98h or E5h)
This command checks the power mode.
Issuing the command while the Card is in Standby mode, is about to enter Standby, or is exiting Standby, the command will set BSY, set the Sector Count Register to 00h, clear BSY and generate an interrupt.
Issuing the command when the Card is in Idle mode will set BSY, set the Sector Count Register to FFh, clear BSY and generate an interrupt. Table 46. defines the Byte sequence of the Check Power Mode command.

Table 46. Check Power Mode

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td>98h or E5h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Execute Drive Diagnostic (90h)
This command performs the internal diagnostic tests implemented by the Card.
In PCMCIA configuration, this command only runs on the Card which is addressed by the Drive/Head register when the command is issued. This is because PCMCIA card interface does not allow for direct inter-drive communication.
In True IDE Mode, the Drive bit is ignored and the diagnostic command is executed by both the Master and the Slave with the Master responding with the status for both devices. Table 47. defines the Execute Drive Diagnostic command Byte sequence. The Diagnostic codes shown in Table 48. are returned in the Error Register at the end of the command.

Table 47. Execute Drive Diagnostic

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td>90h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 48. Diagnostic Codes
Table 48. Diagnostic Codes

<table>
<thead>
<tr>
<th>Code</th>
<th>Error Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>01h</td>
<td>No Error Detected</td>
</tr>
<tr>
<td>02h</td>
<td>Formatter Device Error</td>
</tr>
<tr>
<td>03h</td>
<td>Sector Buffer Error</td>
</tr>
<tr>
<td>04h</td>
<td>ECC Circuitry Error</td>
</tr>
<tr>
<td>05h</td>
<td>Controlling Microprocessor Error</td>
</tr>
<tr>
<td>8Xh</td>
<td>Slave Error in True IDE Mode</td>
</tr>
</tbody>
</table>

Erase Sector(s) (C0h)
This command is used to pre-erase and condition data sectors prior to a Write Sector Without Erase command or a Write Multiple Without Erase command. There is no data transfer associated with this command but a Write Fault error status can occur. Table 49 defines the Byte sequence of the Erase Sector command.

Table 49. Erase Sector(s)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Command (7)</th>
<th>C/D/H (6)</th>
<th>Cyl High (5)</th>
<th>Cyl Low (4)</th>
<th>Sect Num (3)</th>
<th>Sect Cnt (2)</th>
<th>Feature (1)</th>
<th>Drive Head (LBA 27-24)</th>
<th>Cylinder High (LBA 23-16)</th>
<th>Cylinder Low (LBA 15-8)</th>
<th>Sector Number (LBA 7-0)</th>
<th>Sector Count</th>
</tr>
</thead>
</table>

Identify Drive (ECh)
The Identify Drive command enables the host to receive parameter information from the Card. This command has the same protocol as the Read Sector(s) command. Table 50 defines the Identify Drive command Byte sequence. All reserved bits or Words are zero. Table 51 shows the definition of each field in the Identify Drive Information.

Word 0: General Configuration. This field indicates that the device is a CompactFlash Memory Card.

Word 1: Default Number of Cylinders. This field contains the number of translated cylinders in the default translation mode. This value will be the same as the number of cylinders.

Word 3: Default Number of Heads. This field contains the number of translated heads in the default translation mode.

Word 6: Default Number of Sectors per Track. This field contains the number of sectors per track in the default translation mode.

Word 7-8: Number of Sectors per Card. This double Word value is also the first invalid address in LBA translation mode.

Word 10-19: Memory Card Serial Number. The contents of this field are right justified and padded with spaces (20h).

Word 23-26: Firmware Revision. This field contains the revision of the firmware for this product.

Word 27-46: Model Number. This field contains the model number for this product and is left justified and padded with spaces (20h).

Word 47: Read/Write Multiple Sector Count. This field contains the maximum number of sectors that can be read or written per interrupt using the Read Multiple or Write Multiple commands.

Word 49: Capabilities.
- Bit 13 Standby Timer
  is set to '0' to indicate that the Standby timer operation is defined by the manufacturer.
- Bit 11 IORDY Support
  is set to '0' to indicate that the Card may support IORDY operation.
Bit 10 IORDY may be disabled
   Is set to ‘0’ to indicate that IORDY may not
   be disabled.
Bit 9 LBA support
   CompactFlash Memory Cards support
   LBA mode addressing.
Bit 8 DMA Support
   DMA mode is not supported.

**Word 51: PIO Data Transfer Cycle Timing Mode.** This field defines the mode for PIO data transfer. For backward compatibility with BIOSs written before Word 64 was defined for advanced modes, a device reports in Word 51, the highest original PIO mode it can support (PIO mode 0, 1 or 2).

Bits 15-8: are set to 02H.

**Word 53: Translation Parameter Valid.**
   - Bit 1: is set to ‘1’ to indicate that Words 64 to 70 are valid
   - Bit 0: is set to ‘1’ to indicate that Words 54 to 58 are valid

**Word 54-56: Current Number of Cylinders, Heads, Sectors/Track.** These fields contains the current number of user addressable Cylinders, Heads, and Sectors/Track in the current translation mode.

**Word 57-58: Current Capacity.** This field contains the product of the current cylinders, heads and sectors.

**Word 59: Multiple Sector Setting.**
   - Bits 15-9 are reserved and must be set to ‘0’.
   - Bit 8 is set to ‘1’, to indicate that the Multiple Sector Setting is valid.

   - Bits 7-0 are the current setting for the number of sectors to be transferred for every interrupt, on Read/Write Multiple commands; the only values returned are 00h or 01h.

**Word 60-61: Total Sectors Addressable in LBA Mode.** This field contains the number of sectors addressable for the Card in LBA mode only.

**Word 64: Advanced PIO transfer modes supported.** This field is bit significant. Any number of bits may be set to ‘1’ in this field by the CompactFlash Memory Card to indicate the advanced PIO modes it is capable of supporting.
   - Bits 7-2 are reserved for future advanced PIO modes.
   - Bit 1 is set to ‘1’, indicates that the CompactFlash Memory Card supports PIO mode 4.
   - Bit 0 is set to ‘1’ to indicate that the CompactFlash Memory Card supports PIO mode 3.

**Word 67: Minimum PIO transfer cycle time without flow control.** This field gives the minimum cycle time (in ns) that the host should use for the CompactFlash Memory Card to provide data integrity during transfer when flow control is not used. The value returned is 78h (for Cycle time values refer to Table 21.)

**Word 68: Minimum PIO transfer cycle time with IORDY.** This field gives the minimum cycle time (in ns) supported by the CompactFlash Memory Card to perform data transfers using IORDY flow control. The value returned is 78h (for Cycle time values refer to Table 21.)

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>ECh</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
### Table 51. Identify Drive Information

<table>
<thead>
<tr>
<th>Word Address</th>
<th>Default Value</th>
<th>Total Bytes</th>
<th>Data Field Type Information</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>848Ah</td>
<td>2</td>
<td>General Configuration (signature for the CompactFlash Memory Card)</td>
</tr>
<tr>
<td>1</td>
<td>XXXXh</td>
<td>2</td>
<td>Default number of cylinders</td>
</tr>
<tr>
<td>2</td>
<td>0000h</td>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>3</td>
<td>00XXh</td>
<td>2</td>
<td>Default number of heads</td>
</tr>
<tr>
<td>4</td>
<td>0000h</td>
<td>2</td>
<td>Obsolete</td>
</tr>
<tr>
<td>5</td>
<td>0000h</td>
<td>2</td>
<td>Obsolete</td>
</tr>
<tr>
<td>6</td>
<td>XXXXh</td>
<td>2</td>
<td>Default number of sectors per track</td>
</tr>
<tr>
<td>7-8</td>
<td>XXXXh</td>
<td>4</td>
<td>Number of sectors per card (Word 7 = MSW, Word 8 = LSW)</td>
</tr>
<tr>
<td>9</td>
<td>0000h</td>
<td>2</td>
<td>Obsolete</td>
</tr>
<tr>
<td>10-19</td>
<td>aaaa</td>
<td>20</td>
<td>Serial number in ASCII (right justified)</td>
</tr>
<tr>
<td>20</td>
<td>0000h</td>
<td>2</td>
<td>Obsolete</td>
</tr>
<tr>
<td>21</td>
<td>0000h</td>
<td>2</td>
<td>Obsolete</td>
</tr>
<tr>
<td>22</td>
<td>0004h</td>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>23-26</td>
<td>aaaa</td>
<td>8</td>
<td>Firmware revision in ASCII. Big Endian Byte Order in Word</td>
</tr>
<tr>
<td>27-46</td>
<td>aaaa</td>
<td>40</td>
<td>Model number in ASCII (right justified) Big Endian Byte Order in Word</td>
</tr>
<tr>
<td>47</td>
<td>0001h</td>
<td>2</td>
<td>Maximum number of sectors on Read/Write Multiple command</td>
</tr>
<tr>
<td>48</td>
<td>0000h</td>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>49</td>
<td>0200h</td>
<td>2</td>
<td>Capabilities</td>
</tr>
<tr>
<td>50</td>
<td>0000h</td>
<td>2</td>
<td>Reserved</td>
</tr>
<tr>
<td>51</td>
<td>0200h</td>
<td>2</td>
<td>PIO data transfer cycle timing mode</td>
</tr>
<tr>
<td>52</td>
<td>0000h</td>
<td>2</td>
<td>Obsolete</td>
</tr>
<tr>
<td>53</td>
<td>0003h</td>
<td>2</td>
<td>Field validity</td>
</tr>
<tr>
<td>54</td>
<td>XXXXh</td>
<td>2</td>
<td>Current numbers of cylinders</td>
</tr>
<tr>
<td>55</td>
<td>XXXXh</td>
<td>2</td>
<td>Current numbers of heads</td>
</tr>
<tr>
<td>56</td>
<td>XXXXh</td>
<td>2</td>
<td>Current sectors per track</td>
</tr>
<tr>
<td>57-58</td>
<td>XXXXh</td>
<td>4</td>
<td>Current capacity in sectors (LBAs)(Word 57 = LSW, Word 58 = MSW)</td>
</tr>
<tr>
<td>59</td>
<td>01XXh</td>
<td>2</td>
<td>Multiple sector setting</td>
</tr>
<tr>
<td>60-61</td>
<td>XXXXh</td>
<td>4</td>
<td>Total number of sectors addressable in LBA Mode</td>
</tr>
<tr>
<td>62-63</td>
<td>0000h</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>64</td>
<td>0003h</td>
<td>2</td>
<td>Advanced PIO modes supported</td>
</tr>
<tr>
<td>65-66</td>
<td>0000h</td>
<td>4</td>
<td>Reserved</td>
</tr>
<tr>
<td>67</td>
<td>0078h</td>
<td>2</td>
<td>Minimum PIO transfer cycle time without flow control</td>
</tr>
<tr>
<td>68</td>
<td>0078h</td>
<td>2</td>
<td>Minimum PIO transfer cycle time with IORDY flow control</td>
</tr>
<tr>
<td>69-128</td>
<td>0000h</td>
<td>120</td>
<td>Reserved</td>
</tr>
<tr>
<td>129-159</td>
<td>0000h</td>
<td>62</td>
<td>manufacturer unique Bytes</td>
</tr>
<tr>
<td>160-255</td>
<td>0000h</td>
<td>192</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
Idle (97h or E3h)
This command causes the Card to set BSY, enter the Idle mode, clear BSY and generate an interrupt. If the sector count is non-zero, it is interpreted as a timer count (each count is 5ms) and the automatic power down mode is enabled. If the sector count is zero, the automatic power down mode is disabled. Note that this time base (5ms) is different from the ATA specification. Table 52. defines the Byte sequence of the Idle command.

Table 52. Idle

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>97h or E3h</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Timer Count (5ms increments)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>

Idle Immediate (95h or E1h)
This command causes the Card to set BSY, enter the Idle mode, clear BSY and generate an interrupt. Table 53. defines the Idle Immediate command Byte sequence.

Table 53. Idle Immediate

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>95h or E1h</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Initialize Drive Parameters (91h).
This command enables the host to set the number of sectors per track and the number of heads per cylinder. Only the Sector Count and the Card/Drive/Head registers are used by this command. Table 54. defines the Initialize Drive Parameters command Byte sequence.

Table 54. Initialize Drive Parameters

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>91h</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>0</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Number of Sectors</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>
NOP (00h)
This command always fails with the CompactFlash Memory Card returning command aborted.

Table 55. NOP

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td>00h</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td></td>
<td></td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Read Buffer (E4h)
The Read Buffer command enables the host to read the current contents of the Card’s sector buffer. This command has the same protocol as the Read Sector(s) command. Table 56. defines the Read Buffer command Byte sequence.

Table 56. Read Buffer

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td>E4h</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td></td>
<td></td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Read Multiple (C4h)
The Read Multiple command performs similarly to the Read Sectors command. Interrupts are not generated on every sector, but on the transfer of a block which contains the number of sectors defined by a Set Multiple command.

Command execution is identical to the Read Sectors operation except that the number of sectors defined by a Set Multiple command are transferred without intervening interrupts. DRQ qualification of the transfer is required only at the start of the data block, not on each sector.

The block count of sectors to be transferred without intervening interrupts is programmed by the Set Multiple Mode command, which must be executed prior to the Read Multiple command. When the Read Multiple command is issued, the Sector Count Register contains the number of sectors (not the number of blocks or the block count) requested. If the number of requested sectors is not evenly divisible by the block count, as many full blocks as possible are transferred, followed by a final, partial block transfer. The partial block transfer is for \( n \) sectors, where:

\[
n = (\text{sector count}) \mod (\text{block count}).
\]

If the Read Multiple command is attempted before the Set Multiple Mode command has been executed or when Read Multiple commands are disabled, the Read Multiple operation is rejected with an Aborted Command error. Disk errors encountered during Read Multiple commands are posted at the beginning of the block or partial block transfer, but DRQ is still set and the data transfer will take place as it normally would, including transfer of corrupted data, if any.

Interrupts are generated when DRQ is set at the beginning of each block or partial block. The error reporting is the same as that on a Read Sector(s) Command. 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.

If an error occurs, the read terminates at the sector where the error occurred. The Command Block Registers contain the cylinder, head and sector number of the sector where the error occurred. The flawed data is pending in the sector buffer. Subsequent blocks or partial blocks are transferred only if the error was a correctable data error. All other errors cause the command to stop after transfer of the block which contained the error.

Table 57 defines the Read Multiple command Byte sequence.

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>C4h</td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td></td>
<td>LBA</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>Drive (LBA 27-24)</td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Sector Number (LBA 7-0)</td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>
Read Sector(s) (20h or 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. When this command is issued and after each sector of data (except the last one) has been read by the host, the Card sets BSY, puts the sector of data in the buffer, sets DRQ, clears BSY, and generates an interrupt. The host then reads the 512 Bytes of data from the buffer.

If an error occurs, the read terminates at the sector where the error occurred. The Command Block Registers contain the cylinder, head, and sector number of the sector where the error occurred. The flawed data is pending in the sector buffer. Table 58. defines the Read Sector command Byte sequence.

Table 58. Read Sector(s)

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>20h or 21h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td>Head (LBA 27-24)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Sector Number (LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Read Verify Sector(s) (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. When the command is accepted, the Card sets BSY. When the requested sectors have been verified, the Card clears BSY and generates an interrupt.

If an error occurs, the verify terminates at the sector where the error occurs. The Command Block Registers contain the cylinder, head and sector number of the sector where the error occurred. The Sector Count Register contains the number of sectors not yet verified. Table 59. defines the Read Verify Sector command Byte sequence.

Table 59. Read Verify Sector(s)

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>40h or 41h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td>Head (LBA 27-24)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Sector Number (LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Recalibrate (1Xh)
This command is effectively a NOP command to the Card and is provided for compatibility purposes. Table 60. defines the Recalibrate command.

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td>1Xh</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Request Sense (03h)
This command requests extended error information for the previous command. Table 61. defines the Request Sense command Byte sequence.

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td>03h</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>X</td>
<td>1</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Table 62. Extended Error Codes

<table>
<thead>
<tr>
<th>Extended Error Code</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>00h</td>
<td>No Error Detected</td>
</tr>
<tr>
<td>01h</td>
<td>Self Test OK (No Error)</td>
</tr>
<tr>
<td>09h</td>
<td>Miscellaneous Error</td>
</tr>
<tr>
<td>21h</td>
<td>Invalid Address (Requested Head or Sector Invalid)</td>
</tr>
<tr>
<td>2Fh</td>
<td>Address Overflow (Address Too Large)</td>
</tr>
<tr>
<td>35h, 36h</td>
<td>Supply or generated Voltage Out of Tolerance</td>
</tr>
<tr>
<td>11h</td>
<td>Uncorrectable ECC Error</td>
</tr>
<tr>
<td>18h</td>
<td>Corrected ECC Error</td>
</tr>
<tr>
<td>05h, 30-34h, 37h, 3Eh</td>
<td>Self Test or Diagnostic Failed</td>
</tr>
<tr>
<td>10h, 14h</td>
<td>ID Not Found</td>
</tr>
<tr>
<td>3Ah</td>
<td>Spare Sectors Exhausted</td>
</tr>
<tr>
<td>1Fh</td>
<td>Data Transfer Error / Aborted Command</td>
</tr>
<tr>
<td>0Ch, 38h, 3Bh, 3Ch, 3Fh</td>
<td>Corrupted Media Format</td>
</tr>
<tr>
<td>03h</td>
<td>Write / Erase Failed</td>
</tr>
</tbody>
</table>

Seek (7Xh)
This command is effectively a NOP command to the Card although it does perform a range check of cylinder and head or LBA address and returns an error if the address is out of range. Table 63 shows the Seek command Byte sequence.

Table 63. Seek

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>7Xh</td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Head (LBA 27-24)</td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td>X</td>
<td>(LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Set Features (EFh)

This command is used by the host to establish or select certain features. Table 64. shows the Set Features command Byte sequence. Table 65. defines all features that are supported.

Features 01h and 81h are used to enable and clear 8 bit data transfer modes in True IDE Mode. If the 01h feature command is issued all data transfers will occur on the low order D7D0 data bus and the –IOIS16 signal will not be asserted for data register accesses.

Feature 03h allows the host to select the PIO transfer mode by specifying a value in the Sector Count register (see Table 66. for values). The upper 5 bits define the type of transfer and the lower order 3 bits encode the mode value. One PIO mode should be selected at all times. The host may change the selected mode by issuing the Set Features command.

Feature code 9Ah enables the host to configure the card to best meet the host system’s power requirements. The host sets a value in the Sector Count register that is equal to one-fourth of the desired maximum average current (in mA) that the card should consume. For example, if the Sector Count register were set to 6, the card would be configured to provide the best possible performance without exceeding 24 mA. Upon completion of the command, the card responds to the host with the range of values supported by the card. The minimum value is set in the Cylinder Low Register, and the maximum value is set in the Cylinder Hi register. The default value, after a power on reset, is to operate at the highest performance and therefore the highest current mode.

The card will accept values outside this programmable range, but will operate at either the lowest power or highest performance as appropriate.

Table 64. Set Features

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>EFh</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Config</td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Feature</td>
<td></td>
</tr>
</tbody>
</table>

Table 65. Features Supported

<table>
<thead>
<tr>
<th>Feature</th>
<th>Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>01h</td>
<td>Enable 8 bit data transfers.</td>
</tr>
<tr>
<td>03h</td>
<td>Set transfer mode based on value in Sector Count register.</td>
</tr>
<tr>
<td>55h</td>
<td>Disable Read Look Ahead.</td>
</tr>
<tr>
<td>69h</td>
<td>NOP Accepted for backward compatibility.</td>
</tr>
<tr>
<td>81h</td>
<td>Disable 8 bit data transfer.</td>
</tr>
<tr>
<td>96h</td>
<td>NOP Accepted for backward compatibility.</td>
</tr>
<tr>
<td>97h</td>
<td>Accepted for backward compatibility. Use of this Feature is not recommended.</td>
</tr>
<tr>
<td>9Ah</td>
<td>Set the host current source capability. Allows trade-off between current drawn and read/write speed.</td>
</tr>
</tbody>
</table>
Set Multiple Mode (C6h)
This command enables the Card to perform Read and Write Multiple operations and establishes the block count for these commands. The Sector Count Register is loaded with the number of sectors per block. Upon receipt of the command, the Card sets BSY and checks the Sector Count Register.
If the Sector Count Register contains a valid value and the block count is supported, the value is loaded for all subsequent Read Multiple and Write Multiple commands and execution is enabled. If a block count is not supported, an Aborted Command error is posted, and Read Multiple and Write Multiple commands are disabled. If the Sector Count Register contains '0' when the command is issued, Read and Write Multiple commands are disabled. At power on, or after a hardware reset (unless disabled by a Set Feature command), the default mode is Read and Write Multiple disabled. Table 67. defines the Set Multiple Mode command Byte sequence.

Set Sleep Mode (99h or E6h)
This command causes the CompactFlash Memory Card to set BSY, enter the Sleep mode, clear BSY and generate an interrupt. Recovery from sleep mode is accomplished by simply issuing another command (a reset is permitted but not required). Sleep mode is also entered when internal timers expire so the host does not need to issue this command except when it wishes to enter Sleep mode immediately. The default value for the timer is 5 milliseconds. Note that this time base (5ms) is different from the ATA Specification. Table 68. defines the Set Sleep Mode command Byte sequence.

---

**Table 66. Transfer Mode Values**

<table>
<thead>
<tr>
<th>Mode</th>
<th>Bits (7:3)</th>
<th>Bits (2:0)</th>
</tr>
</thead>
<tbody>
<tr>
<td>PIO default mode</td>
<td>00000b</td>
<td>000b</td>
</tr>
<tr>
<td>PIO default mode, disable IORDY</td>
<td>00000b</td>
<td>001b</td>
</tr>
<tr>
<td>PIO flow control transfer mode</td>
<td>00001b</td>
<td>Mode(1)</td>
</tr>
</tbody>
</table>

Note: 1. Mode = transfer mode number

**Table 67. Set Multiple Mode**

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>C6h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Table 68. Set Sleep Mode**

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>99h or E6h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Standby (96h or E2)
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. Recovery from Sleep mode is accomplished by issuing another command (a reset is not required). Table 69 defines the Standby command Byte sequence.

Table 69. Standby

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>96h or E2h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Standby Immediate (94h or E0h)
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. Recovery from Sleep mode is accomplished by issuing another command (a reset is not required). Table 70 defines the Standby Immediate Byte sequence.

Table 70. Standby Immediate

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>94h or E0h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>Drive</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
SMCxxxAF

Translate Sector (87h)
This command allows the host a method of determining the exact number of times a user sector has been erased and programmed. The controller responds with a 512 Byte buffer of information containing the desired cylinder, head and sector, including its Logical Address, and the Hot Count, if available, for that sector. Table 71. defines the Translate Sector command Byte sequence. Table 72. represents the information in the buffer.

Table 71. Translate Sector

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>87h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td>Head (LBA 27-24)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>Sector Number (LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 72. Translate Sector Information

<table>
<thead>
<tr>
<th>Address</th>
<th>Information</th>
</tr>
</thead>
<tbody>
<tr>
<td>00h-01h</td>
<td>Cylinder MSB (00), Cylinder LSB (01)</td>
</tr>
<tr>
<td>02h</td>
<td>Head</td>
</tr>
<tr>
<td>03h</td>
<td>Sector</td>
</tr>
<tr>
<td>04-06h</td>
<td>LBA MSB (04) - LSB (06)</td>
</tr>
<tr>
<td>07-12h</td>
<td>Reserved</td>
</tr>
<tr>
<td>13h</td>
<td>Erased Flag (FFh) = Erased; 00h = Not Erased</td>
</tr>
<tr>
<td>14h-17h</td>
<td>Reserved</td>
</tr>
<tr>
<td>18h-1Ah</td>
<td>Hot Count MSB (18) - LSB (1A); 0 = Hot Count not supported</td>
</tr>
<tr>
<td>1Bh-1FFh</td>
<td>Reserved</td>
</tr>
</tbody>
</table>
Wear Level (F5h)
This command is effectively a NOP command and only implemented for backward compatibility. The Sector Count Register will always be returned with a 00h indicating Wear Level is not needed. Table 73. defines the Wear Level command Byte sequence.

Table 73. Wear Level

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>F5h</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Drive</td>
<td>Flag</td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Completion Status</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Write Buffer (E8h)
The Write Buffer command enables the host to overwrite contents of the Card’s sector buffer with any data pattern desired. This command has the same protocol as the Write Sector(s) command and transfers 512 Bytes. Table 74. defines the Write Buffer command Byte sequence.

Table 74. Write Buffer

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>E8h</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>Drive</td>
<td>X</td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Write Multiple Command (C5h)

This command is similar to the Write Sectors command. The Card sets BSY within 400ns of accepting the 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 execution is identical to the Write Sectors operation except that the number of sectors defined by the Set Multiple command is transferred without intervening interrupts.

DRQ qualification of the transfer is required only at the start of the data block, not on each sector. The block count of sectors to be transferred without intervening interrupts is programmed by the Set Multiple Mode command, which must be executed prior to the Write Multiple command.

When the Write Multiple command is issued, the Sector Count Register contains the number of sectors (not the number of blocks or the block count) requested. If the number of requested sectors is not evenly divisible by the sector/block, as many full blocks as possible are transferred, followed by a final, partial block transfer. The partial block transfer is for \( n \) sectors, where:

\[
    n = \text{(sector count)} \mod \text{(block count)}.
\]

If the Write Multiple command is attempted before the Set Multiple Mode command has been executed or when Write Multiple commands are disabled, the Write Multiple operation will be rejected with an aborted command error.

Errors encountered during Write Multiple commands are posted after the attempted writes of the block or partial block transferred. The Write command ends with the sector in error, even if it is in the middle of a block. Subsequent blocks are not transferred in the event of an error. Interrupts are generated when DRQ is set at the beginning of each block or partial block.

The Command Block Registers contain the cylinder, head and sector number of the sector where the error occurred and the Sector Count Register contains the residual number of sectors that need to be transferred for successful completion of the command. For example, each block has 4 sectors, a request for 8 sectors is issued and an error occurs on the third sector. The Sector Count Register contains 6 and the address is that of the third sector.

Note: The current revision of the CompactFlash Memory Card only supports a block count of 1 as indicated in the Identify Drive Command information. The Write Multiple command is provided for compatibility with future products which may support a larger block count.

Table 75. defines the Write Multiple command Byte sequence.

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>C5h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td>Head</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td>Cylinder High</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td>Cylinder Low</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td>Sector Number</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Write Multiple without Erase (CDh)

This command is similar to the Write Multiple command with the exception that an implied erase before write operation is not performed. The sectors should be pre-erased with the Erase Sector(s) command before this command is issued. Table 76. defines the Write Multiple without Erase command Byte sequence.

Table 76. Write Multiple without Erase

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>CDh</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>X</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Number</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Write Sector(s) (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. When this command is accepted, the Card sets BSY, sets DRQ and clears BSY, then waits for the host to fill the sector buffer with the data to be written. No interrupt is generated to start the first host transfer operation. No data should be transferred by the host until BSY has been cleared by the host.

For multiple sectors, after the first sector of data is in the buffer, BSY will be set and DRQ will be cleared. After the next buffer is ready for data, BSY is cleared, DRQ is set and an interrupt is generated. When the final sector of data is transferred, BSY is set and DRQ is cleared. It will remain in this state until the command is completed at which time BSY is cleared and an interrupt is generated. If an error occurs during a write of more than one sector, writing terminates at the sector where the error occurred. The Command Block Registers contain the cylinder, head and sector number of the sector where the error occurred. The host may then read the command block to determine what error has occurred, and on which sector. Table 77. defines the Write Sector(s) command Byte sequence.

Table 77. Write Sector(s)

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td>30h or 31h</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Number (LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Write Sector(s) without Erase (38h)
This command is similar to the Write Sector(s) command with the exception that an implied erase before write operation is not performed. This command has the same protocol as the Write Sector(s) command. The sectors should be pre-erased with the Erase Sector(s) command before this command is issued. If the sector is not pre-erased a normal write sector operation will occur. Table 78 defines the Write Sector(s) without Erase command Byte sequence.

Table 78. Write Sector(s) without Erase

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>38h</td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td></td>
<td></td>
<td>Head (LBA 27-24)</td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Number (LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>

Write Verify (3Ch)
This command is similar to the Write Sector(s) command, except each sector is verified immediately after being written. This command has the same protocol as the Write Sector(s) command. Table 79 defines the Write Verify command Byte sequence.

Table 79. Write Verify

<table>
<thead>
<tr>
<th>Bit</th>
<th>7</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Command (7)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>3Ch</td>
</tr>
<tr>
<td>C/D/H (6)</td>
<td>1</td>
<td>LBA</td>
<td>1</td>
<td>Drive</td>
<td></td>
<td></td>
<td>Head (LBA 27-24)</td>
<td></td>
</tr>
<tr>
<td>Cyl High (5)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder High (LBA 23-16)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Cyl Low (4)</td>
<td></td>
<td></td>
<td></td>
<td>Cylinder Low (LBA 15-8)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Num (3)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Number (LBA 7-0)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Sect Cnt (2)</td>
<td></td>
<td></td>
<td></td>
<td>Sector Count</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Feature (1)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>
PACKAGE MECHANICAL

Figure 10. Type I CompactFlash Memory Card Dimensions

[Diagram showing the dimensions of a compact flash memory card, including measurements in millimeters and inches.]
### PART NUMBERING

#### Table 80. Ordering Information Scheme

<table>
<thead>
<tr>
<th>Example:</th>
<th>SMC 256 A F A 6 E</th>
</tr>
</thead>
</table>

**Memory Card Standard**

SMC = Storage Medium, CompactFlash

**Density**

- 016 = 16 MBytes
- 032 = 32 MBytes
- 064 = 64 MBytes
- 128 = 128 MBytes
- 256 = 256 MBytes
- 512 = 512 MBytes
- 01G = 1 GByte

**Options of the Standard**

- A = CF Type I

**Memory Type**

- F = Flash Memory

**Card Version**

- A = Version depending on device mix

**Temperature Range**

- 6 = -40 to 85°C

**Packing**

- Blank = Standard Packing (tray)
- E = Lead-Free Package, Standard Packing (tray)

---

Note: Other digits may be added to the ordering code for preprogrammed parts or other options. Devices are shipped from the factory with the memory content bits erased to ‘1’. For further information on any aspect of the device, please contact your nearest ST Sales Office.
## REVISION HISTORY

### Table 81. Document Revision History

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Revision Details</th>
</tr>
</thead>
<tbody>
<tr>
<td>30-Jun-2004</td>
<td>0.1</td>
<td>First Issue</td>
</tr>
<tr>
<td>04-Aug-2004</td>
<td>0.2</td>
<td>Operating and Non-Operating voltage ranges modified (see Table 4., Environmental Specifications and Table 80., Ordering Information Scheme). Conditions for Voltage on any pin except VCC with respect to GND modified in Table 9., Absolute Maximum Conditions. Unit for lxD modified in Table 11., Input Leakage Current. Small text changes. In Table 2., System Performance, Sustained Write and Command to DRQ Max values changed, Reset to Ready parameter changed to Power-up to Ready and equivalent speed grades given in multiples of X (see Note: 1.). CompactFlash Storage Card renamed as CompactFlash Memory Card.</td>
</tr>
<tr>
<td>29-Sep-2004</td>
<td>0.3</td>
<td>Code for “Standard Packing (tray)” Packing option corrected in Table 80., Ordering Information Scheme.</td>
</tr>
<tr>
<td>17-Dec-2004</td>
<td>0.4</td>
<td>Sustained Write Performance updated in FEATURES SUMMARY and Table 2., System Performance. Table 6., System Reliability and Maintenance added in SUMMARY DESCRIPTION section. Weight updated in Figure 5., Common Memory Read Timing Diagram. Figure 10., Type I CompactFlash Memory Card Dimensions updated.</td>
</tr>
<tr>
<td>18-Feb-2005</td>
<td>0.5</td>
<td>All text, tables and figures relating to the Security features of the SMCxxxAF from removed. All text, tables and figures related to Soft Reset features, removed. Flush Cache (E7h) and Format Track (50h) sections removed. Read Long Sector (22h to 23h) and Write Long Sector (32h to 33h) removed. All text, tables and figures relating to three sections on Key Management, removed. Word 82-84, Word 85-87, Word 91 and Word 162 sections removed from Identify Drive (ECh). Table 70., Power Management Levels; removed. Added Table 66. to Set Features (EFh) section. Text altered in Configuration Option Register (Base + 00h in Attribute Memory), Read Sector(s) (20h or 21h), Read Verify Sector(s) (40h or 41h), Set Multiple Mode (C6h). and Set Features (EFh). Modified Word 49: Capabilities section. Modified Table 2., Table 4., Table 6., Table 10., Table 12., Table 24., Table 43., Table 45., Table 51., Table 62. and Table 65. Modifications to Electrical Specification and PART NUMBERING sections. Minor modifications to headings in the ELECTRICAL INTERFACE section.</td>
</tr>
</tbody>
</table>