# **DATA SHEET** # SILICONDRIVE II CF SSD-Cxxx(I)-4000 ### **OVERVIEW** The SiliconDrive II CF is an optimal timeto-market replacement for hard drives and flash cards or in host systems that require low power and scalable storage solutions. SiliconDrive II technology is engineered exclusively for the high performance, high reliability and multi-year product lifecycle requirements of the Enterprise System OEM market. Typical end-market applications include broadband data and voice networks, military systems, flight system avionics, medical equipment, industrial control systems, video surveillance, storage networking, VoIP, wireless infrastructure, and interactive kiosks. Every SiliconDrive II CF is integrated with SiliconSystems patented PowerArmor and patent-pending SiSMART and SiSecure technologies. PowerArmor prevents data corruption and loss from power disturbances by integrating patented technology into every SiliconDrive II. SiSMART acts as an early warning system to eliminate unscheduled downtime by constantly monitoring and reporting the exact amount of remaining storage system useful life. SiSecure is a comprehensive suite of user-selectable security technologies that solves the critical need for robust storage security for embedded systems applications that have a small footprint and low-power requirement. ### SISECURE SiZone Data zones with different security parameters. SiKey Ties SiliconDrive to a specific host and/or software IP. SiProtect Protection software for password-required, read/write, or read-only access. SiSweep Ultra-fast data erasure. SiPurge Non-recoverable data erasure. AutoLock Automatically locks the SiliconDrive. ### **F**EATURES RoHS 6 of 6 compliant - Integrated PowerArmor, SiSMART, and SiSecure technology - Capacity range: 1GB to 16GB - Supports both 8-bit and 16-bit data register transfers - Supports dual-voltage 3.3V or 5V interface - MTBF >4,000,000 hours - ATA-5 compliant - Industry standard Type I CF form factor - Supports PIO modes 0-6, multi-word DMA 0-4, and UDMA modes 0-4 Click here Click here ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. 26840 ALISO VIEJO PARKWAY, ALISO VIEJO, CA 92656 • PHONE: 949.900.9400 • FAX: 949.900.9500 • http://www.siliconsystems.com DOCUMENT: 4000C-12DSR JUNE 13, 2008 # **REVISION HISTORY** | Document No. | Release Date | Changes | |-------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4000C-12DSR | June 13, 2008 | <ul> <li>Updated:</li> <li>PIO mode.</li> <li>Read and Write (Typical/Peak) in the "System Power Requirements" table.</li> <li>16GB &amp; 32GB in the "Product Capacity Specifications" table.</li> <li>"Pin Assignments" table.</li> <li>"Signal Descriptions" table.</li> <li>"Absolute Maximum Ratings" table."</li> <li>"Capacitance" table.</li> <li>"DC Characteristics" table.</li> <li>"Attribute and Common Memory Read Timing" table.</li> <li>"Attribute and Common Memory Write Timing" table.</li> <li>"I/O Access Read Timing" table.</li> <li>"I/O Access Write Timing" table.</li> <li>"True IDE Read/Write Access Timing" table.</li> <li>"True IDE Multiword DMA Read/Write Access Timing" table.</li> <li>"Irrue IDE Multiword DMA Read/Write Access Timing" table.</li> <li>"Identify Drive — Drive Attribute Data" table.</li> <li>Added:</li> <li>"Ultra DMA Data Burst Timing Requirements."</li> </ul> | | | | Removed: | | 4000C-11DSR | May 7, 2009 | "Capacitance." Updated "Overview." | | PRELIMINARY | May 7, 2008 | Opualed Overview. | | SSDS10-4000C-R<br>PRELIMINARY | April 3, 2008 | Updated part pictures. | ### SILICONSYSTEMS PROPRIETARY PAGE 2 JUNE 13, 2008 DOCUMENT: 4000C-12DSR | Document No. | Release Date | Changes | |-------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SSDS09-4000C-R<br>PRELIMINARY | March 20, 2008 | <ul> <li>Updated:</li> <li>"Overview."</li> <li>"Features."</li> <li>SiProtect in the "SiSecure" and "Related Documentation" tables.</li> <li>Read and Write Transfer rates in the "System Performance" table.</li> </ul> | | | | <ul><li>Added:</li><li>SiSecure verbiage.</li><li>"MTBF."</li></ul> | | | | Removed: | | | | <ul> <li>SiSecure rows from the "SiSecure" and "Related Documentation" tables.</li> <li>"System Reliability."</li> </ul> | | SSDS08-4000C-R | February 8, 2008 | Updated: | | PRELIMINARY | | <ul><li>Document's title.</li><li>16GB cylinder value in the "Product Capacity<br/>Specifications" table.</li></ul> | | | | Added: | | | | <ul> <li>"SiliconDrive II Secure" to the cover, which<br/>includes AutoLock.</li> </ul> | | | | Removed: | | | | • The Note under the "Product Capacity Specifications" table. | | SSDS07-4000C-R<br>PRELIMINARY | January 29, 2008 | Added a Note below the "DC Characteristics" table. | | SSDS06-4000C-R<br>PRELIMINARY | December 21, 2007 | Updated the Endurance in the "System Reliability" table. | | | December 19, 2007 | Updated: | | PRELIMINARY | | <ul> <li>Capacity range.</li> <li>Transfer Rates in the "System Performance" table.</li> <li>"Product Capacity Specifications" table.</li> <li>Removed:</li> </ul> | | | | <ul> <li>Endurance from the "System Reliability" table.</li> </ul> | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. | Document No. | Release Date | Changes | |-------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SSDS04-4000C-R<br>PRELIMINARY | December 17, 2007 | Updated the t <sub>RWD</sub> Maximum in the "True IDE Multiword DMA Read/Write Access Timing" table. | | SSDS03-4000C-R<br>PRELIMINARY | August 16, 2007 | <ul> <li>Updated:</li> <li>RoHS information.</li> <li>Cylinder Low in the "Task File Register Specification" table.</li> <li>"Part Numbering Nomenclature" table.</li> <li>"Sample Label."</li> </ul> | | SSDS02-4000C-R<br>PRELIMINARY | May 10, 2007 | <ul> <li>Updated:</li> <li>Capacity range.</li> <li>"System Performance" table.</li> <li>"Related Documentation" table.</li> <li>Removed:</li> <li>NOP command from the "ATA Command Set" table.</li> </ul> | | SSDS01-4000C-<br>PRELIMINARY | April 10, 2007 | Updated the capacity range. | | SSDS00-4000C-R<br>PRELIMINARY | February 27, 2007 | Initial release. | PAGE 4 JUNE 13, 2008 DOCUMENT: 4000C-12DSR PAGE 1 # **TABLE OF CONTENTS** | Overview | 1 | |-------------------------------------------------|----| | SiSecure | 1 | | Features | 1 | | Physical Specifications | 1 | | Physical Dimensions | 1 | | Product Specifications | 2 | | System Performance | 2 | | System Power Requirements | 2 | | MTBF | 2 | | Product Capacity Specifications | 3 | | Environmental Specifications | 3 | | Electrical Specification | 4 | | Pin Assignments | 4 | | Signal Descriptions | 5 | | Absolute Maximum Ratings | 17 | | DC Characteristics | 17 | | AC Characteristics | 18 | | Attribute and Common Memory Read Timing | 18 | | Attribute and Common Memory Write Timing | 19 | | I/O Access Read Timing | 20 | | I/O Access Write Timing | 21 | | True IDE PIO Mode Read/Write Access Timing | 22 | | True IDE Multiword DMA Read/Write Access Timing | 25 | | Ultra DMA Data Burst Timing Requirements | 27 | | Attribute Memory Description and Operation | 37 | | Attribute Memory Read Operations | 37 | | Attribute Memory Write Operations | 38 | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. | | Attribute Memory Map | . 39 | |----|----------------------------------------------------|------| | | Card Information Structure | . 40 | | | Configuration Option Register (200h) | . 51 | | | Configuration and Status Register (202h) | . 52 | | | Pin Placement Register (204h) | . 53 | | | Socket and Copy Register (206h) | . 54 | | C | Common Memory Description and Operation | . 55 | | | Common Memory Read Operations | . 55 | | | Common Memory Write Operations | . 55 | | I/ | O Space Description and Operation | . 56 | | | I/O Space Read Operations | . 56 | | | I/O Space Write Operations | . 56 | | A | TA and True IDE Register Decoding | . 57 | | | Memory-Mapped Register Decoding | . 57 | | | Independent I/O Mode Register Decoding | . 58 | | | Primary and Secondary I/O Mapped Register Decoding | . 59 | | | Task File Register Specification | . 60 | | A | TA Registers | . 61 | | | Data Register | . 61 | | | Error Register | . 61 | | | Feature Register | . 62 | | | Sector Count Register | . 63 | | | Sector Number Register | . 64 | | | Cylinder Low Register | . 65 | | | Cylinder High Register | . 66 | | | Drive/Head Register | . 67 | | | Status Register | . 68 | | | Command Register | . 69 | | | Alternate Status Register | . 70 | PAGE 3 | D€ | evice Control Register | 71 | |-----|---------------------------------------|-----| | De | evice Address Register | 72 | | ATA | Command Block and Set Description | 73 | | Α | TA Command Set | 73 | | | Check Power Mode — 98h, E5h | 75 | | | Executive Drive Diagnostic — 90h | 76 | | | Format Track — 50h | 77 | | | Identify Drive — ECh | 78 | | | Identify Drive — Drive Attribute Data | 79 | | | Idle — 97h, E3h | 82 | | | Idle Immediate — 95h, E1h | 83 | | | Initialize Drive Parameters — 91h | 84 | | | Recalibrate — 1Xh | 85 | | | Read Buffer — E4h | 86 | | | Read DMA — C8h | 87 | | | Read Multiple — C4h | 88 | | | Read Sector — 20h, 21h | 89 | | | Read Long Sector(s) — 22h, 23h | 90 | | | Read Verify Sector(s) — 40h, 41h | 91 | | | Seek — 7Xh | 92 | | | Set Features — EFh | 93 | | | Set Multiple Mode — C6h | 94 | | | Set Sleep Mode — 99h, E6h | 95 | | | Standby — 96h, E2h | 96 | | | Standby Immediate — 94h, E0h | 97 | | | Write Buffer — E8h | 98 | | | Write DMA — CAh | 99 | | | Write Multiple — C5h | 100 | | | Write Sector(s) — 30h, 31h | 101 | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. | Write Long Sector(s) — 32h, 33h | 102 | |-------------------------------------------------------------|-----| | Erase Sector(s) — C0h | 103 | | Request Sense — 03h | 104 | | Translate Sector — 87h | 105 | | Wear-Level — F5h | 106 | | Write Multiple w/o Erase — CDh | 107 | | Write Sector(s) w/o Erase — 38h | 108 | | Write Verify — 3Ch | 109 | | Sales and Support | 110 | | Part Numbering | 110 | | Nomenclature | 110 | | Part Numbers | 111 | | RoHS 6 of 6 Product Labeling — Pb-Free Identification Label | 111 | | Sample Label | 111 | | Related Documentation | 112 | # **LIST OF FIGURES** | Figure 1: Physical Dimensions | 1 | |--------------------------------------------------------------|-----| | Figure 2: Attribute and Common Memory Read Timing Diagram | 18 | | Figure 3: Attribute and Common Memory Write Timing Diagram | 19 | | Figure 4: I/O Access Read Timing Diagram | 20 | | Figure 5: I/O Access Write Timing Diagram | 21 | | Figure 6: True IDE PIO Mode Read/Write Access Timing Diagram | 22 | | Figure 7: True IDE Multiword DMA Read/Write Access Timing | 25 | | Figure 8: Initiating a UDMA Data-In Burst | 27 | | Figure 9: Sustained UDMA Data-In Burst | 28 | | Figure 10: Host Pausing a UDMA Data-In Burst | 28 | | Figure 11: Device Terminating a UDMA Data-In Burst | 29 | | Figure 12: Host Terminating a UDMA Data-In Burst | 30 | | Figure 13: Initiating a UDMA Data-Out Burst | 31 | | Figure 14: Sustained UDMA Data-Out Burst | 31 | | Figure 15: Device Pausing a UDMA Data-Out Burst | 32 | | Figure 16: Host Terminating a UDMA Data-Out Burst | 33 | | Figure 17: Device Terminating a UDMA Data-Out Burst | 34 | | Figure 18: Sample Label | 111 | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 2 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # **LIST OF TABLES** | Table 1: System Performance | 2 | |-----------------------------------------------------------|----| | Table 2: System Power Requirements | 2 | | Table 3: MTBF | 2 | | Table 4: Product Capacity Specifications | 3 | | Table 5: Environmental Specifications | 3 | | Table 6: Pin Assignments | 4 | | Table 7: Signal Descriptions | 5 | | Table 8: Absolute Maximum Ratings | 17 | | Table 9: DC Characteristics | 17 | | Table 10: Attribute and Common Memory Read Timing | 18 | | Table 11: Attribute and Common Memory Write Timing | 19 | | Table 12: I/O Access Read Timing | 20 | | Table 13: I/O Access Write Timing | 21 | | Table 14: True IDE PIO Mode Read/Write Access Timing | 23 | | Table 15: True IDE Multiword DMA Read/Write Access Timing | 25 | | Table 16: UDMA Data Burst Timing Requirements | 35 | | Table 17: Attribute Memory Read Operations | 37 | | Table 18: Attribute Memory Write Operations | 38 | | Table 19: Attribute Memory Map | 39 | | Table 20: Card Information Structure | 40 | | Table 21: Configuration Option Register (200h) | 51 | | Table 22: Configuration and Status Register (202h) | 52 | | Table 23: Pin Placement Register (204h) | 53 | | Table 24: Socket and Copy Register (206h) | 54 | | Table 25: Common Memory Read Operations | 55 | | Table 26: Common Memory Write Operations | 55 | | Table 27: I/O Space Read Operations | 56 | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. | Table 28: I/O Space Write Operations | 56 | |--------------------------------------------------------------|----| | Table 29: Memory-Mapped Register Decoding | 57 | | Table 30: Independent I/O Mode Register Decoding | 58 | | Table 31: Primary and Secondary I/O Mapped Register Decoding | 59 | | Table 32: Task File Register Specification | 60 | | Table 33: Error Register | 61 | | Table 34: Feature Register | 62 | | Table 35: Sector Count Register | 63 | | Table 36: Sector Number Register | 64 | | Table 37: Cylinder Low Register | 65 | | Table 38: Cylinder High Register | 66 | | Table 39: Drive/Head Register | 67 | | Table 40: Status Register | 68 | | Table 41: Command Register | 69 | | Table 42: Alternate Status Register | 70 | | Table 43: Device Control Register | 71 | | Table 44: Device Address Register | 72 | | Table 45: ATA Command Block and Set Description | 73 | | Table 46: ATA Command Set | 73 | | Table 47: Check Power Mode — 98h, E5h | 75 | | Table 48: Executive Drive Diagnostic — 90h | 76 | | Table 49: Format Track — 50h | 77 | | Table 50: Identify Drive — ECh | 78 | | Table 51: Identify Drive — Drive Attribute Data | 79 | | Table 52: Idle — 97h, E3h | 82 | | Table 53: Idle Immediate — 95h, E1h | 83 | | Table 54: Initialize Drive Parameters — 91h | 84 | | Table 55: Recalibrate — 1Xh | 85 | | Table 56: Read Buffer — E4h | 86 | ### **LIST OF TABLES** | Table 57: Read DMA — C8h | 87 | |--------------------------------------------|-----| | Table 58: Read Multiple — C4h | 88 | | Table 59: Read Sector — 20h, 21h | 89 | | Table 60: Read Long Sector(s) — 22h, 23h | 90 | | Table 61: Read Verify Sector(s) — 40h, 41h | 91 | | Table 62: Seek — 7Xh | 92 | | Table 63: Set Features — EFh | 93 | | Table 64: Set Features' Attributes | 93 | | Table 65: Set Multiple Mode — C6h | 94 | | Table 66: Set Sleep Mode — 99h, E6h | 95 | | Table 67: Standby — 96h, E2h | 96 | | Table 68: Standby Immediate — 94h, E0h | 97 | | Table 69: Write Buffer — E8h | 98 | | Table 70: Write DMA — CAh | 99 | | Table 71: Write Multiple — C5h | 100 | | Table 72: Write Sector(s) — 30h, 31h | 101 | | Table 73: Write Long Sector(s) — 32h, 33h | 102 | | Table 74: Erase Sector(s) — C0h | 103 | | Table 75: Request Sense — 03h | 104 | | Table 76: Extended Error Codes | 104 | | Table 77: Translate Sector — 87h | 105 | | Table 78: Wear-Level — F5h | 106 | | Table 79: Write Multiple w/o Erase — CDh | 107 | | Table 80: Write Sector(s) w/o Erase — 38h | 108 | | Table 81: Write Verify — 3Ch | 109 | | Table 82: Part Numbering Nomenclature | 110 | | Table 83: Part Numbers | 111 | | Table 84: Related Documentation | 112 | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 4 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # PHYSICAL SPECIFICATIONS The SiliconDrive II CF products are offered in an industry-standard Type I form factor. See "Part Numbering" on page 110 for details regarding CF capacities. ### PHYSICAL DIMENSIONS This section provides diagrams that describe the physical dimensions for the CF. Figure 1: Physical Dimensions ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 1 # **PRODUCT SPECIFICATIONS** **Note:** All SiliconDrive II CF values quoted are typical at 25°C and nominal supply voltage. ### SYSTEM PERFORMANCE Table 1: System Performance | Reset to Ready Startup Time (Typical/Maximum) | 200ms/400ms | |-----------------------------------------------|---------------| | Read Transfer Rate (Typical) | 34MBps | | Write Transfer Rate (Typical) | 19MBps | | Burst Transfer Rate | 66MBps | | Controller Overhead (Command to DRQ) | 2ms (maximum) | # SYSTEM POWER REQUIREMENTS Table 2: System Power Requirements | DC Input Voltage | 3.3 ± 10% | 5.0 ± 10% | |-------------------------|------------|------------| | Sleep (Standby Current) | <0.5mA | <1.0mA | | Read (Typical/Peak) | 50mA/100mA | 60mA/120mA | | Write (Typical/Peak) | 50mA/100mA | 60mA/120mA | ### **MTBF** ### Table 3: MTBF | MTBF (@ 25°C) | >4,000,000 hours | | |---------------|------------------|--| PAGE 2 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # PRODUCT CAPACITY SPECIFICATIONS Table 4: Product Capacity Specifications | Product<br>Capacity | Formatted<br>Capacity<br>(Bytes) | Number of<br>Sectors | Number of Cylinders | Number of Heads | Number of<br>Sectors/<br>Track | |---------------------|----------------------------------|----------------------|---------------------|-----------------|--------------------------------| | 1GB | 1,024,966,656 | 2,001,888 | 1986 | 16 | 63 | | 2GB | 2,048,901,120 | 4,001,760 | 3970 | 16 | 63 | | 4GB | 4,110,188,544 | 8,027,712 | 7964 | 16 | 63 | | 8GB | 8,195,604,480 | 16,007,040 | 15,880 | 16 | 63 | | 16GB | 16,391,208,960 | 32,014,080 | 16,383 | 16 | 63 | # **ENVIRONMENTAL SPECIFICATIONS** Table 5: Environmental Specifications | Temperature | 0°C to 70°C (Commercial) | |-------------|----------------------------------------------------| | | -40°C to 85°C (Industrial) | | Humidity | 8% to 95% non-condensing | | Vibration | 16.3gRMS, MIL-STD-810F, Method 514.5, Procedure I, | | | Category 24 | | Shock | 1000G, Half-sine, 0.5ms Duration | | | 50g Pk, MIL-STD-810F, Method 516.5, Procedure I | | Altitude | 80,000ft, MIL-STD-810F, Method 500.4, Procedure II | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. # **ELECTRICAL SPECIFICATION** ### **PIN ASSIGNMENTS** The following table describes the SiliconDrive II CF 50-pin IDE connector signals. Table 6: Pin Assignments | | | | | | _ | | | | | | |-----|---------------------------|---------------------|-----------------|-------------------|---|-----|---------------------------|---------------------|------------------|--------------------| | Pin | PC Card<br>Memory<br>Mode | PC Card<br>I/O Mode | IDE-ATA<br>Mode | Ultra DMA<br>Mode | | Pin | PC Card<br>Memory<br>Mode | PC Card<br>I/O Mode | IDE-ATA<br>Mode | Ultra DMA<br>Mode | | 1 | GND | GND | GND | GND | - | 26 | CD1# | CD1# | CD1# | CD#1 | | 2 | D3 | D3 | D3 | D3 | _ | 27 | D11 <sup>1</sup> | D11 <sup>1</sup> | D11 <sup>1</sup> | D11 <sup>1</sup> | | 3 | D4 | D4 | D4 | D4 | _ | 28 | D12 <sup>1</sup> | D12 <sup>1</sup> | D12 <sup>1</sup> | D12 <sup>1</sup> | | 4 | D5 | D5 | D5 | D5 | _ | 29 | D13 <sup>1</sup> | D13 <sup>1</sup> | D13 <sup>1</sup> | D13 <sup>1</sup> | | 5 | D6 | D6 | D6 | D6 | _ | 30 | D14 <sup>1</sup> | D14 <sup>1</sup> | D14 <sup>1</sup> | D14 <sup>1</sup> | | 6 | D7 | D7 | D7 | D7 | - | 31 | D15 <sup>1</sup> | D15 <sup>1</sup> | D15 <sup>1</sup> | D15 <sup>1</sup> | | 7 | CE1# | CE1# | CS0# | CS0# | - | 32 | CE2# | CE2# | CS1# | CS1# | | 8 | A10 | A10 | A10 | A10 | - | 33 | VS1# | VS1# | VS1# | VS1# | | 9 | OE# | OE# | ATA-SEL# | ATA-SEL# | - | 34 | IORD# | IORD# | IORD# | HSTROBE<br>HDMARD\ | | 10 | A9 | A9 | A9 | A9 | - | 35 | IOWR# | IOWR# | IOWR# | STOP | | 11 | A8 | A8 | A8 | A8 | _ | 36 | WE# | WE# | WE# | WE# | | 12 | A7 | A7 | A7 | A7 | _ | 37 | RDY/BSY | IREQ# | INTRQ | INTRQ | | 13 | V <sub>CC</sub> | $V_{CC}$ | V <sub>CC</sub> | V <sub>CC</sub> | _ | 38 | V <sub>CC</sub> | V <sub>CC</sub> | V <sub>CC</sub> | $V_{CC}$ | | 14 | A6 | A6 | A6 | A6 | - | 39 | CSEL# | CSEL# | CSEL# | CSEL# | | 15 | A5 | A5 | A5 | A5 | - | 40 | VS2# | VS2# | VS2# | VS2# | | 16 | A4 | A4 | A4 | A4 | - | 41 | RESET# | RESET | RESET# | RESET# | | 17 | A3 | A3 | A3 | A3 | _ | 42 | WAIT# | WAIT# | WAIT# | DDMARDY<br>DSTROBE | | 18 | A2 | A2 | A2 | A2 | - | 43 | INPACK# | INPACK# | DMARQ | DMARQ# | | 19 | A1 | A1 | A1 | A1 | - | 44 | REG# | REG# | DMACK# | DMACK# | | 20 | A0 | A0 | A0 | A0 | _ | 45 | BVD2 | SPKR# | DASP# | DASP# | | 21 | D0 | D0 | D0 | D0 | - | 46 | BVD1 | STSCHG# | PDIAG# | PDIAG# | | 22 | D1 | D1 | D1 | D1 | _ | 47 | D8 <sup>1</sup> | D8 <sup>1</sup> | D8 <sup>1</sup> | D8 <sup>1</sup> | | 23 | D2 | D2 | D2 | D2 | - | 48 | D9 <sup>1</sup> | D9 <sup>1</sup> | D9 <sup>1</sup> | D9 <sup>1</sup> | | 24 | WP | IOIS16# | IOCS16# | IOCS16# | - | 49 | D10 <sup>1</sup> | D10 <sup>1</sup> | D10 <sup>1</sup> | D10 <sup>1</sup> | | 25 | CD2# | CD2# | CD2# | CD2# | _ | 50 | GND | GND | GND | GND | ### Note: 1 = These signals are required only for 16-bit access, and not required when installed in 8-bit systems. ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 4 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # SIGNAL DESCRIPTIONS Table 7: Signal Descriptions | Signal Name | Pin | Туре | Description | |----------------------------------|------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A10-A0 | 8, 10, 11,<br>12, 14, 15,<br>16, 17, 18, | I | These address lines along with the -<br>REG signal are used to select the<br>following: | | | 19, 20 | | <ul> <li>The I/O port address registers within the SiliconDrive II CF</li> <li>The memory-mapped port address registers within the SiliconDrive II CF</li> <li>A byte in the card's information structure and its configuration control and status registers</li> </ul> | | A10-A0<br>(PC Card I/O<br>mode) | | | This signal is the same as the PC Card Memory Mode signal. | | A2-A0<br>(True IDE mode) | 18, 19, 20 | I | In true IDE mode, only A[2:0] are used to select the one of eight registers in the Task File. The remaining address lines should be grounded by the host. | | BVD1<br>(PC Card memory<br>mode) | 46 | I/O | This signal is asserted high, because BVD1 is not supported. | | -STSCHG<br>(PC Card I/O<br>mode) | | | This signal is asserted low to alert the host to changes in the RDY/-BSY and Write Protect states while the I/O interface is configured. This signal's use is controlled by the Card Configuration and Status register. | | -PDIAG<br>(True IDE mode) | | | In the true IDE mode, this input/<br>output is the Pass Diagnostic signal in<br>the Master/Slave handshake protocol. | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |----------------------------------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BVD2<br>(PC Card memory<br>mode) | 45 | I/O | This signal is asserted high, as BVD2 is not supported. | | -SPKR<br>(PC Card I/O<br>mode) | | | This line is the Binary Audio output from the card. If the Card does not support the Binary Audio function, this line should be held negated. | | -DASP<br>(True IDE mode) | | | In the true IDE mode, this input/output is the Disk Active/Slave Present signal in the Master/Slave handshake protocol. | | -CD1, -CD2<br>(PC Card memory<br>mode) | 26, 25 | O | These Card Detect pins are connected to ground on the SiliconDrive II CF, and are used by the host to determine that the SiliconDrive II CF is fully inserted into its socket. | | -CD1, -CD2<br>(PC Card I/O<br>Mode) | | | This signal is the same for all modes. | | -CD1, -CD2<br>(True IDE mode) | | | This signal is the same for all modes. | PAGE 6 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |-------------------------------------------------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -CE1, -CE2<br>(PC Card memory<br>mode)<br>Card Enable | 7, 32 | I | These input signals are used both to select the card and to indicate to the card whether a byte or a word operation is being performed. | | | | | <ul> <li>-CE2 always accesses the odd<br/>byte of the word.</li> <li>-CE1 accesses the even byte or<br/>the odd byte of the word depending<br/>on A0 and -CE2.</li> </ul> | | | | | A multiplexing scheme based on A0, -CE1, and -CE2 allows 8-bit hosts to access all data on D0-D7. See "Attribute Memory Read Operations" on page 37, "Attribute Memory Write Operations" on page 38, "Common Memory Read Operations" on page 55, and "Common Memory Write Operations" on page 55. | | -CE1, -CE2<br>(PC Card I/O<br>mode)<br>Card Enable | | | This signal is the same as the PC Card Memory Mode signal. See "I/O Space Read Operations" on page 56 and "I/O Space Write Operations" on page 56. | | -CS0, -CS1<br>(True IDE mode) | | | In the true IDE mode, -CS0 is the chip select for the task file registers while -CS1 is used to select the Alternate Status register and the Device Control register. | | -CSEL<br>(PC Card memory<br>mode) | 39 | I | This signal is not used for this mode. | | -CSEL<br>(PC Card I/O<br>mode) | | | This signal is not used for this mode. | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |-------------------------------------------------------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -CSEL<br>(True IDE mode) | | | This internally pulled-up signal is used to configure this device as a master or slave when configured in the true IDE mode. When this pin is: | | | | | <ul> <li>Grounded, this device is configured as a master.</li> <li>Open, this device is configured as a slave.</li> </ul> | | -INPACK<br>(PC Card memory<br>mode) | 43 | 0 | This signal is not used in this mode. | | -INPACK<br>(PC Card I/O<br>mode)<br>Input Acknowledge | | | This signal is asserted by the SiliconDrive II CF when the card is selected and responding to an I/O read cycle at the address that is on the address bus. This signal is used by the host to control the enabling of any input data buffers between the SiliconDrive II CF and the CPU. | PAGE 8 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |-------------------------------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -DMARQ<br>(UDMA Protocol<br>active) | | | This signal is a DMA request that is used for DMA data transfers between host and device. It is asserted by the device when it is ready to transfer data to or from the host. | | | | | For Multiword DMA transfers, the direction of data transfer is controlled by -IORD and -IOWR. This signal is used in a handshake manner with -DMACK (i.e., the device waits until the host asserts (-)DMACK before negating (-)DMARQ, and reasserting (-)DMARQ if there is more data to transfer). | | | | | In PCMCIA I/O mode, the -DMARQ is ignored by the host while the host is performing an I/O Read cycle to the device. The host does not initiate an I/O Read cycle while -DMARQ is asserted by the device. | | | | | In True IDE mode, DMARQ is not driven when the device is not selected in the Drive-Head register. | | | | | While a DMA operation is in progress, -CS0 (-CE1) and -CS1 (-CE2) are held negated and the width of the transfers is 16 bits. | | | | | If there is no hardware support for True IDE DMA mode in the host, this output signal is not used and should not be connected at the host. In this case, the BIOS must report that DMA mode is not supported by the host so that device drivers do not attempt DMA mode operation. | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |-------------------------------------|-----------------------------------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DMARQ<br>(True IDE mode) | 43 | O | In true IDE mode, this signal is used for DMA transfers between the host and device. DMARQ is asserted by the device when the device is ready to transfer data to/from the host. The direction of data transfer is controlled by -IORD and -IOWR. This signal is used in a handshake manner with -DMACK (i.e., the device waits until the host asserts -DMACK before negating DMARQ, and reasserts DMARQ if there is more data to transfer). The DMARQ/-DMACK handshake is used to provide flow control during the transfer. | | D15-D00<br>(PC Card memory<br>mode) | 31, 30, 29,<br>28, 27, 49,<br>48, 47, 6,<br>5, 4, 3, 2,<br>23, 22, 21 | I/O | These lines carry the data, commands, and status information between the host and the controller. | | | | | <ul> <li>D00 is the LSB of the word's even byte.</li> <li>D08 is the LSB of the word's odd byte.</li> </ul> | | D15-D00<br>(PC Card I/O<br>mode) | | | This signal is the same as the PC Card Memory Mode signal. | | D15-D00<br>(True IDE mode) | | | In true IDE mode, all Task File operations occur in byte mode on the low-order bus D00-D07, while all data transfers are 16 bits using D00-D15. | | GND<br>(PC Card memory<br>mode) | 1, 50 | - | Ground. | | GND<br>(PC Card I/O<br>mode) | | | This signal is the same for all modes. | | GND<br>(True IDE mode) | | | This signal is the same for all modes. | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |---------------------------------------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -IORD<br>(PC Card memory<br>mode) | 34 | I | This signal is not used in this mode. | | -IORD<br>(PC Card I/O<br>mode) | | | This is an I/O read strobe generated by the host. This signal gates I/O data onto the bus from the SiliconDrive II CF when the card is configured to use the I/O interface. | | -IORD<br>(True IDE mode) | | | In true IDE mode, this signal has the same function as the PC Card I/O mode. | | -HDMARDY<br>(UDMA read<br>protocol active) | | | When UDMA mode DMA read is active in all modes, this signal is asserted by the host to indicate that the host is ready to receive UDMA data-in bursts. The host may negate -HDMARDY to pause a UDMA transfer. | | HDSTROBE<br>(UDMA write<br>protocol active) | | | When UDMA mode DMA write is active in all modes, this signal is the data out strobe generated by the host. Both the rising and falling edge of HSTROBE cause data to be latched by the device. The host may stop generating HSTROBE edges to pause a UDMA data-out burst. | | -IOWR<br>(PC Card memory<br>mode) | 35 | I | This signal is not used in this mode. | | -IOWR<br>(PC Card I/O<br>mode) | | | The I/O write strobe pulse is used to clock I/O data on the Card data bus into the SiliconDrive II CF controller registers when the SiliconDrive II CF is configured to use the I/O interface. The clocking occurs on the negative-to-positive edge of the signal (the trailing edge). | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |-----------------------------------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------| | -IOWR<br>(True IDE mode) | | | In true IDE mode, this signal has the same function as the PC Card I/O mode. | | STOP<br>(UDMA protocol<br>active) | | | In all modes, while the UDMA mode protocol is active, the assertion of this signal causes the termination of the UDMA data burst. | | -OE<br>(PC Card memory<br>mode) | 9 | I | This is an output enable strobe generated by the host interface, which is used to read: | | | | | <ul> <li>Data from the SiliconDrive II CF in<br/>memory mode.</li> <li>The CIS and configuration<br/>registers.</li> </ul> | | -OE<br>(PC Card I/O<br>mode) | | | In PC Card I/O mode, this signal is used to read the CIS and configuration registers. | | -ATA SEL<br>(True IDE mode) | | | To enable true IDE mode, this input should be grounded by the host. | Table 7: Signal Descriptions (Continued) | 0' 11 | D: | _ | B | |----------------------------------------------------------------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Signal Name | Pin | Туре | Description | | RDY/BSY | 37 | 0 | In memory mode, this signal is: | | (PC Card memory mode) | | | <ul> <li>Set high when the SiliconDrive II<br/>CF is ready to accept a new data<br/>transfer operation.</li> <li>Held low when the card is busy.</li> </ul> | | | | | The host memory card socket must provide a pull-up resistor. At power-up and reset, the RDY/-BSY signal is held low (busy) until the SiliconDrive II CF has completed its power-up or reset function. No access of any type should be made to the SiliconDrive II CF during this time. The RDY/-BSY signal is held high (disabled from being busy) whenever the SiliconDrive II CF has been powered up with +RESET continuously disconnected or asserted. | | -IREQ<br>(PC Card I/O<br>mode)<br>Input Acknowledge | | | I/O Operation. After the SiliconDrive II CF has been configured for I/O operation, this signal is used as -Interrupt Request. This line is strobed low to generate a pulse mode interrupt or held low for a level mode interrupt. | | INTRQ<br>(True IDE mode) | | | In true IDE mode, this signal is the active high Interrupt Request to the host. | | -REG<br>(PC Card memory<br>mode)<br>Attribute Memory<br>Select | 44 | I | This signal is used during memory cycles to distinguish between common memory and register (attribute) memory accesses. This signal is set: • High for common memory. | | | | | <ul> <li>Low for attribute memory.</li> </ul> | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |---------------------------------------------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | -REG<br>(PC Card I/O<br>mode) | | | The signal must also be active (low) during I/O cycles when the I/O address is on the bus. | | -DMACK<br>(True IDE mode) | | | In true IDE mode, this signal is used by the host in response to DMARQ to initiate DMA transfers. The DMARQ/ -DMACK handshake is used to provide flow control during the transfer. When -DMACK is asserted, -CS0 and -CS1 are not asserted and transfers are 16-bits wide. | | DMACK<br>(UDMA protocol<br>active) | | | In UDMA mode, this signal is used by the host in response to DMARQ to initiate DMA transfers. The DMARQ/DMACK handshake is used to provide flow control during the transfer. When DMACK is asserted, -CS0 and -CS1 are not asserted and transfers are 16-bits wide. | | -RESET<br>(PC Card memory<br>mode) | 41 | I | When the pin is high, this signal resets the SiliconDrive II CF. The SiliconDrive II CF is reset only at power-up if this pin is left high or open from power-up. The SiliconDrive II CF is also reset when the Soft Reset bit in the Card Configuration Option register is set. | | -RESET<br>(PC Card I/O<br>mode) | | | This signal is the same as the PC Card Memory Mode signal. | | -RESET<br>(True IDE mode) | | | In the true IDE mode, this input pin is the active low hardware reset from the host. | | V <sub>CC</sub><br>(PC Card memory<br>mode) | 13, 38 | - | +5V, +3.3V power. | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |------------------------------------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>CC</sub><br>(PC Card I/O<br>mode) | | | This signal is the same for all modes. | | V <sub>CC</sub> | | | This signal is the same for all modes. | | (True IDE mode) | | | | | -VS1, -VS2 | 33, 40 | 0 | Voltage Sense Signals. | | | | | <ul> <li>-VS1 is grounded so that the<br/>SiliconDrive II CF CIS can be read<br/>at 3.3V.</li> <li>-VS2 is reserved by PC Card for a<br/>secondary voltage.</li> </ul> | | -VS1, -VS2<br>(PC Card I/O<br>mode) | | | This signal is the same for all modes. | | -VS1, -VS2 | | | This signal is the same for all modes. | | (True IDE mode) | | | | | -WAIT<br>(PC Card memory<br>mode) | 42 | 0 | The -WAIT signal is driven low by the SiliconDrive II CF to signal the host to delay completion of a memory or I/O cycle that is in progress. | | -WAIT | | | This signal is the same as the PC | | (PC Card I/O mode) | | | Card Memory Mode signal. | | -IORDY | | | In true IDE mode, this output signal | | (True IDE mode) | | | may be used as IORDY. | | -DDMARDY | | | In all modes, when UDMA mode DMA | | (UDMA write protocol active) | | | write is active, this signal is asserted by the device during a data burst to indicate that the device is ready to receive UDMA data out bursts. The device may negate -DDMARDY to pause a UDMA transfer. | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 15 Table 7: Signal Descriptions (Continued) | Signal Name | Pin | Туре | Description | |-------------------------------------------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DSTROBE<br>(UDMA read<br>protocol active) | | | In all modes, when UDMA mode DMA read is active, this signal is the data in strobe generated by the device. Both the rising and falling edge of DSTROBE cause data to be latched by the host. The device may stop generating DSTROBE edges to pause a UDMA data in burst. | | -WE<br>(PC Card memory<br>mode) | 36 | I | This is a signal driven by the host and used for strobing memory write data to the registers of the SiliconDrive II CF when the card is configured in the memory interface mode. This signal is also used for writing the configuration registers. | | -WE<br>(PC Card I/O<br>mode) | | | In PC Card I/O mode, this signal is used for writing the configuration registers. | | -WE<br>(True IDE mode) | | | In true IDE mode, this input signal is not used and should be connected to V <sub>CC</sub> by the host. | | WP<br>(PC Card memory<br>mode) | 24 | 0 | Write Protect Memory Mode. The SiliconDrive II CF does not have a write protect switch. This signal is held low after the completion of the reset initialization sequence. | | -IOIS16<br>(PC Card I/O<br>mode) | | | I/O Operation. When the SiliconDrive II CF is configured for I/O operation, pin 24 is used for the -I/O Selected, which is a 16-bit port (-IOIS16) function. A low signal indicates that a 16-bit or odd byte only operation can be performed at the addressed port. | | -IOCS16<br>(True IDE mode) | | | In true IDE mode, this output signal is the Pass Diagnostic signal in the Master/Slave handshake protocol | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. ### **ABSOLUTE MAXIMUM RATINGS** Table 8: Absolute Maximum Ratings | Symbol | Parameter | Minimum | Maximum | Units | |------------------|-------------------------------------|---------|-----------------------|-------| | T <sub>S</sub> | Storage Temperature | -55 | 125 | °C | | $T_A$ | Operating Temperature | -40 | 85 | °C | | V <sub>CC</sub> | V <sub>CC</sub> with Respect to GND | -0.5 | V <sub>CC</sub> + 0.5 | V | | $V_{IN}$ | Input Voltage | -0.3 | $V_{CC} + 0.3$ | V | | V <sub>OUT</sub> | Output Voltage | - | 6.0 | V | # **DC CHARACTERISTICS** Table 9: DC Characteristics | Symbol | Parameter | 3.3 V | ± 5% | 5V ± | : 10% | Units | |------------------|------------------------------------|---------|-----------------------|---------|-----------------------|-------| | Symbol | | Minimum | Maximum | Minimum | Maximum | | | V <sub>CC</sub> | Power Supply<br>Voltage | 3.15 | 3.45 | 4.5 | 5.5 | V | | I <sub>LI</sub> | Input Leakage<br>*(1) Current | - | 10 | - | 10 | μA | | I <sub>LO</sub> | Output<br>Leakage *(1)<br>Current | - | 10 | - | 10 | μΑ | | V <sub>CCR</sub> | V <sub>CC</sub> Read<br>Current | 50 | 100 | 60 | 120 | mA | | V <sub>CCW</sub> | V <sub>CC</sub> Write<br>Current | 50 | 100 | 60 | 120 | mA | | V <sub>CCS</sub> | V <sub>CC</sub> Standby<br>Current | - | 0.3 | - | 0.5 | mA | | V <sub>IL</sub> | Input Low<br>Voltage | -0.3 | V <sub>CC</sub> x 0.3 | -0.3 | V <sub>CC</sub> x 0.3 | V | | V <sub>IH</sub> | Input High<br>Voltage | 2.0 | V <sub>CC</sub> + 0.3 | 2.0 | V <sub>CC</sub> + 0.3 | V | | V <sub>OL</sub> | Output Low<br>Voltage | - | 0.45 | - | 0.45 | V | | V <sub>OH</sub> | Output High<br>Voltage | 2.4 | - | 2.4 | - | V | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 17 ### **AC CHARACTERISTICS** # **Attribute and Common Memory Read Timing** Figure 2: Attribute and Common Memory Read Timing Diagram Table 10: Attribute and Common Memory Read Timing | Symbol | Parameter | Minimum | Maximum | Units | |-----------------------|------------------------------------|---------|---------|-------| | t <sub>RC</sub> | Read Cycle Time | 250 | - | ns | | t <sub>A</sub> (A) | Address Access Time | - | 250 | ns | | t <sub>A</sub> (CE) | Card Enable Access Time | - | 250 | ns | | t <sub>A</sub> (OE) | Output Enable Access Time | - | 125 | ns | | t <sub>DIS</sub> (OE) | Output Disable Time from OE | - | 100 | ns | | t <sub>EN</sub> (OE) | Output Enable Time from OE | 5 | - | ns | | t <sub>AXQX</sub> | Data Valid from Address Change | 0 | - | ns | | t <sub>AVWL</sub> | Address Setup Time | 30 | - | ns | | t <sub>AXQX</sub> | Address Hold Time | 20 | - | ns | | t <sub>ELWL</sub> | Card Enable Setup Time before OE | 10 | - | ns | | t <sub>GHEH</sub> | Card Enable Hold Time following OE | 15 | - | ns | ### SILICONSYSTEMS PROPRIETARY # A[10::0], REG TELWH TELWH TELWH TELWH TELWH TELWH TOWHAX TOWHOL TOWH # **Attribute and Common Memory Write Timing** Figure 3: Attribute and Common Memory Write Timing Diagram Table 11: Attribute and Common Memory Write Timing | Symbol | Parameter | Minimum | Maximum | Units | |-------------------|----------------------------------|---------|---------|-------| | t <sub>WR</sub> | Write Cycle Time | 250 | - | ns | | t <sub>WLWH</sub> | Write Pulse Width | 150 | - | ns | | t <sub>AVWL</sub> | Address Setup Time | 30 | - | ns | | t <sub>AVWH</sub> | Address Setup Time for WE | 30 | - | ns | | t <sub>ELWH</sub> | Card Enable Setup Time for WE | 30 | - | ns | | t <sub>WHDX</sub> | Data Hold Time | 30 | - | ns | | t <sub>WHAX</sub> | Write Recover Time | 15 | - | ns | | t <sub>WLQZ</sub> | Output Disable Time from WE | - | 100 | ns | | t <sub>OLWH</sub> | Output Disable Time from OE | - | 100 | ns | | t <sub>WHOX</sub> | Output Enable Time from WE | 10 | - | ns | | t <sub>OHDX</sub> | Output Enable Time from OE | 10 | - | ns | | t <sub>WLOL</sub> | Output Enable Setup for WE | 10 | - | ns | | t <sub>WHOL</sub> | Output Enable Hold from WE | 10 | - | ns | | t <sub>ELWL</sub> | Card Enable Setup Time before WE | 0 | - | ns | | t <sub>GHEH</sub> | Card Enable Hold Time from WE | 15 | - | ns | | $t_{DVWH}$ | Data Setup Time | 80 | - | ns | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. # REG trauct trauc # I/O Access Read Timing Figure 4: I/O Access Read Timing Diagram | Symbol | Parameter | Minimum | Maximum | Units | |---------------------|-----------------------------------|---------|---------|-------| | t <sub>DVRL</sub> | Data Delay after IORD | - | 45 | ns | | t <sub>IGHQX</sub> | Data Hold following IORD | 5 | - | ns | | t <sub>IGLIGH</sub> | IORD Pulse Width | 55 | - | ns | | t <sub>AVIGL</sub> | Address Setup before IORD | 15 | - | ns | | t <sub>GHAX</sub> | Address Hold following IORD | 10 | - | ns | | t <sub>CLIGL</sub> | CE Setup before IORD | 5 | - | ns | | t <sub>CHIGH</sub> | CE Hold following IORD | 10 | - | ns | | t <sub>RLIGL</sub> | REG Setup before IORD | 5 | - | ns | | t <sub>RHIGH</sub> | REG Hold following IORD | 0 | - | ns | | t <sub>IGLINL</sub> | INPACK Delay falling from IORD | 0 | 45 | ns | | t <sub>IGHINH</sub> | INPACK Delay Rising from IORD | - | 45 | ns | | t <sub>AVISL</sub> | IOIS16 Delay Falling from Address | - | 35 | ns | | t <sub>AXISH</sub> | IOIS16 Delay Rising from Address | - | 35 | ns | Table 12: I/O Access Read Timing ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 20 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # REG touch touc # I/O Access Write Timing Figure 5: I/O Access Write Timing Diagram Table 13: I/O Access Write Timing | Symbol | Parameter | Minimum | Maximum | Units | |---------------------|-----------------------------------|---------|---------|-------| | t <sub>IGHDX</sub> | Data Hold following IOWR | 5 | - | ns | | t <sub>IGHQX</sub> | Data Setup before IOWR | 15 | - | ns | | t <sub>IGLIGH</sub> | IOWR Pulse Width | 55 | - | ns | | t <sub>AVIGL</sub> | Address Setup before IOWR | 15 | - | ns | | t <sub>AXIGH</sub> | Address Hold following IOWR | 10 | - | ns | | t <sub>CLIGL</sub> | CE Setup before IOWR | 5 | - | ns | | t <sub>CHIGH</sub> | CE Hold following IOWR | 10 | - | ns | | t <sub>RLIGL</sub> | REG Setup before IOWR | 5 | - | ns | | t <sub>RHIGH</sub> | REG Hold following IOWR | 0 | - | ns | | t <sub>AVISL</sub> | IOIS16 Delay Falling from Address | - | 35 | ns | | t <sub>AXISH</sub> | IOIS16 Delay Rising from Address | - | 35 | ns | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. ### True IDE PIO Mode Read/Write Access Timing Figure 6: True IDE PIO Mode Read/Write Access Timing Diagram ### Notes: - 1. The device address consists of -CS0, -CS1, and A[02::00]. - 2. The data consists of D[15::00] (16-bit) or D[07::00] (8 bit). - 3. -IOCS16 is shown for PIO modes 0, 1, and 2. For other modes, this signal is ignored. - 4. The negation of IORDY by the device is used to extend the PIO cycle. The determination of whether the cycle is to be extended is made by the host after t<sub>A</sub> from the assertion of -IORD or -IOWR. The assertion and negation of IORDY is described in the following three cases: - a. The device never negates IORDY; no wait is generated. - b. The device starts to drive IORDY low before $t_A$ , but causes IORDY to be asserted before $t_A$ ; no wait generated. - c. The device drives IORDY low before $t_A$ ; wait generated. The cycle completes after IORDY is reasserted. For cycles where a wait is generated and -IORD is asserted, the device places read data on D15-D00 for $t_{RD}$ before causing IORDY to be asserted. ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Symbol Item Mode 1 Mode 2 Mode 3 Mode 4 Mode 5 Mode 0 Mode 6 Note Units $t_0$ Cycle Time (minimum) 600 383 240 180 120 100 80 1 t<sub>1</sub> Address Valid to 70 50 30 30 25 15 10 ns IORD/-IOWR Setup (minimum) 70 t<sub>2</sub> -IORD/-IOWR (minimum) 165 125 100 80 65 55 1 ns -IORD/-IOWR (minimum) 290 290 290 80 70 65 55 1 $t_2$ ns register (8 bit) -IORD/-IOWR Recovery t<sub>2i</sub> 70 25 25 20 1 ns Time (minimum) -IOWR Data Setup 45 30 30 20 20 15 $t_3$ 60 ns (minimum) t<sub>4</sub> -IOWR Data Hold 30 20 15 10 10 5 5 ns (minimum) t<sub>5</sub> -IORD Data Setup 50 35 20 20 20 15 10 ns (minimum) $t_6$ -IORD Data Hold 5 5 5 5 5 5 5 ns (minimum) $t_{6Z}$ -IORD Data Tristate 30 30 30 30 30 20 20 2 (maximum) Address Valid to IOCS16 90 50 40 N/A N/A N/A N/A 4 $t_7$ ns Assertion (maximum) 45 30 N/A N/A t<sub>8</sub> Address Valid to IOCS16 N/A N/A 4 ns Released (maximum) t<sub>9</sub> -IORD/-IOWR to 20 15 10 10 10 10 10 ns Address Valid Hold 0 0 0 0 0 0 0 Read Data Valid to $t_{RD}$ ns **IORDY** Active (minimum), if IORDY is initially low after t<sub>A</sub> IORDY Setup Time 35 35 35 35 35 $t_A$ N/A<sup>5</sup> N/A<sup>5</sup> 3 ns $t_B$ **IORDY Pulse Width** 1250 1250 1250 1250 1250 $N/A^5$ ns N/A<sup>5</sup> (maximum) t<sub>C</sub> **IORDY** Assertion to 5 5 5 5 5 ns N/A<sup>5</sup> N/A<sup>5</sup> Release (maximum) Table 14: True IDE PIO Mode Read/Write Access Timing #### Notes: - 1. The symbol $t_0$ is the minimum total cycle time, $t_2$ is the minimum command active time, and $t_{2i}$ 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_{2i}$ must be met. The minimum total cycle time requirement is greater than the sum of $t_2$ and $t_{2i}$ . This means a host implementation can lengthen either or both $t_2$ or $t_{2i}$ to ensure that $t_0$ is equal to or greater than the value reported in the device's identify device data. - 2. This parameter specifies the time from the negation edge of -IORD to the time that the data bus is no longer driven by the CF (tristate). #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. - 3. The delay from the activation of -IORD or -IOWR until the state of IORDY is first sampled. If IORDY is inactive, then the host waits until IORDY is active before the PIO cycle can be completed. If the CF is not driving IORDY negated at $t_A$ after the activation of -IORD or -IOWR, then $t_5$ must be met and $t_{RD}$ is not applicable. If the CF is driving IORDY negated at the time $t_A$ after the activation of -IORD or -IOWR, then $t_{RD}$ must be met and $t_5$ is not applicable. - 4. The symbols t<sub>7</sub> and t<sub>8</sub> apply only to modes 0, 1, and 2. For other modes, this signal is not valid. - 5. IORDY is not supported in this mode. PAGE 24 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## True IDE Multiword DMA Read/Write Access Timing This function does not apply to SiliconDrive IIs that have DMA disabled. Figure 7: True IDE Multiword DMA Read/Write Access Timing #### Notes: - 1. If the drive cannot sustain continuous, minimum cycle time DMA transfers, it may negate DMARQ within the time specified from the start of a DMA transfer cycle to suspend the DMA transfers in progress, and reassert the signal at a later time to continue the DMA operation. - 2. This signal may be negated by the host to suspend the DMA transfer in progress. | Symbol | Item | Mode 0 | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Note | Units | |----------------|--------------------------------------------|--------|--------|--------|--------|--------|------|-------| | t <sub>O</sub> | Cycle Time (minimum) | 480 | 150 | 120 | 100 | 80 | 1 | ns | | t <sub>D</sub> | -IORD/-IOWR<br>Asserted Width<br>(minimum) | 215 | 80 | 70 | 65 | 55 | 1 | ns | | t <sub>E</sub> | -IORD Data Access<br>(maximum) | 150 | 60 | 50 | 50 | 45 | - | ns | | t <sub>F</sub> | -IORD Data Hold<br>(minimum) | 5 | 5 | 5 | 5 | 5 | - | ns | | $t_{G}$ | -IORD/-IOWR Data<br>Setup (minimum) | 100 | 30 | 20 | 15 | 10 | - | ns | Table 15: True IDE Multiword DMA Read/Write Access Timing #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. | Symbol | Item | Mode 0 | Mode 1 | Mode 2 | Mode 3 | Mode 4 | Note | Units | |-----------------|-----------------------------------------------|--------|--------|--------|--------|--------|------|-------| | t <sub>H</sub> | -IOWR Data Hold<br>(minimum) | 20 | 15 | 10 | 5 | 5 | - | ns | | tı | DMACK to -IORD/-<br>IOWR Setup<br>(minimum) | 0 | 0 | 0 | 0 | 0 | - | ns | | tu | -IORD / -IOWR to -<br>DMACK Hold<br>(minimum) | 20 | 5 | 5 | 5 | 5 | - | ns | | t <sub>KR</sub> | -IORD Negated Width (minimum) | 50 | 50 | 25 | 25 | 20 | 1 | ns | | t <sub>KW</sub> | -IOWR Negated Width (minimum) | 215 | 50 | 25 | 25 | 20 | 1 | ns | | t <sub>LR</sub> | -IORD to DMARQ<br>Delay (maximum) | 120 | 40 | 35 | 35 | 35 | - | ns | | t <sub>LW</sub> | -IOWR to DMARQ<br>Delay (maximum) | 40 | 40 | 35 | 35 | 35 | - | ns | | t <sub>M</sub> | CS(1:0) Valid to –<br>IORD / -IOWR | 50 | 30 | 25 | 10 | 5 | - | ns | | t <sub>N</sub> | CS(1:0) Hold | 15 | 10 | 10 | 10 | 10 | - | ns | | t <sub>Z</sub> | -DMACK | 20 | 25 | 25 | 25 | 25 | - | ns | ### Notes: 1. The symbol $t_0$ is the minimum total cycle time and $t_D$ is the minimum command active time, while $t_{KR}$ and $t_{KW}$ are the minimum command recovery times or command inactive times for input and output cycles, respectively. 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_D$ , $t_{KR}$ , and $t_{KW}$ must be met. The minimum total cycle time requirement is greater than the sum of $t_D$ and $t_{KR}$ , or $t_{KW}$ for input and output cycles, respectively. This means a host implementation can lengthen either or both of $t_D$ and either of $t_{KR}$ and $t_{KW}$ as needed to ensure that $t_0$ is equal to or greater than the value reported iN The device's identify device data. PAGE 26 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## **Ultra DMA Data Burst Timing Requirements** The following figures and table describe the requirements for the Ultra DMA (UDMA) data burst timing. Figure 8: Initiating a UDMA Data-In Burst **Note:** The definitions for the DIOW-:STOP, DIOR-:HDMARDY-:HSTROBE, and IORDY:DDMARDY-:DSTROBE signal lines are not in effect until DMARQ and DMACK are asserted. This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 27 Figure 9: Sustained UDMA Data-In Burst **Note:** DD(15:0) and DSTROBE signals are shown at both the host and the device to emphasize that the cable settling time as well as cable propagation delay does not allow the data signals to be considered stable at the host until some time after they are driven by the device. Figure 10: Host Pausing a UDMA Data-In Burst ## Notes: - 1. The host may assert STOP to request termination of the UDMA burst no sooner than $t_{RP}$ after HDMARDY- is negated. - 2. If the t<sub>SR</sub> timing is not satisfied, the host may receive zero, one, or two more data words from the device. #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 28 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Figure 11: Device Terminating a UDMA Data-In Burst **Note:** The definitions for the DIOW-:STOP, DIOR-:HDMARDY-:HSTROBE, and IORDY:DDMARDY-:DSTROBE signal lines are no longer in effect after DMARQ and DMACK are negated. This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Figure 12: Host Terminating a UDMA Data-In Burst **Note:** The definitions for the DIOW-:STOP, DIOR-:HDMARDY-:HSTROBE, and IORDY:DDMARDY-:DSTROBE signal lines are no longer in effect after DMARQ and DMACK are negated. Figure 13: Initiating a UDMA Data-Out Burst **Note:** The definitions for the DIOW-:STOP, IORDY:DDMARDY:DSTROBE, and DIOR-:HDMARDY-:HSTROBE signal lines are not in effect until DMARQ and DMACK are asserted. Figure 14: Sustained UDMA Data-Out Burst **Note:** DD(15:0) and HSTROBE signals are shown at both the device and the host to emphasize that the cable settling time as well as cable propagation delay does not allow the data signals to be considered stable at the device until some time after they are driven by the host. #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Figure 15: Device Pausing a UDMA Data-Out Burst ### Notes: - 1. The device may negate DMARQ to request termination of the UDMA burst no sooner than $t_{\rm RP}$ after DDMARDY- is negated. - 2. If the t<sub>SR</sub> timing is not satisfied, the host may receive zero, one, or two more data words from the host. Figure 16: Host Terminating a UDMA Data-Out Burst **Note:** The definitions for the DIOW-:STOP, IORDY:DDMARDY:DSTROBE, and DIOR-:HDMARDY:HSTROBE signal lines are no longer in effect after DMARQ and DMACK are negated. This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Figure 17: Device Terminating a UDMA Data-Out Burst **Note:** The definitions for the DIOW-:STOP, IORDY:DDMARDY:DSTROBE, and DIOR-:HDMARDY:HSTROBE signal lines are no longer in effect after DMARQ and DMACK are negated. Table 16: UDMA Data Burst Timing Requirements | | Мо | de 0 | Мо | de 1 | Мо | de 2 | Мо | de 3 | Мо | de 4 | Comment (see Notes 1 and | | |----------------------|------|------|------|------|------|------|------|------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------|-------| | Symbol | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | 2) | Units | | t <sub>2CYCTYP</sub> | 240 | - | 160 | - | 120 | - | 90 | - | 60 | - | Typical sustained average two-cycle time. | ns | | tcyc | 112 | - | 73 | - | 54 | - | 39 | - | 25 | - | Cycle time allowing for asymmetry and clock variations (from STROBE edge to STROBE edge). | ns | | t <sub>2CYC</sub> | 230 | - | 154 | - | 115 | - | 86 | - | 57 | - | Two-cycle time allowing for clock variations (from rising edge to next rising edge, or from falling edge to next falling edge of STROBE). | ns | | t <sub>DS</sub> | 15 | | 10 | | 7 | | 7 | | 5 | | Data setup time at recipient. | ns | | t <sub>DH</sub> | 5 | - | 5 | - | 5 | - | 5 | - | 5 | - | Data hold time at recipient. | ns | | t <sub>DVS</sub> | 70 | - | 48 | - | 30 | - | 20 | - | 6 | - | Data valid setup time at sender (from data valid until STROBE edge) (see Note 4). | ns | | t <sub>DVH</sub> | 6 | - | 6 | - | 6 | - | 6 | - | 6 | - | Data valid hold time at sender<br>(from STROBE edge until<br>data may become invalid)<br>(see Note 4). | ns | | t <sub>FS</sub> | 0 | 230 | 0 | 200 | 0 | 170 | 0 | 130 | 0 | 120 | First STROBE time (for device to first negate DSTROBE from STOP during a data-in burst). | ns | | t <sub>LI</sub> | 0 | 150 | 0 | 150 | 0 | 150 | 0 | 100 | 0 | 100 | Limited interlock time (see Note 3). | ns | | t <sub>MLI</sub> | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | Interlock time with minimum (see Note 3). | ns | | t <sub>UI</sub> | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | Unlimited interlock time (see Note 3). | ns | | t <sub>AZ</sub> | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | Maximum time allowed for output drivers to release (from asserted or negated). | ns | | t <sub>ZAH</sub> | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | Minimum delay time required for output. | ns | | $t_{ZAD}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | Drivers to assert or negate (from released). | ns | | t <sub>ENV</sub> | 20 | 70 | 20 | 70 | 20 | 70 | 20 | 55 | 20 | 55 | Envelope time (from DMACK-to STOP and HDMARDY-during data-in burst initiation, and from DMACK to STOP during data-out burst initiation). | ns | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 16: UDMA Data Burst Timing Requirements (Continued) | Symbol | Мо | de 0 | Мо | de 1 | Мо | de 2 | Мо | de 3 | Мо | de 4 | Comment (see Notes 1 and | Units | |---------------------|------|------|------|------|------|------|------|------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | Syllibol | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | 2) | Oilits | | t <sub>SR</sub> | - | 50 | - | 30 | - | 20 | - | NA | - | NA | STROBE to DMARDY- time<br>(if DMARDY- is negated<br>before this long after<br>STROBE edge, the recipient<br>receives no more than one<br>additional data word). | ns | | t <sub>RFS</sub> | - | 75 | - | 70 | - | 60 | - | 60 | - | 60 | Ready-to-final STROBE time<br>(no STROBE edges are sent<br>this long after negation of<br>DMARDY-). | ns | | t <sub>RP</sub> | 160 | - | 125 | - | 100 | - | 100 | | 100 | - | Minimum time to assert STOP or negate DMARQ. | ns | | t <sub>IORDYZ</sub> | - | 20 | - | 20 | - | 20 | - | 20 | - | 20 | Maximum time before releasing IORDY. | ns | | t <sub>ZIORDY</sub> | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | Minimum time before driving STROBE (see note 5). | ns | | t <sub>ACK</sub> | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | Setup and hold times for DMACK- (before assertion or negation). | ns | | t <sub>SS</sub> | 50 | - | 50 | - | 50 | - | 50 | - | 50 | - | Time from STROBE edge to<br>negation of DMARQ or<br>assertion of STOP (when the<br>sender terminates a burst). | ns | #### Notes: Timing parameters are measured at the connector of the sender or receiver to which the parameter applies. Both STROBE and DMARDY- timing measurements are taken at the sender's connector. $\it Example:$ For example, the sender stops generating STROBE edges $\it t_{RFS}$ after the negation of DMARDY-. - 2. All timing measurement switching points (low-to-high and high-to-low) are taken at 1.5V. - 3. The symbols t<sub>UI</sub>, t<sub>MLI</sub>, and t<sub>LI</sub> indicate sender-to-recipient or recipient-to-sender interlocks (i.e., either the sender or recipient is waiting for the other to respond with a signal before proceeding). The symbol t<sub>UI</sub> is an unlimited interlock that has no maximum time value, t<sub>MLI</sub> is a limited time-out that has a defined minimum, and t<sub>LI</sub> is a limited time-out that has a defined maximum. - The test load for t<sub>DVS</sub> and t<sub>DVH</sub> are a lumped capacitor load with no cable or receivers. Timing for t<sub>DVS</sub> and t<sub>DVH</sub> are met for all capacitive loads from 15pf to 40pf where all signals have the same capacitive load value. - The symbol t<sub>ZIORDY</sub> may be greater than t<sub>ENV</sub> since the device has a pull-up on IORDY- giving it a known state when released. This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 36 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## ATTRIBUTE MEMORY DESCRIPTION AND OPERATION The attribute memory plane can be read or written to by asserting the REG# signal, qualified by the appropriate combination of CE1#, OE#, and WE#. An attribute memory map describing the type and location of the information maintained in the attribute memory plane is provided in "Attribute Memory Map" on page 39. With respect to SiliconDrive II CF, attribute memory consists of two sections: - Card Information Structure (CIS), which contains a description of the Card's capabilities and specifications. - Function Configuration Registers (FCRs), which consists of four registers, that can be read or written to by a host to configure the Card for specific purposes. ## **ATTRIBUTE MEMORY READ OPERATIONS** Attribute memory read operations are enabled by asserting REG#, OE#, and CE1# low. Odd byte read operations from the attribute memory plane are not valid. **Function** REG# CE1# CE2# A0 OE# WE# D[15:8] D[7:0] Mode Standby L Н Η X X X High-Z High-Z Н Byte Access L L Н L L High-Z Even Н Н Not Valid L Н L High-Z Word Access L Χ L Н Not Valid Even Odd Byte Н Χ Н Н Not Valid High-Z L L Only Access Table 17: Attribute Memory Read Operations #### SILICONSYSTEMS PROPRIETARY # **ATTRIBUTE MEMORY WRITE OPERATIONS** Attribute memory write operations are enabled by asserting REG#, WE#, and CE1# low. Odd byte write operations from the attribute memory plane are not valid. Table 18: Attribute Memory Write Operations | Function<br>Mode | REG# | CE1# | CE2# | A0 | OE# | WE# | D[15:8] | D[7:0] | |-------------------------|------|------|------|----|-----|-----|-----------|-----------| | Standby | L | Н | Н | Χ | Χ | Χ | High-Z | High-Z | | Byte Access | L | L | Н | L | Н | L | High-Z | Even | | | L | Н | L | Н | Н | L | High-Z | Not Valid | | Word Access | L | L | L | Χ | Н | L | Not Valid | Even | | Odd Byte<br>Only Access | L | L | Н | X | Н | Н | Not Valid | High-Z | PAGE 38 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## **ATTRIBUTE MEMORY MAP** As stated earlier, the Attribute Memory plane is comprised of two components, the CIS and the FCRs. The following tables detail the type, location, and read/write requirements for each of the four FCRs maintained in the attribute memory plane. Table 19: Attribute Memory Map | Register | Operation | Addr | CE1# | REG# | WE# | OE# | |-------------------------------|-----------|------|------|------|-----|-----| | Card Information Structure | Read | Χ | 0 | 0 | 1 | 0 | | | Write | Χ | 0 | 0 | 0 | 1 | | Configuration Option | Read | 200h | 0 | 0 | 1 | 0 | | | Write | 200h | 0 | 0 | 0 | 1 | | Card Configuration and Status | Read | 202h | 0 | 0 | 1 | 0 | | | Write | 202h | 0 | 0 | 0 | 1 | | Pin Replacement | Read | 204h | 0 | 0 | 1 | 0 | | | Write | 204h | 0 | 0 | 0 | 1 | | Socket and Copy | Read | 206h | 0 | 0 | 1 | 0 | | | Write | 206h | 0 | 0 | 0 | 1 | ## **CARD INFORMATION STRUCTURE** The CIS is data that describes the SiliconDrive II CF, and is described by the CFA standard. This information can be used by the host system to determine a number of things about the Card that has been inserted. For information regarding the exact nature of this data and how to design the host software to interpret it, refer to the *PC Card Standard Metaformat Specification*. Table 20: Card Information Structure | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | | | | |---------------------|------|--------------------------------------------|--------------------------------|---------------------------------------------------|--------|--------------|----------------|----------------------|------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|--| | 00h | 01h | | | CIS | TPL_ | DEV | 'ICE | | | Device information tuple | Tuple code | | | | | 02h | 03h | | | | | - | | | | Link length is 3 bytes | Link to next tuple | | | | | 04h | D9h | D | Co | e Typ<br>de<br>= I/O | е | W<br>1 | | Device<br>Speed<br>1 | | <ul><li>I/O device</li><li>No WP</li><li>Speed = 100ns</li></ul> | <ul><li>Device ID</li><li>WPS</li><li>Device speed</li></ul> | | | | | 06h | 01h | | | 1X | | | | 2K | | 2KB of address space | Device size | | | | | 08h | FFh | | | List | Enc | l Mar | ker | | | End of device | END marker | | | | | 0Ah | 1Ch | | С | ISTP | L_D | EVIC | E_O | С | | Other conditions device in tuple code | Tuple code | | | | | 0Ch | 04h | | TPL_LINK | | | | | | | Link length is 4 bytes Link to next t | | | | | | 0Eh | 02h | | E | XT F | | rved<br>/AIT | V <sub>C</sub> | 2 | | 3V, wait is Not Used | Other conditions information field | | | | | 10h | D9h | D | revice Type W Device P Speed S | | | | | | | <ul> <li>Device type = DH: I/O</li> <li>Device WPS = 1: No WP</li> <li>Device speed = 1: 250ns</li> </ul> | - | | | | | 12h | 01h | | 1 | Х | | | 2K | units | | 2KB of address space | Device size | | | | | 14h | FFh | | | List | End | Mar | ker | | | End of device | End marker | | | | | 16h | 18h | | ( | CIST | PL_ | JEDE | C_C | ; | | JEDEC ID common memory | Tuple code | | | | | 18h | 02h | | | 7 | ΓPL_ | LIN | ( | | | Link length is 2 bytes | Link to next tuple | | | | | 1Ah | DFh | PO | CMC | IA Ma | anuf | actur | er's . | JEDE | C | Manufacturer's ID code - | -<br>JEDEC ID | | | | | 1Ch | 01h | P | СМС | CMCIA JEDEC Device Code Second byte of JEDEC ID - | | | | - | | | | | | | | 1Eh | 20h | | | CIS | TPL_ | MAN | IFID | | | Manufacturer's ID code | Tuple code | | | | | 20h | 04h | | | - | ΓPL_ | LIN | ( | | | - | - | | | | | 22h | 00h | Low | Byte | of P | | IA M<br>de | anuf | actur | er's | JEDEC manufacturer's ID | Low byte of manufacturer's code | | | | | 24h | 00h | High Byte of PCMCIA<br>Manufacturer's Code | | | | | | | | Code of 0, because the other byte is the<br>JEDEC 1 byte manufacturer's ID | High byte of the manufacturer's code | | | | | 26h | 00h | | Low | / Byte | e of I | Produ | ıct C | ode | | Manufacturer's code for SiliconDrive II CF | Low byte of the product code | | | | | 28h | 00h | | High | n Byt | e of | Prod | uct C | ode | | Manufacturer's code for SiliconDrive II<br>CF | High byte of the product code | | | | | 2Ah | 21h | | | CIS | TPL_ | FUN | CID | | Function ID tuple Tuple code | | | | | | | 2Ch | 02h | | | 1 | ΓPL_ | LIN | ( | | | Link length is 2 bytes | Link to next tuple | | | | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 40 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | | | | |---------------------|------|-----------------------------------|-------|--------|-------|-------|------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|--|--| | 2Eh | 04h | | TPL | FID_ | FUN | СТІС | N = | 04H | | Disk function, which may be silicon or removable | PC Card function code | | | | | 30h | 01h | | Rese | ervec | I | R | | Р | | <ul><li>R = 0: No BIOS ROM</li><li>P = 1: Configure card at power-on</li></ul> | System initialization byte | | | | | 32h | 22h | | | CIS | TPL | _FU1 | NCE | | | Function extension tuple | Tuple code | | | | | 34h | 02h | | | • | TPL_ | LIN | ( | | | Link length is 2 bytes | Link to next tuple | | | | | 36h | 01h | Disk Function Extension Tuple Typ | | | | | | | | Disk interface type | Extension tuple type for disk | | | | | 38h | 01h | | | Disk | Inter | face | Туре | ) | | PC Card interface type | Interface type | | | | | 3Ah | 22h | | | CIS | TPL | _FUI | NCE | | | Function extension tuple | Tuple code | | | | | 3Ch | 03h | | | • | TPL_ | LIN | ( | | | Link length is 3 bytes | Link to next tuple | | | | | 3Eh | 02h | Disk | k Fur | nction | Ext | ensio | n Tu | iple T | Гуре | Basic PCMCIA-ATA extension tuple | Extension tuple type for disk | | | | | 40h | 04h | Re | eserv | ed | D | U | S | ٧ | | No Vpp, silicon, single drive | Basic ATA option | | | | | | | | | | | | | | | <ul> <li>V = 0: No Vpp required parameters by</li> <li>S = 0: Silicon</li> <li>U = 1: Unique serial number</li> <li>D = 0: Single drive on Card</li> </ul> | | | | | | 42h | 07h | R | ı | E | N | P3 | P2 | P1 | P0 | <ul> <li>P0: Sleep mode supported</li> <li>P1: Standby mode supported</li> <li>P2: Idle mode supported</li> <li>P3: Drive auto power control</li> <li>N: Some configuration excludes 3X7</li> <li>E: Index bit is emulated</li> <li>I: Twin IOIS16# data register only</li> <li>R: Reserved</li> </ul> | Basic ATA option parameters byte 2 | | | | | 44h | 1Ah | | | CIS | TPL_ | CON | IFIG | | | Configuration tuple | Tuple code | | | | | 46h | 05h | | | • | TPL_ | LIN | ( | | | Link length is 5 bytes | Link to next tuple | | | | | 48h | 01h | RA | AS | RI | ИS | R/ | AS | | - | <ul> <li>RFS: Reserved</li> <li>RMS: TPCC RMSK size -1 = 0</li> <li>RAS: TPCC_RADR size -1 = 1</li> <li>1-byte register mask</li> <li>2-byte configuration base address</li> </ul> | Size of fields byte<br>TPCC_SZ | | | | | 4Ah | 07h | | | Т | PCC. | _LAS | ST | | | Entry with configuration index of 7 is final entry in table | Last entry of configuration registers | | | | | 4Ch | 00h | TPCC_RADR (LSB) | | | | | | | | Configuration registers are located at 200H in REG space | Location of configuration registers | | | | | 4Eh | 02h | | 7 | TPCC | _RA | DR ( | MSE | 3) | | - | - | | | | | 50h | 0Fh | Re | eserv | red | S | Р | С | I | - | <ul> <li>I: Configuration index</li> <li>C: Configuration and status</li> <li>P: Pin replacement</li> <li>S: Socket and copy</li> </ul> | Configuration<br>registers present<br>mask<br>TPCC_RMSK | | | | | 52h | 1Bh | CISTPL_TABLE_ENTRY | | | | | | | | Configuration table entry tuple | Tuple code | | | | | 54h | 0Bh | | | - | TPL_ | LIN | ( | | | Link length is 11 bytes | Link to next tuple | | | | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | | | 0 | Description of Contents | CIS Function | | | |---------------------|------|----|-------|-------|--------------|--------|----------------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--|--| | 56h | C0h | I | D | | Conf | igura | ation | inde | X | Memory-mapped I/O configuration I = 1: Interface byte follows D = 1: Default entry Configuration index = 0 | Configuration table index byte TPCE_INDX | | | | 58h | C0h | W | R | Р | В | Int | Interface Type | | | <ul> <li>W = 0: Wait not used</li> <li>R = 1: Ready active</li> <li>P = 0: WP used</li> <li>B = 0: BVD1 and BVD2 not used</li> <li>IF type = 0: Memory interface</li> </ul> | Interface description field TPCE_IF | | | | 5Ah | A1h | M | MS | IR | IO | - | Т | I | P | <ul> <li>M = 1: Miscellaneous information present</li> <li>MS = 01: Memory space information single 2-byte length</li> <li>IR = 0: No interrupt information present</li> <li>IO = 0: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | | | | 5Ch | 27h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | | | 5Eh | 55h | Х | | Man | tissa | | E | pone | ent | Nominal voltage = 5V | V <sub>CC</sub> nominal value | | | | 60h | 4Dh | Х | M | antis | sa | | Ехро | onen | t | V <sub>CC</sub> nominal 4.5V | V <sub>CC</sub> minimum value | | | | 62h | 5Dh | Х | M | antis | ssa Exponent | | Exponent | | t | V <sub>CC</sub> nominal 5.5V | V <sub>CC</sub> maximum value | | | | 64h | 75h | Х | M | antis | sa | | Ехро | onen | t | Maximum average current over 10ms is 80mA | Maximum average current | | | | 66h | 08h | Le | ength | in 2 | 56 by | /tes p | page | s (LS | SB) | Length of memory space is 2KB | Memory space<br>description<br>structures<br>(TPCE_MS) | | | | 68h | 00h | Le | ngth | in 25 | 56 by | tes p | ages | s (MS | SB) | Length of memory space is 2KB | Memory space<br>description<br>structures<br>(TPCE_MS) | | | | 6Ah | 21h | X | R | Р | R | 0 | O AT - | | | <ul> <li>X = 0: No more miscellaneous fields</li> <li>R: Reserved</li> <li>P = 1: Powerdown supported</li> <li>RO = 0: Not read only mode</li> <li>A = 0: Audio not supported</li> <li>T = 0: Single drive</li> </ul> | Miscellaneous<br>features field<br>TPCE_MI | | | | 6Ch | 1Bh | | CIS | STPL | _TAI | BLE_ | ENT | RY | | Configuration table entry tuple | Tuple code | | | | 6Eh | 06h | | | - | TPL_ | LIN | < | | | Link length is 6 bytes | Link to next tuple | | | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 42 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | |---------------------|------|---|-----|-------|--------|-------|--------|----------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 70h | 00h | I | D | IR | IQ | Т | Р | - | | Memory-mapped I/O configuration I = 0: No interface byte D = 0: No default entry Configuration index = 0 | Configuration table index byte TPCE_INDX | | 72h | 01h | M | MS | IR | Ю | T | P | | - | <ul> <li>M = 0: No miscellaneous information</li> <li>MS = 00: No memory space information</li> <li>IR = 0: No interrupt information present</li> <li>IO = 0: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection<br>byte<br>TPCE_FS | | 74h | 21h | R | DI | PI | AI | SI | ΗV | //LV/ | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | 76h | B5h | Х | M | antis | sa | | Expo | nent | t | Nominal voltage = 3.0 V | V <sub>CC</sub> nominal value | | 78h | 1Eh | | l | | Exte | nsior | 1 | | | +0.3 V | Extension byte | | 7Ah | 4Dh | X | Ma | antis | sa | | Expo | nent | t | Maximum average current over 10ms is 45 mA | Maximum average current | | 7Ch | 1Bh | | CIS | STPL | _TAI | BLE_ | ENT | RY | | Configuration table entry tuple | Tuple code | | 7Eh | 0Dh | | | • | TPL_ | LIN | < | | | Link length is 10 bytes | Link to next tuple | | 80h | C1h | I | D | Con | figura | ation | II | NDE. | X | Contiguous I/O mapped ATA registers configuration I = 1: Interface byte follows D = 1: Default entry Configuration index = 1 | Configuration table index byte TPCE_INDX | | 82h | 41h | W | R | Р | В | Int | terfac | ace Type | | <ul> <li>W = 0: Wait not used</li> <li>R = 1: Ready active</li> <li>P = 0: WP not used</li> <li>B = 0: BVS1 and BVD2 not used</li> <li>IF type = 1: I/O interface</li> </ul> | Interface description field TPCE_IF | | 84h | 99h | M | MS | IR | Ю | Т | Р | | - | <ul> <li>M = 1: Miscellaneous information present</li> <li>MS = 00: No memory space information</li> <li>IR = 1: Interrupt information present</li> <li>IO = 1: I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | |---------------------|------|----|-----|-------|------|-------|-------|-------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | 86h | 27h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | 88h | 55h | Х | M | antis | sa | | Expo | nen | t | Nominal voltage = 5V | V <sub>CC</sub> nominal value | | 8Ah | 4Dh | Х | М | antis | sa | | Expo | nen | t | V <sub>CC</sub> nominal 4.5V | V <sub>CC</sub> minimum value | | 8Ch | 5Dh | Х | М | antis | sa | | Expo | nen | t | V <sub>CC</sub> nominal 5.5V | V <sub>CC</sub> maximum value | | 8Eh | 75h | Х | М | antis | sa | | Expo | nen | t | Maximum average current over 10ms is 80mA | Maximum average current | | 90h | 64h | R | S | Е | I | 0 | Ad | ddrLi | ne | <ul> <li>S = 1: 16-bit hosts supported</li> <li>E = 1: 8-bit hosts supported</li> <li>IO AddrLine: 4 lines decoded</li> </ul> | I/O space<br>description field<br>TPCE_IO | | 92h | F0h | S | P | L | M | V | В | 1 | N | <ul> <li>S = 1: Share logic active</li> <li>P = 1: Pulse mode IRQ supported</li> <li>L = 1: Level mode IRQ supported</li> <li>M = 1: Bit mask of IRQs present</li> <li>V = 0: No vender unique IRQ</li> <li>B = 0: No bus error IRQ</li> <li>I = 0: No IO check IRQ</li> <li>N = 0: No NMI</li> </ul> | Interrupt request<br>description structure<br>TPCE_IR | | 94h | FFh | IR SiliconSystems recommends the IRQ | Mask extension | | | | Q | Q | Q | Q | Q | Q | Q | Q | level to be routed 0 to 15 | byte 1 TPCE_IR | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | 96h | FFh | IR SiliconSystems recommends routing to | Mask extension | | | | Q | Q | Q | Q | Q | Q | Q | Q | any normal, maskable IRQ. | byte 2 TPCE_IR | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | 98h | 21h | X | R | P | R | 0 | Α | Т | - | <ul> <li>X = 0: No more miscellaneous fields</li> <li>R: Reserved</li> <li>P = 1: Powerdown supported</li> <li>RO = 0: Not read only mode</li> <li>A = 0: Audio not supported</li> <li>T = 0: Single drive</li> </ul> | Miscellaneous<br>features field<br>TPCE_MI | | 9Ah | 1Bh | | CIS | TPL. | TA | BLE | _EN | ΓRΥ | | Configuration table entry tuple | Tuple code | | 9Ch | 06h | | | | TPL_ | LIN | < | | | Link length is 6 bytes | Link to next tuple | | 9Eh | 01h | I | D | | Conf | igura | ition | Inde | K | Contiguous I/O mapped ATA registers configuration I = 0: No Interface byte D = 0: No Default entry Configuration index = 1 | Configuration table index Byte TPCE_INDX | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 44 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | |---------------------|------|---|-----|-------|------|-------|--------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | A0h | 01h | M | MS | IR | Ю | Т | P | | - | <ul> <li>M = 0: No miscellaneous information</li> <li>MS = 00: No memory space information</li> <li>IR = 0: No interrupt information present</li> <li>IO = 0: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | | A2h | 21h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | A4h | B5h | Х | Ma | antis | sa | | Expo | onen | t | Nominal voltage = 3.0V | V <sub>CC</sub> nominal value | | A6h | 1Eh | Х | M | antis | sa | | Expo | nen | t | +0.3V | Extension byte | | A8h | 4Dh | Х | Ma | antis | sa | | Expo | nen | t | Maximum average current over 10ms is 45mA | Maximum average current | | AAh | 1Bh | | CIS | STPL | _TAI | BLE_ | ENT | RY | | Configuration table entry tuple | Extension byte | | ACh | 12h | | | - | TPL_ | LIN | < | | | Link length is 18 bytes | Link to next tuple | | AEh | C2h | I | D | | Conf | igura | ition | Inde | x | ATA primary I/O mapped configuration I = 1: Interface byte follows D = 1: default entry follows Configuration index = 2 | Configuration table index byte TPCE_INDX | | B0h | 41h | W | R | Р | В | In | terfac | се Ту | /ре | <ul> <li>W = 0: Wait not used</li> <li>R = 1: Ready active</li> <li>P = 0: WP not used</li> <li>B = 0: BVS1 and BVD2 not used</li> <li>IF type = 1: I/O interface</li> </ul> | Interface description field TPCE_IF | | B2h | 99h | M | MS | IR | Ю | T | P | | - | <ul> <li>M = 1: Miscellaneous information present</li> <li>MS = 00: No memory space information</li> <li>IR = 1: Interrupt information present</li> <li>IO = 1: I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | | B4h | 27h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 45 Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | | |---------------------|------|----|-----|-----------------------|-------|-------|------|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|--| | B6h | 55h | Х | M | antis | sa | | Ехр | onent | | Nominal voltage = 5V | V <sub>CC</sub> nominal value | | | B8h | 4Dh | Х | M | antis | sa | | Ехро | onent | | V <sub>CC</sub> nominal 4.5V | V <sub>CC</sub> minimum value | | | BAh | 5Dh | Х | M | antis | sa | | Ехро | onent | | V <sub>CC</sub> nominal 5.5V | V <sub>CC</sub> maximum value | | | BCh | 75h | Х | M | antis | sa | | Ехро | onent | : | Maximum average current over 10ms is 80mA | Maximum average current | | | BEh | EAh | R | S | Е | I | 0 | A | ddrLii | ne | <ul> <li>R = 1: Range follows</li> <li>S = 1: 16-bit hosts supported</li> <li>E = 1: 8-bit hosts supported</li> <li>IO AddrLines: 10 lines decoded</li> </ul> | I/O space<br>description field<br>TPCE_IO | | | C0h | 61h | LS | AS | | | N Ra | ange | ; | | <ul> <li>LS = 1: Size of lengths is 1 byte</li> <li>AS = 2: Size of address is 2 bytes</li> <li>N Range = 1: Address Range-1</li> </ul> | I/O range format description | | | C2h | F0h | | Fi | irst I/ | 0 Ba | ise A | ddre | SS | | First I/O base address (LSB) | First I/O range address | | | C4h | 01h | | F | irst I/ | 0 Ba | se A | ddre | ss | | First I/O base address (MSB) | - | | | C6h | 07h | | Fi | irst I/ | 0 Ba | ise A | ddre | ss | | First I/O length -1 | First I/O range length | | | C8h | F6h | | Sec | ond I/O Base Address | | | | | | Second I/O base address (LSB) | Second I/O range address | | | CAh | 03h | | Sec | cond I/O Base Address | | | | | | Second I/O base address (MSB) | | | | CCh | 01h | | Sec | ond | I/O F | Range | e Le | ngth | | Second I/O length -1 | Second I/O range length | | | CEh | EEh | S | Р | L | М | IRQ | | Leve | I | <ul> <li>S = 1: Share logic active</li> <li>P = 1: Pulse mode IRQ supported</li> <li>L = 1: Level mode IRQ supported</li> <li>M = 0: Bit mask of IRQs present —<br/>IRQ level is IRQ14</li> </ul> | Interrupt request description structure TPCE_IR | | | D0h | 21h | X | R | P | R | 0 | A | Т | - | <ul> <li>X = 0: No more miscellaneous fields</li> <li>R: Reserved</li> <li>P = 1: Powerdown supported</li> <li>RO = 0: Not read only mode</li> <li>A = 0: Audio not supported</li> <li>T = 0: Single drive</li> </ul> | Miscellaneous<br>features field<br>TPCE_MI | | | D2h | 1Bh | | CIS | STPL | _TA | BLE_ | ENT | RY | | Configuration table entry tuple | Tuple code | | | D4h | 06h | | | | TPL_ | LINE | ( | | | Link length is 6 bytes | Link to next tuple | | | D6h | 02h | I | D | | Conf | igura | tion | Index | • | ATA primary I/O mapped configuration I = 0: No Interface byte D = 0: No Default entry Configuration index = 2 | Configuration table index byte TPCE_INDX | | | D8h | 01h | I | D | | Conf | igura | tion | Index | ( | Contiguous I/O mapped ATA registers configuration I = 0: No interface byte D = 0: No default entry Configuration index = 1 | Configuration table index byte TPCE_INDX | | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 46 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | |---------------------|------|---|-----|-------|------|-------|------|------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | DAh | 21h | M | MS | IR | Ю | Т | P | | - | <ul> <li>M = 0: No miscellaneous information</li> <li>MS = 00: No memory space information</li> <li>IR = 0: No interrupt information present</li> <li>IO = 0: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | | DCh | B5h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | DEh | 1Eh | Х | M | antis | sa | | Expo | nent | t | Nominal voltage = 3.0V | V <sub>CC</sub> nominal value | | E0h | 4Dh | | | | Exte | nsior | 1 | | | +0.3V | Extension byte | | E2h | 1Bh | | CIS | STPL | _TAE | BLE_ | ENT | RY | | Configuration table entry tuple | Tuple code | | E4h | 12h | | | • | TPL_ | LINE | ( | | | Link length is 18 bytes | Link to next tuple | | E6h | C3h | M | MS | IR | Ю | Т | P | | - | <ul> <li>M = 0: No miscellaneous information</li> <li>MS = 00: No memory space information</li> <li>IR = 0: No interrupt information present</li> <li>IO = 0: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | | E8h | 41h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | EAh | 99h | M | MS | IR | Ю | Т | P | | _ | <ul> <li>M = 1: No miscellaneous information</li> <li>MS = 00: No Memory space information</li> <li>IR = 1: No interrupt information present</li> <li>IO = 1: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 01: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | | | |---------------------|------|----|-----|-------|------|---------|------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--|--| | ECh | 27h | R | DI | PI | Al | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | | | EEh | 55h | X | M | antis | sa | | Expo | nent | | Nominal voltage = 5V | V <sub>CC</sub> nominal value | | | | F0h | 4Dh | Х | Ma | antis | sa | | Expo | nent | : | V <sub>CC</sub> nominal 4.5V | V <sub>CC</sub> minimum value | | | | F2h | 5Dh | Х | Ma | antis | sa | | Expo | nent | | V <sub>CC</sub> nominal 5.5V | V <sub>CC</sub> maximum value | | | | F4h | 75h | X | Ma | antis | sa | | Expo | nent | | Maximum average current over 10ms is 80mA | Maximum average current | | | | F6h | EAh | R | S | Е | I | 0 | Ac | ddrLi | ne | <ul> <li>R = 1: Range follows</li> <li>S = 1: 16-bit hosts supported</li> <li>E = 1: 8-bit hosts supported</li> <li>IO AddrLines: 10 lines decoded</li> </ul> | I/O space<br>description field<br>TPCE_IO | | | | F8h | 61h | LS | AS | | | N Range | | | | <ul> <li>LS = 1: Size of lengths is 1 byte</li> <li>AS = 2: Size of address is 2 bytes</li> <li>N Range = 1: Address range -1</li> </ul> | I/O range format description | | | | FAh | 70h | | | | | - | | | | First I/O base address (LSB) | First I/O range address | | | | FCh | 01h | | | | | - | | | | First I/O base address (MSB) | - | | | | FEh | 07h | | | | | - | | | | First I/O length -1 | First I/O range length | | | | 100h | 76h | | | | | - | | | | Second I/O base address (LSB) | Second I/O range address | | | | 102h | 03h | | | | | - | | | | Second I/O base address (MSB) | - | | | | 104h | 01h | | | | | - | | | | Second I/O length | Second I/O range length | | | | 106h | EEh | Ø | P | L | M | IRQ | I | Leve | I - | <ul> <li>S = 1: Share logic active</li> <li>P = 1: Pulse mode IRQ supported</li> <li>L = 1: Level mode IRQ supported</li> <li>M = 0: Bit mask of IRQs present — IRQ level is IRQ14</li> </ul> | Interrupt request<br>description structure<br>TPCE_IR<br>miscellaneous<br>features field<br>TPCE_MI | | | | 108h | 21h | X | R | Р | R | 0 | Α | T | - | <ul> <li>X = 0: No more miscellaneous fields</li> <li>R: Reserved</li> <li>P = 1: Powerdown supported</li> <li>RO = 0: Not read only mode</li> <li>A = 0: Audio not supported</li> <li>T = 0: Single drive</li> </ul> | | | | | 10Ah | 1Bh | | CIS | STPL | _TA | BLE_ | ENT | RY | | Configuration table entry tuple | Tuple code | | | | 10Ch | 06h | | | _ | TPL_ | LIN | ( | | | Link length is 6 bytes | Link to next tuple | | | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 48 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | |---------------------|------|---|----|-------|--------------|-------|----------|------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | 10Eh | 03h | ı | D | • | Conf | igura | ition | Inde | X | ATA primary I/O mapped configuration I = 0: No interface byte D = 0: No default entry Configuration index = 2 | Configuration table index byte TPCE_INDX | | 110h | 01h | M | MS | IR | Ю | Т | P | | - | <ul> <li>M = 0: No miscellaneous information</li> <li>MS = 00: No memory space information</li> <li>IR = 0: No interrupt information present</li> <li>IO = 0: No I/O port information present</li> <li>T = 0: No timing information present</li> <li>P = 1: V<sub>CC</sub> only information</li> </ul> | Feature selection byte TPCE_FS | | 112h | 21h | R | DI | PI | AI | SI | HV | LV | NV | Nominal voltage only follows R: Reserved DI: Powerdown current information PI: Peak current information AI: Average current information SI: Static current information HV: Maximum voltage information LV: Minimum voltage information NV: Nominal voltage information | Power parameters for V <sub>CC</sub> | | 114h | B5h | Х | Ма | antis | sa | | Exponent | | | Nominal voltage = 3.0V | V <sub>CC</sub> nominal value | | 116h | 1Eh | | | | Exte | nsion | | | | +0.3V | Extension byte | | 118h | 4Dh | X | Ma | antis | sa | | Expo | nen | t | Maximum average current over 10ms is 45mA | Maximum average current | | 11Ah | 1Bh | | | CIS | TPL_ | IAM | NFID | | | Manufacturer's ID code | Tuple code | | 11Ch | 04h | | | - | TPL_ | LIN | < | | | Link length is 4 bytes | Link to next tuple | | 11Eh | 07h | | D | ( | Conf | igura | ition | Inde | X | AT fixed disk secondary I/O 3.3V configuration | TPCE_INDX | | 120h | 00h | М | MS | IR | Ю | Т | Р | | - | P: Power information type | TPCL_FS | | 122h | 28h | | | | | - | | | | Manufacturer code for SiliconDrive II CF | Reserved | | 124h | D3h | | | | | - | | | | Manufacturer code for SiliconDrive II CF | Reserved | | 126h | 14h | | | CIST | PL_ | NO_ | LINK | | | No link control tuple | Tuple code | | 128h | 00h | | | | | - | | | | Link is 0 bytes | Link to next tuple | | 12Ah | 15h | | | CIS | TPL_ | VEF | RS_1 | | | Level 1 version | Tuple code | | 12Ch | 1Ah | | | - | TPL_ | LIN | < | | | Link length is 26h bytes | Link to next tuple | | 12Eh | 04h | | | TPF | LV1 | _MA | JOR | | | PC Card 2.0/JEIDA4.1 | END marker | | 130h | 01h | | | TPF | TPPLV1_MINOR | | | | | PC Card 2.0/JEIDA4.1 | Tuple code | | 132h | 53h | | | | | - | | | | S | Information string | | 134h | 49h | | | | | - | | | | I | - | | 136h | 4Ch | | | | | - | | | | L | - | | 138h | 49h | | | | | - | | | | I | - | | 13Ah | 43h | | | | | - | | | | С | - | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Table 20: Card Information Structure (Continued) | Attribute<br>Offset | Data | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description of Contents | CIS Function | |---------------------|------|---|---|---|---|---|---|---|---|-------------------------|--------------| | 13Ch | 4Fh | - | | | | | | | | 0 | - | | 13Eh | 4Eh | | | | | - | | | | N | - | | 140h | 53h | | | | | - | | | | S | - | | 142h | 59h | | | | | - | | | | Υ | - | | 144h | 53h | | | | | - | | | | S | - | | 146h | 54h | | | | | - | | | | Т | - | | | 45h | | | | | _ | | | | Е | - | | 14Ah | 4Dh | - | | | | | | | | М | - | | 14Ch | 53h | | | | | - | | | | S | - | | 14Eh | 00h | | | | | - | | | | Space | - | | 150h | 56h | | | | | - | | | | V | - | | 152h | 45h | | | | | - | | | | Е | - | | 154h | 52h | | | | | - | | | | R | - | | 156h | 32h | | | | | - | | | | 2 | - | | 158h | 2Eh | | | | | - | | | | - | - | | 15Ah | 30h | - | | | | | | | 0 | - | | | 15Ch | 30h | - | | | | 0 | - | | | | | | | 00h | - | | | | | | | - | - | | | 160h | FFh | | | | | - | | | | - | - | PAGE 50 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # **CONFIGURATION OPTION REGISTER (200H)** The Configuration Option register is used to configure the SiliconDrive II CF, define the address decoding, and initiate the software RESET sequence. Table 21: Configuration Option Register (200h) | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Read/<br>Write | SRESET | LevIREQ | | Co | onfigura | tion Ind | ex | | | Default<br>Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit(s) | Description | | | | | | | | | | | |---------------|---------------------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--|--|--|--|--| | SRESET | When set, this bit initiates a sis equivalent to a power-on re | software-reset sequence, which eset or hardware reset. | | | | | | | | | | | LevIREQ | IREQ# interrupt signal level r | REQ# interrupt signal level mode select: | | | | | | | | | | | | <ul><li>Logic 0 = Pulse mode</li><li>Logic 1 = Level mode</li></ul> | | | | | | | | | | | | Configuration | <ul> <li>Memory-mapped mode</li> </ul> | 000000B | | | | | | | | | | | Index | <ul> <li>Independent I/O mode</li> </ul> | 000001B | | | | | | | | | | | | <ul> <li>Primary mode</li> </ul> | · | | | | | | | | | | | | <ul> <li>Secondary mode</li> </ul> | 000011B | | | | | | | | | | # CONFIGURATION AND STATUS REGISTER (202H) The Configuration and Status Register (CSR) informs the host of any status changes with regard to power-down. Table 22: Configuration and Status Register (202h) | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Read | Changed | SigChg | lOis8 | 0 | 0 | PwrDn | Int | 0 | | Write | Changed | SigChg | lOis8 | 0 | 0 | PwrDn | Int | 0 | | Default<br>Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit(s) | Description | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Changed | Indicates that either CREADY (D5) or CWPort (D4) of the Pin Replacement register is set. Additionally, this bit changes state as the Powerdown (D2) bit changes. | | SigChg | Outputs the inverse state of the Changed bit to the hardware interface signal STSCHG# at the card interface. | | lois8 | Informs the host of the valid data bus width for the operations in progress: | | | <ul><li>0 = 16-bit data transfer</li><li>1 = 8-bit data transfer</li></ul> | | PwrDwn | Indicates the state of the Card, which is either operating -0 or powerdown mode 1. During powerdown mode, no commands are accepted. Additionally, the host may not initiate a powerdown request when the card is busy via the Status register or the Hardware RDY/BSY pin. | | Int | Indicates the inverse of the IREQ# status signal. | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 52 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # PIN PLACEMENT REGISTER (204H) Table 23: Pin Placement Register (204h) | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Read/<br>Write | CBVD1 | CBVD2 | CRDY | CWProt | RBVD1 | RBVD2 | RRDY | RWProt | | Default<br>Value | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | Bit(s) | Description | |--------|-----------------------------------------------------------------------------------------------------------------| | CRDY | Indicates a bit change in the RRDY (D1) bit. | | CWProt | Indicates a bit change in the RWProt (D0) bit. | | RRDY | When set: | | | <ul><li>High 1 informs the host that the card is ready</li><li>Low 0 state indicates the card is busy</li></ul> | | RWProt | Indicates Write Protect is enabled when set to 1, and disabled when 0. | # SOCKET AND COPY REGISTER (206H) Table 24: Socket and Copy Register (206h) | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | |---------------|----------------|----------------|----------------|----------------|---------------|----------------|----------------|----------------|--| | Read/Write | RFU | Со | py Num | ber | Socket Number | | | | | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bit(s) | Description | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RFU | Reserved for future use. | | Copy<br>Number | Indicates the card number. Allows the host to differentiate between identical cards by writing to the bit of the card that is being accessed. This value is compared to the DRV bit in the ATA Drive/Head register. | | | <ul> <li>Card 0: 000B = (D6, D5, D4) (default)</li> <li>Card 1: 001B = (D6, D5, D4) (alternate)</li> </ul> | | Socket<br>Number | The host writes the socket number that identifies the inserted card. | PAGE 54 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## COMMON MEMORY DESCRIPTION AND OPERATION Common memory space can be accessed when the SiliconDrive II is configured in memory-mapped mode. ## **COMMON MEMORY READ OPERATIONS** Common memory read operations are issued by asserting CE1#, CE2#, or both, and OE# low, REG#, and WE# must be inactive. Table 25: Common Memory Read Operations | <b>Function Mode</b> | REG# | CE1# | CE2# | A0 | OE# | WE# | D[15:8] | D[7:0] | |-------------------------|------|------|------|----|-----|-----|---------|--------| | Standby | Χ | Н | Н | Χ | Χ | Χ | High-Z | High-Z | | Byte Access | Н | L | Н | L | L | Н | High-Z | Even | | | Н | L | Н | Н | L | Н | High-Z | Odd | | Word Access | Н | L | L | Χ | L | Н | Odd | Even | | Odd Byte Only<br>Access | Н | Н | L | X | L | Н | Odd | High-Z | ## **COMMON MEMORY WRITE OPERATIONS** Common memory write operations are issued by asserting CE1#, CE2#, or both, and WE# low, REG#, and OE# must be inactive. Table 26: Common Memory Write Operations | <b>Function Mode</b> | REG# | CE1# | CE2# | A0 | OE# | WE# | D[15:8] | D[7:0] | |-------------------------|------|------|------|----|-----|-----|---------|--------| | Standby | Χ | Н | Н | Χ | Χ | Χ | High-Z | High-Z | | Byte Access | Н | L | Н | L | Н | L | High-Z | Even | | | Н | L | Н | Н | Н | L | High-Z | Odd | | Word Access | Н | L | L | Χ | Н | L | Odd | Even | | Odd Byte Only<br>Access | Н | Н | L | X | Н | L | Odd | High-Z | # I/O SPACE DESCRIPTION AND OPERATION ## I/O SPACE READ OPERATIONS Table 27: I/O Space Read Operations | <b>Function Mode</b> | REG# | CE1# | CE2# | Α0 | IORD# | IOWR# | D[15:8] | D[7:0] | |-------------------------|------|------|------|----|-------|-------|---------|--------| | Standby | Χ | Н | Н | Χ | Χ | Χ | High-Z | High-Z | | Byte Access | L | L | Н | L | L | Н | High-Z | Even | | | L | L | Н | Н | L | Н | High-Z | Odd | | Word Access | L | L | L | L | L | Н | Odd | Even | | I/O Inhibit | Н | Χ | Χ | Χ | L | Н | High-Z | High-Z | | Odd Byte Only<br>Access | L | Н | L | X | L | Н | Odd | High-Z | # I/O SPACE WRITE OPERATIONS Table 28: I/O Space Write Operations | <b>Function Mode</b> | REG# | CE1# | CE2# | A0 | IORD# | IOWR# | D[15:8] | D[7:0] | |-------------------------|------|------|------|----|-------|-------|---------|--------| | Standby | Χ | Н | Н | Χ | Χ | Х | Х | X | | Byte Access | L | L | Н | L | Н | L | Χ | Even | | | L | L | Н | Н | Н | L | Χ | Odd | | Word Access | L | L | L | L | Н | L | Odd | Even | | I/O Inhibit | Н | Χ | Χ | Χ | Н | L | Χ | Χ | | Odd Byte Only<br>Access | L | Н | L | Χ | Н | L | Odd | X | PAGE 56 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # ATA AND TRUE IDE REGISTER DECODING SiliconDrive II can be configured as either a a memory-mapped or an an I/O devices. As noted earlier, communication to and from the drive is accomplished using the ATA Command Block. ## MEMORY-MAPPED REGISTER DECODING In memory-mapped mode, the SiliconDrive II registers are accessed via standard memory references (i.e., OE# and WE#). The ATA registers are mapped to common memory space in a 2KB window starting at address 0. Table 29: Memory-Mapped Register Decoding | Reg# | Offset | A10 | A9:A4 | А3 | <b>A2</b> | <b>A1</b> | Α0 | OE# = L | WE# = L | |------|--------|-----|-------|----|-----------|-----------|----|--------------------------------|---------------------------------| | 1 | 0 | 0 | X | 0 | 0 | 0 | 0 | Even Data<br>Read | Even Data<br>Write | | 1 | 1 | 0 | Χ | 0 | 0 | 0 | 1 | Error | Feature | | 1 | 2 | 0 | Χ | 0 | 0 | 1 | 0 | Sector Count | Sector Count | | 1 | 3 | 0 | X | 0 | 0 | 1 | 1 | Sector<br>Number | Sector<br>Number | | 1 | 4 | 0 | Χ | 0 | 1 | 0 | 0 | Cylinder Low | Cylinder Low | | 1 | 5 | 0 | X | 0 | 1 | 0 | 1 | Cylinder High | Cylinder High | | 1 | 6 | 0 | Χ | 0 | 1 | 1 | 0 | Drive/Head | Drive/Head | | 1 | 7 | 0 | X | 0 | 1 | 1 | 1 | Status | Command | | 1 | 8 | 0 | X | 1 | 0 | 0 | 0 | Duplicate<br>Even Data<br>Read | Duplicate<br>Even Data<br>Write | | 1 | 9 | 0 | X | 1 | 0 | 0 | 1 | Duplicate Odd<br>Data Read | Duplicate Odd<br>Data Write | | 1 | D | 0 | X | 1 | 1 | 0 | 1 | Duplicate<br>Error | Duplicate<br>Feature | | 1 | Е | 0 | X | 1 | 1 | 1 | 0 | Alternate<br>Status | Device Control | | 1 | F | 0 | Χ | 1 | 1 | 1 | 1 | Drive Address | Reserved | | 1 | X | 1 | X | X | Χ | X | 0 | Even Data<br>Read | Even Data<br>Write | | 1 | X | 1 | X | Χ | Χ | Χ | 1 | Odd Data<br>Read | Odd Data<br>Write | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. # INDEPENDENT I/O MODE REGISTER DECODING Independent I/O mode or contiguous I/O mode requires the host to decode a continuous block of 16 I/O registers to select the SiliconDrive II. Table 30: Independent I/O Mode Register Decoding | Reg# | Offset | A10 | A9:A4 | А3 | <b>A2</b> | <b>A1</b> | A0 | OE# = L | WE# = L | |------|--------|-----|-------|----|-----------|-----------|----|--------------------------------|---------------------------------| | 0 | 0 | X | X | 0 | 0 | 0 | 0 | Even Data<br>Read | Even Data<br>Write | | 0 | 1 | Χ | Χ | 0 | 0 | 0 | 1 | Error | Feature | | 0 | 2 | Χ | Χ | 0 | 0 | 1 | 0 | Sector Count | Sector Count | | 0 | 3 | X | X | 0 | 0 | 1 | 1 | Sector<br>Number | Sector<br>Number | | 0 | 4 | Χ | Χ | 0 | 1 | 0 | 0 | Cylinder Low | Cylinder Low | | 0 | 5 | Χ | Χ | 0 | 1 | 0 | 1 | Cylinder High | Cylinder High | | 0 | 6 | Χ | Χ | 0 | 1 | 1 | 0 | Drive/Head | Drive/Head | | 0 | 7 | Χ | Χ | 0 | 1 | 1 | 1 | Status | Command | | 0 | 8 | X | X | 1 | 0 | 0 | 0 | Duplicate<br>Even Data<br>Read | Duplicate<br>Even Data<br>Write | | 0 | 9 | X | X | 1 | 0 | 0 | 1 | Duplicate Odd<br>Data Read | Duplicate Odd<br>Data Write | | 0 | D | X | X | 1 | 1 | 0 | 1 | Duplicate Error | Duplicate<br>Feature | | 0 | Е | X | X | 1 | 1 | 1 | 0 | Alternate<br>Status | Device Control | | 0 | F | Χ | Χ | 1 | 1 | 1 | 1 | Drive Address | Reserved | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 58 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # PRIMARY AND SECONDARY I/O MAPPED REGISTER DECODING Table 31: Primary and Secondary I/O Mapped Register Decoding | Reg# | A10 | A9:A4<br>Primary | A9:A4<br>Secondary | А3 | A2 | <b>A</b> 1 | Α0 | IORD# = L | IOWR# = L | |------|-----|------------------|--------------------|----|----|------------|----|---------------------|--------------------| | 0 | X | 1Fxh | 17xh | 0 | 0 | 0 | 0 | Even Data<br>Read | Even Data<br>Write | | 0 | Χ | 1Fxh | 17xh | 0 | 0 | 0 | 1 | Error | Feature | | 0 | X | 1Fxh | 17xh | 0 | 0 | 1 | 0 | Sector<br>Count | Sector<br>Count | | 0 | X | 1Fxh | 17xh | 0 | 0 | 1 | 1 | Sector<br>Number | Sector<br>Number | | 0 | X | 1Fxh | 17xh | 0 | 1 | 0 | 0 | Cylinder<br>Low | Cylinder<br>Low | | 0 | X | 1Fxh | 17xh | 0 | 1 | 0 | 1 | Cylinder<br>High | Cylinder<br>High | | 0 | Χ | 1Fxh | 17xh | 0 | 1 | 1 | 0 | Drive/Head | Drive/Head | | 0 | Χ | 1Fxh | 17xh | 0 | 1 | 1 | 1 | Status | Command | | 0 | X | 3Fxh | 37xh | 0 | 1 | 1 | 0 | Alternate<br>Status | Device<br>Control | | 0 | X | 3Fxh | 37xh | 0 | 1 | 1 | 1 | Drive<br>Address | Reserved | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 59 # TASK FILE REGISTER SPECIFICATION The Task File registers are used for reading and writing the storage data in the SiliconDrive II. The decoded addresses are as shown in the following table. Table 32: Task File Register Specification | CS0# | CS1# | DA02 | DA01 | DA00 | DIOR# = L | DIOW# = L | |------|------|------|------|------|------------------|----------------| | 0 | 1 | 0 | 0 | 0 | Data | Data | | 0 | 1 | 0 | 0 | 1 | Error | Feature | | 0 | 1 | 0 | 1 | 0 | Sector Count | Sector Count | | 0 | 1 | 0 | 1 | 1 | Sector Number | Sector Number | | 0 | 1 | 1 | 0 | 0 | Cylinder Low | Cylinder Low | | 0 | 1 | 1 | 0 | 1 | Cylinder High | Cylinder High | | 0 | 1 | 1 | 1 | 0 | Drive/Head | Drive/Head | | 0 | 1 | 1 | 1 | 1 | Status | Command | | 0 | 0 | Χ | Χ | Χ | Invalid | Invalid | | 1 | 1 | Χ | Χ | Χ | High-Z | Not Used | | 1 | 0 | 0 | Χ | Χ | High-Z | Not Used | | 1 | 0 | 1 | 0 | Χ | High-Z | Not Used | | 1 | 0 | 1 | 1 | 0 | Alternate Status | Device Control | | 1 | 0 | 1 | 1 | 1 | Device Address | Not Used | PAGE 60 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # **ATA REGISTERS** ## **DATA REGISTER** The Data register is a 16-bit register used to transfer data blocks between the host and drive buffers. The register may set to 8-bit mode by using the Set Features Command defined in "Seek — 7Xh" on page 92. ### **ERROR REGISTER** The Error register contains the error status, if any, generated from the last executed ATA command. The contents are qualified by the ERR bit being set in "Status Register" on page 68. Table 33: Error Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Read | BBK | UNC | MC | IDNF | MCR | ABRT | TKNOF | AMNF | | Default<br>Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit(s) | Description | |--------|------------------------------------------------------------------------------------------------| | 7 | Bad Block Detected (BBK). Set when a bad block is detected. | | 6 | <b>Uncorrectable Data Error (UNC).</b> Set when an uncorrectable error is encountered. | | 5 | Media Changed (MC). Set to 0. | | 4 | ID Not Found (IDNF). Set when the sector ID is not found. | | 3 | MCR (Media Change Request). Set to 0. | | 2 | <b>Aborted Command (ABRT).</b> Set when a command is aborted due to a drive error. | | 1 | <b>Track 0 Not Found (TKONF).</b> Set when the executive drive diagnostic command is executed. | | 0 | Address Mark Not Found (AMNF). Set in the case of a general error. | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 61 # **FEATURE REGISTER** The Feature register is command-specific and used to enable and disable interface features. This register supports only either odd or even byte data transfers. Table 34: Feature Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Read/Write | | | | Featur | e Byte | | | | # **SECTOR COUNT REGISTER** The Sector Count register is used to read or write the sector count of the data for which an ATA transfer has been made. Table 35: Sector Count Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--| | Read/Write | | Sector Count | | | | | | | | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. ### SECTOR NUMBER REGISTER The Sector Number register is set by the host to specify the starting sector number associated with the next ATA command to be executed. Following a qualified ATA command sequence, the device sets the register value to the last sector read or written as a result of the previous AT command. When Logical Block Addressing (LBA) mode is implemented and the host issues a command, the contents of the register describe the Logical Block Number bits A[7:0]. Following an ATA command, the device loads the register with the LBA block number resulting from the last ATA command. Table 36: Sector Number Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | |---------------|----------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--| | Read/Write | Sector Number (CHS Addressing) | | | | | | | | | | | Logical Block Number bits A07-A00 (LBA Addressing) | | | | | | | | | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | PAGE 64 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## CYLINDER LOW REGISTER The Cylinder Low register is set by the host to specify the cylinder number low byte. Following an ATA command, the content of the register is written by the device, identifying the cylinder number low byte. In LBA mode, the 8-bit register maintains the contents of the Logical Block number address bits A15:A08. Table 37: Cylinder Low Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------------------------------------------|-------------------------------------------|----------------|----------------|-------|----------------|----------------|----------------|--|--| | Read/Write | | Cylinder Number Low Byte (CHS Addressing) | | | | | | | | | | | Logical Block Number bits A15-A08 (LBA Addressing) | | | | | | | | | | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. ### CYLINDER HIGH REGISTER The Cylinder High register is set by the host to specify the cylinder number high byte. Following an ATA command, the content of the register is set internally by the device, identifying the cylinder number high byte. In LBA mode, the 8-bit register maintains the contents of the Logical Block number address bits A23:A16. Table 38: Cylinder High Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------------------------------------------|-------------------------------------------|----------------|----------------|-------|----------------|----------------|----------------|--|--| | Read/Write | | Cylinder Number Low Byte (CHS Addressing) | | | | | | | | | | | Logical Block Number bits A23-A16 (LBA Addressing) | | | | | | | | | | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | PAGE 66 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## **DRIVE/HEAD REGISTER** The Drive/Head register is used by the host and the device to select the type of addressing (CHS or LBA), the drive letter, and either bits 3-0 of the head number in CHS mode or logical block number bits 27-24 in LBA mode. Table 39: Drive/Head Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Read/Write | 1 | LBA | 1 | DRV | HS3 | HS2 | HS1 | HS0 | | | | | | | LBA27 | LBA26 | LBA25 | LBA24 | | Default<br>Value | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | The Drive/Head register is used by the host to specify one of a pair of ATA drives present in the platform. | Bit(s) | Description | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | LBA. Selects between CHS (0) and LBA (1) addressing mode. | | 4 | <b>Drive Address (DRV).</b> Indicates the drive number selected by the host, either 0 or 1. | | 3-0 | HS3 to 0. Indicates bits 3-0 of the head number in CHS addressing mode or LBA bits 27-24 in LBA mode. | | | <ul> <li>CHS to LBA conversion: LBA = (C x HpC + H) x SpH + S -1</li> <li>LBA to CHS conversion:</li> </ul> | | | <ul> <li>C = LBA/(HpC x SpH)</li> <li>H = (LBA/SpH) mod (HpC)</li> <li>S = (LBA mod(SpH)) + 1</li> </ul> | | | where: | | | <ul> <li>C is the cylinder number</li> <li>H is the head number</li> <li>S is the sector count</li> <li>HpC is the head count per cylinder count</li> <li>SpH is the sector count per head count (track)</li> </ul> | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 67 # **STATUS REGISTER** The Status register provides the device's current status to the host. The status register is an 8-bit read-only register. When the contents of the register are read by the host, the IREQ# bit is cleared. Table 40: Status Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Read/Write | BSY | DRDY | DWF | DSC | DRQ | CORR | IDX | ERR | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit(s) | Description | |--------|------------------------------------------------------------------------------------------------------------------------------| | 7 | <b>Busy (BSY).</b> Set when the drive is busy and unable to process any new ATA commands. | | 6 | <b>Data Ready (DRDY).</b> Set when the device is ready to accept ATA commands from the host. | | 5 | Drive Write Fault (DWF). Always set to 0. | | 4 | <b>Drive Seek Complete (DSC).</b> Set when the drive heads have been positioned over a specific track. | | 3 | <b>Data Request (DRQ).</b> Set when a device is ready to transfer a word or byte of data to or from the host and the device. | | 2 | Corrected Data (CORR). Always set to 0. | | 1 | Index (IDX). Always set to 0. | | 0 | <b>Error (ERR).</b> Set when an error occurs during the previous ATA command. | #### SILICONSYSTEMS PROPRIETARY PAGE 68 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## **COMMAND REGISTER** The Command register specifies the ATA command code being issued to the drive by the host. Execution of the command begins immediately following the issuance of the command register code by the host. Table 41: Command Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |------------|------------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Read/Write | ATA Command Code | | | | | | | | See "ATA Command Block and Set Description" on page 73 for a listing of the supported ATA commands. ## **ALTERNATE STATUS REGISTER** The Alternate Status register is a read-only register indicating the status of the device, following the previous ATA command. See "Status Register" on page 68 for specific details. Table 42: Alternate Status Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Read/Write | BSY | DRDY | DWF | DSC | DRQ | CORR | IDX | ERR | | Default Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## **DEVICE CONTROL REGISTER** The Device Control register is used to control the interrupt request and issue ATA software resets. Table 43: Device Control Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |-----------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Write | - | - | - | - | 1 | SRST | nIEN | 0 | | Bit(s) | Description | |--------|--------------------------------------------------------------------------------------------------------------------| | 7-4 | Reserved bits. | | 3 | Always set to 1. | | 2 | Software Reset (SRST). When set, resets the ATA software. | | 1 | Interrupt Enable (nIEN). When set, device interrupts are disabled. There is no function in the memory-mapped mode. | | 0 | Always set to 0. | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. ## **DEVICE ADDRESS REGISTER** The Device Address register is used to maintain compatibility with ATA disk drive interfaces. Table 44: Device Address Register | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | $D_0$ | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|-------| | Read/Write | - | nWTG | nHS3 | nHS2 | nHS1 | nHS0 | nDS1 | nDS0 | | Default Value | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | | Bit(s) | Description | |--------|---------------------------------------------------------------------------------| | 7 | Reserved bit. | | 6 | Write Gate (nWTG). Low when a write to the device is in process. | | 5-2 | <b>nHS3 to nHS0.</b> The negated binary address of the currently selected head. | | 1 | nDS1. Low when drive 1 is selected and active. | | 0 | nDS0. Low when drive 0 is selected and active. | # ATA COMMAND BLOCK AND SET DESCRIPTION In accordance with the ANSI ATA Specification, the device implements seven registers that are used to transfer instructions to the device by the host. These commands follow the ANSI standard ATA protocol. A description of the ATA command block is provided in the following table. Table 45: ATA Command Block and Set Description | Operation | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | |---------------|-----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|--|--|--| | Feature | | ı | | > | ( | | | | | | | | Sector Count | | X | | | | | | | | | | | Sector Number | | X | | | | | | | | | | | Cylinder Low | | | | > | ( | | | | | | | | Cylinder High | | | | > | ( | | | | | | | | Drive Head | 1 LBA 1 Drive X | | | | | | | | | | | | Command | X | | | | | | | | | | | ### **ATA COMMAND SET** Table 46: ATA Command Set | Class | Command Name | Command | Registers Used | | | | | | | |-------|--------------------------------|----------|----------------|----|----|----|----|-----|--| | Ciass | Command Name | Code | | SC | SN | CY | DH | LBA | | | 1 | Check Power Mode | 98h, E5h | - | - | - | - | D | - | | | 1 | Execute Drive Diagnostics | 90h | - | - | - | - | D | - | | | 1 | Erase Sector | C0h | - | Υ | Υ | Υ | Υ | Υ | | | 2 | Format Track | 50h | - | Υ | - | Υ | Υ | Υ | | | 1 | Identify Drive | ECh | - | - | - | - | D | - | | | 1 | Idle | 97h, E3h | - | Υ | - | - | D | - | | | 1 | Idle Immediate | 95h, E1h | - | | - | - | D | - | | | 1 | Initialize Drive<br>Parameters | 91h | - | Υ | - | - | Y | - | | | 1 | Read Buffer | E4h | - | - | - | - | D | - | | | 1 | Read DMA* | C8h | - | Υ | Υ | Υ | Υ | Υ | | | 1 | Read Multiple | C4h | - | Υ | Y | Y | Υ | Υ | | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Registers Used Command Class Command Name Code FR SC SN CY LBA DH Y Υ Y 1 Read Long Sector 22h, 23h Υ 1 Υ Υ Read Sector(s) 20h, 21h Υ Υ 1 Υ Υ Υ Read Verify Sector(s) 40h, 41h Υ Υ 1 Recalibrate 1Xh Υ 1 Request Sense 03h D 1 Seek 7Xh Υ Y Υ Υ 1 Set Features EFh Υ D 1 Set Multiple Mode C6h Υ D 1 Set Sleep Mode 99h, E6h D 1 Standby 96h, E2h D 1 Standby Immediate 94h, E0h D 1 **Translate Sector** 87h Υ Y Υ 1 Wear Level F5h Υ 2 Write Buffer E8h D 1 Write DMA\* CAh Υ Y Υ Υ 2 Υ 32h. 33h Υ Υ Υ Write Long Sector 3 C5h Υ Υ Υ Υ Write Multiple 3 CDh Υ Υ Υ Υ Write Multiple w/o **Erase** 2 Write Sector(s) 30h, 31h Υ Υ Υ Υ 2 Y Y Υ Write Sector(s) w/o 38h Erase 3 3Ch Υ Υ Write Verify Υ Υ Υ Table 46: ATA Command Set (Continued) #### Notes: - CY = Cylinder - SC = Sector Count - DH = Drive/Head - SN = Sector Number - FR = Feature LBA LBA bit of the Drive/Head register (D denotes that only the drive bit is used) #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. <sup>\* =</sup> This function does not apply to SiliconDrive IIs that have DMA disabled. ## Check Power Mode — 98h, E5h The Check Power Mode command verifies the device's current power mode. When the device is configured for standby mode or is entering or exiting standby, the BSY bit is set, the Sector Count register set to 00h, and the BSY bit is cleared. In idle mode, BSY is set and the Sector Count register is set to FFh. The BSY bit is then cleared and an interrupt is issued. Table 47: Check Power Mode — 98h, E5h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|--|--|--| | Feature | | | | × | ( | | | | | | | | Sector Count | | X | | | | | | | | | | | Sector Number | | X | | | | | | | | | | | Cylinder Low | | | | X | ( | | | | | | | | Cylinder High | | | | X | ( | | | | | | | | Drive Head | X X Drive | | | | | | | | | | | | Command | 98h or E5h | | | | | | | | | | | # Executive Drive Diagnostic — 90h The Executive Drive Diagnostic performs an internal read write diagnostic test using (AA55h and 55AAh). If an error is detected in the read/write buffer, the Error register reports the appropriate diagnostic code. Table 48: Executive Drive Diagnostic — 90h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|--|--| | Feature | | | ı | > | ( | | | | | | | Sector Count | | X | | | | | | | | | | Sector Number | X | | | | | | | | | | | Cylinder Low | | | | > | ( | | | | | | | Cylinder High | | | | > | ( | | | · | | | | Drive Head | Х | Χ | Χ | Drive | | | | | | | | Command | 90h | | | | | | | | | | PAGE 76 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## Format Track — 50h The Format Track command formats the common solid-state memory array. Table 49: Format Track — 50h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | |---------------|------------------------|----------------|----------------|----------------|------------------------|----------------|----------------|----------------|--|--|--| | Feature | | | | > | ( | | 1 | | | | | | Sector Count | | Sector Count | | | | | | | | | | | Sector Number | Sector Number (LBA7-0) | | | | | | | | | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | | | | Cylinder High | | | Cylin | der High | ı (LBA2 | 3-16) | | | | | | | Drive Head | 1 | LBA | 1 | Drive | Head Number (LBA27-24) | | | | | | | | Command | 50h | | | | | | | | | | | # Identify Drive — ECh Issued by the host, the Identify Drive command provides 256 bytes of drive attribute data (i.e., sector size, count, and so on) The identify drive data structure is detailed in the following table. Table 50: Identify Drive — ECh | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|--|--| | Feature | | X | | | | | | | | | | | Sector Count | | X | | | | | | | | | | | Sector Number | | X | | | | | | | | | | | Cylinder Low | | | | X | ( | | | · | | | | | Cylinder High | | | | X | ( | | | · | | | | | Drive Head | X X X Drive X | | | | | | | | | | | | Command | ECh | | | | | | | | | | | PAGE 78 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Identify Drive — Drive Attribute Data Table 51: Identify Drive — Drive Attribute Data | Word<br>Address | Data Default | Bytes | Data Description | | | | |-----------------|-----------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0 | 044Ah (fixed | 2 | General configuration bit information | | | | | | ID bit) in IDE mode 848A (removable ID bit) in PCMCIA memory and I/ O modes | | <ul> <li>15: Non-magnetic disk</li> <li>14: Formatting speed latency permissible gap needed</li> <li>13: Track Offset option supported</li> <li>12: Data Strobe Offset option supported</li> <li>11: Over 0.5% rotational speed difference</li> <li>10: Disk transfer rate &gt; 10Mbps</li> <li>9: 10Mbps &gt;= disk transfer rate &gt; 5Mbps</li> <li>8: 5Mbps &gt;= disk transfer rate</li> <li>7: Removable cartridge drive</li> <li>6: Fixed drive</li> <li>5: Spindle Motor Control option executed</li> <li>4: Over 15µs changing head time</li> <li>3: Non-MFM encoding</li> <li>2: Soft sector allocation</li> <li>1: Hard sector allocation</li> <li>0: Reserved</li> </ul> | | | | | 1 | XXXXh | 2 | Number of cylinders | | | | | 2 | 0000h | 2 | Reserved | | | | | 3 | 00XXh | 2 | Number of heads | | | | | 4 | 0000h | 2 | Number of unformatted bytes per track | | | | | 5 | XXXXh | 2 | Number of unformatted bytes per sector | | | | | 6 | XXXXh | 2 | Number of sectors per track | | | | | 7-8 | XXXXh | 4 | Number of sectors per device | | | | | 9 | 0000h | 2 | Reserved | | | | | 10-19 | XXXXh | 20 | Serial number | | | | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 79 Table 51: Identify Drive — Drive Attribute Data (Continued) | Word<br>Address | Data Default | Bytes | Data Description | |-----------------|--------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20 | 0002h | 2 | Buffer type | | | | | <ul> <li>0000h: Not specified</li> <li>0001h: A single-ported, single-sector buffer</li> <li>0002h: A dual-ported multisector buffer</li> <li>0003h: A dual-ported multisector buffer with a read caching</li> </ul> | | 21 | 0002h | 2 | Buffer size in 512-byte increments | | 22 | 0004h | 2 | Number of ECC bytes passed on read/<br>write long commands | | 23-26 | XXXXh | 8 | Firmware revision (eight ASCII characters) | | 27-46 | XXXXh | 40 | Model number (40 ASCII characters) | | 47 | 8001h | 2 | 15-8: Maximum number of sectors that can be transferred with a Read/Write Multiple command per interrupt | | 48 | 0000h | 2 | Double word (32 bit) not supported | | 49 | 0002h | 2 | <ul><li>11: IORDY supported</li><li>9: LBA supported</li><li>8: DMA supported</li></ul> | | 50 | 0000h | 2 | Reserved | | 51 | 0100h | 2 | 15-8: PIO data transfer cycle timing | | 52 | 0000h | 2 | 15-8: DMA data transfer cycle timing | | 53 | 0007h | 2 | <ul><li>2: Word 88 is valid</li><li>1: Words 64-70 are valid</li><li>0: Words 54-58 are valid</li></ul> | | 54 | XXXXh | 2 | Current number of cylinders | | 55 | XXXXh | 2 | Current number of heads | | 56 | XXXXh | 2 | Current sectors per track | | 57-58 | XXXXh | 4 | Current capacity in sectors | | 59 | 010Xh | 2 | 7-0: Current sectors can be transferred with a Read/Write Multiple command per interrupt | | 60-61 | XXXXh | 4 | Total number of sectors addressable in LBA mode | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 80 JUNE 13, 2008 DOCUMENT: 4000C-12DSR Table 51: Identify Drive — Drive Attribute Data (Continued) | Word<br>Address | Data Default | Bytes | Data Description | |-----------------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 62 | 0000h | 2 | Single-word DMA modes supported | | 63 | 0007h | 2 | <ul> <li>2: Multiword DMA mode 2 supported</li> <li>1: Multiword DMA mode 1 supported</li> <li>0: Multiword DMA mode 0 supported</li> </ul> | | 64 | 0003h | 2 | 7-0: Advanced PIO modes supported | | 65 | 0078h | 2 | 15-0: Multiword DMA cycle time in nanoseconds | | 66 | 0078h | 2 | 15-0: Multiword DMA transfer cycle time in nanoseconds | | 67 | 0078h | 2 | 15-0: PIO mode cycle time without flow control | | 68 | 0078h | 2 | 15-0: PIO mode cycle time with IORDY flow control | | 80 | 003Eh | 2 | <ul> <li>5: ATA/ATAPI-5 supported</li> <li>4: ATA/ATAPI-4 supported</li> <li>3: ATA-3 supported</li> <li>2: ATA-2 supported</li> <li>1: ATA-2 supported</li> <li>0: Reserved</li> </ul> | | 88 | 001Fh | 2 | <ul> <li>4: UDMA mode 4 supported</li> <li>3: UDMA mode 3 supported</li> <li>2: UDMA mode 2 supported</li> <li>1: UDMA mode 1 supported</li> <li>0: UDMA mode 0 supported</li> </ul> | | 163 | 0002h | 2 | 2: Multiword DMA mode 4 and PIO mode 6 supported | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. DOCUMENT: 4000C-12DSR June 13, 2008 Page 81 # Idle - 97h, E3h When issued by the host, the device's internal controller sets the BSY bit, enters the Idle mode, clears the BSY bit, and generates an interrupt. If the sector count is non-zero, it is interpreted as a timer count with each count being 5ms, and the automatic power-down mode is enabled. If the sector count is zero, the automatic power-down mode is disabled. Table 52: Idle — 97h, E3h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|--|--| | Feature | | X | | | | | | | | | | | Sector Count | | | Timer C | ount (5 | ns incre | ements) | | | | | | | Sector Number | | X | | | | | | | | | | | Cylinder Low | | | | × | ( | | | · | | | | | Cylinder High | | | | × | ( | | | · | | | | | Drive Head | Χ | X X Drive X | | | | | | | | | | | Command | | 97h or E3h | | | | | | | | | | # Idle Immediate — 95h, E1h When issued by the host, the device's internal controller sets the BSY bit, enters Idle Mode, clears the BSY bit, and issues an interrupt. The interrupt is issued whether or not the Idle mode is fully entered. Table 53: Idle Immediate — 95h, E1h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--| | Feature | | | | X | • | | ı | | | | Sector Count | | X | | | | | | | | | Sector Number | | X | | | | | | | | | Cylinder Low | | | | Х | | | | · | | | Cylinder High | | | | Х | | | | · | | | Drive Head | X X Drive X | | | | | | | | | | Command | 95h or E1h | | | | | | | | | ### Initialize Drive Parameters — 91h Initialize Drive Parameters allows the host to set the sector counts per track and the head counts per cylinder to 1 Fixed. Upon issuance of the command, the device sets the BSY bit and associated parameters, clears the BSY bit, and issues an interrupt. Table 54: Initialize Drive Parameters — 91h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | |---------------|----------------|----------------------------------|----------------|----------------|-----------------------|----------------|----------------|----------------|--|--|--| | Feature | X | | | | | | | | | | | | Sector Count | | Sector Count (Number of Sectors) | | | | | | | | | | | Sector Number | | | | Χ | ( | | | | | | | | Cylinder Low | | | | × | ( | | | | | | | | Cylinder High | | | | > | ( | | | | | | | | Drive Head | Х | 0 | Х | Drive | | Head N | | | | | | | | | | | | (Number of Heads — 1) | | | | | | | | Command | 91h | | | | | | | | | | | PAGE 84 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ### Recalibrate — 1Xh The Recalibrate command sets the cylinder low and high, head number to 0h, and sector number to 1h in CHS mode. In LBA mode (i.e., LBA = 1), the sector number is set to 0h. Table 55: Recalibrate — 1Xh | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | |---------------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--| | Feature | | | | × | ( | | | | | | Sector Count | | X | | | | | | | | | Sector Number | | X | | | | | | | | | Cylinder Low | | | | X | | | | | | | Cylinder High | | | | X | | | | | | | Drive Head | 1 LBA 1 Drive X | | | | | | | | | | Command | 1Xh | | | | | | | | | ### Read Buffer — E4h The Read Buffer command allows the host to read the contents of the sector buffer. When issued, the device sets the BSY bit and sets up the sector buffer data in preparation for the read operation. When the data is ready, the DRQ bit is set and the BSY bit in the Status register are set and cleared, respectively. Table 56: Read Buffer — E4h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|--| | Feature | | X | | | | | | | | | | Sector Count | | X | | | | | | | | | | Sector Number | | X | | | | | | | | | | Cylinder Low | | | | X | ( | | | | | | | Cylinder High | | | | X | ( | | | | | | | Drive Head | Χ | X X X Drive X | | | | | | | | | | Command | | E4h | | | | | | | | | PAGE 86 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ## Read DMA — C8h The Read DMA command allows the host to read data using the DMA transfer protocol. **Note:** This function does not apply to SiliconDrive IIs that have DMA disabled. Table 57: Read DMA — C8h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | | |---------------|----------------|--------------------------------------|----------------|----------------|---------|----------------|----------------|----------------|--|--|--|--| | Feature | | X | | | | | | | | | | | | Sector Count | | | | Sector | Count | | | | | | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | | | | | Cylinder High | | | Cylin | der High | (LBA2 | 3-16) | | | | | | | | Drive Head | 1 | 1 LBA 1 Drive Head Number (LBA27-24) | | | | | | | | | | | | Command | | C8h | | | | | | | | | | | # Read Multiple — C4h The Read Multiple command executes similarly to the Read Sector command, with the exception that interrupts are issued only when a block containing the counts of sectors defined by the Set Multiple command is transferred. Table 58: Read Multiple — C4h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | | |---------------|--------------------------------------|------------------------|----------------|----------------|---------|----------------|----------------|----------------|--|--|--|--| | Feature | | X | | | | | | | | | | | | Sector Count | | | | Sector | Count | | | | | | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | | | | | Cylinder High | | | Cylind | der High | ı (LBA2 | 3-16) | | | | | | | | Drive Head | 1 LBA 1 Drive Head Number (LBA27-24) | | | | | | | | | | | | | Command | C4h | | | | | | | | | | | | PAGE 88 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # Read Sector — 20h, 21h The Read Sector command allows the host to read sectors 1 to 256 as specified in the Sector Count register. If the sector count is set to 0h, all 256 sectors of data are made available. When the command code is issued and the first sector of data has been transferred to the buffer, the DRQ bit is set. The Read Sector command is terminated by writing the cylinder, head, and sector number of the last sector read in the task file. On error, the read operation is aborted in the errant sector. Table 59: Read Sector — 20h, 21h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | | | |---------------|----------------|--------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|--|--|--|--| | Feature | | X | | | | | | | | | | | | Sector Count | | Sector Count | | | | | | | | | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | | | | | Cylinder High | | | Cylin | der High | ı (LBA2 | 3-16) | | | | | | | | Drive Head | 1 | 1 LBA 1 Drive Head Number (LBA27-24) | | | | | | | | | | | | Command | 20h or 21h | | | | | | | | | | | | # Read Long Sector(s) — 22h, 23h The Read Long Sector(s) command operates similarly to the Read Sector(s) command, with the exception that it transfers requested data sectors and ECC data. The long instruction ECC byte transfer for Long commands is a byte transfer at a fixed length of 4 bytes. Table 60: Read Long Sector(s) — 22h, 23h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|--------------------------------------|----------------|----------------|-------|----------------|----------------|----------------|--|--| | Feature | | | | > | ( | | ı | | | | | Sector Count | | | | > | ( | | | · | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | | | Cylinder Low | | Cylinder Low (LBA15-8) | | | | | | | | | | Cylinder High | | Cylinder High (LBA23-16) | | | | | | | | | | Drive Head | 1 | 1 LBA 1 Drive Head Number (LBA27-24) | | | | | | | | | | Command | 22h or 23h | | | | | | | | | | PAGE 90 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # Read Verify Sector(s) — 40h, 41h The Read Verify Sector(s) command operates similarly to the Read Sector(s) command, with the exception that is does not set the DRQ bit and does not transfer data to the host. When the requested sectors are verified, the onboard controller clears the BSY bit and issues an interrupt. Table 61: Read Verify Sector(s) — 40h, 41h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|--------------------------|----------------|----------------|--------------------------|----------------|----------------|----------------|--|--| | Feature | | X | | | | | | | | | | Sector Count | | | | Sector | Count | | | | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | | | Cylinder Low | | Cylinder Low (LBA15-8) | | | | | | | | | | Cylinder High | | Cylinder High (LBA23-16) | | | | | | | | | | Drive Head | 1 | LBA | 1 | Drive | e Head Number (LBA27-24) | | | | | | | Command | | 40h or 41h | | | | | | | | | DOCUMENT: 4000C-12DSR June 13, 2008 Page 91 ### Seek — 7Xh The Seek command seeks and picks up the head to the tracks specified in the task file. When the command is issued, the solid-state memory chips do not need to be formatted. After an appropriate amount of time, the DSC bit is set. Table 62: Seek — 7Xh | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|--------------------------|----------------|------------------------------|-------|----------------|----------------|----------------|--|--| | Feature | | X | | | | | | | | | | Sector Count | | X | | | | | | | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | | | Cylinder Low | | Cylinder Low (LBA15-8) | | | | | | | | | | Cylinder High | | Cylinder High (LBA23-16) | | | | | | | | | | Drive Head | 1 | LBA | 1 | Drive Head Number (LBA27-24) | | | | | | | | Command | 7Xh | | | | | | | | | | PAGE 92 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ### Set Features — EFh The Set Features command allows the host to configure the feature set of the device according to the attributes listed in Table 64. Table 63: Set Features — EFh | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|--|--| | Feature | | Feature | | | | | | | | | | Sector Count | | | | × | ( | | | · | | | | Sector Number | | X | | | | | | | | | | Cylinder Low | | X | | | | | | | | | | Cylinder High | | X | | | | | | | | | | Drive Head | Χ | X X Drive X | | | | | | | | | | Command | | EFh | | | | | | | | | Table 64: Set Features' Attributes | Feature | Operation | |---------|---------------------------------------------------| | 01h | Enable 8-bit data transfer | | 66h | Disable reverting to power on defaults | | 81h | Disable 8-bit data transfer | | BBh | 4 bytes of data apply on Read/Write Long commands | | CCh | Enable revert to power on defaults | On power-up or following a hardware reset, the device is set to the default mode 81h. ## Set Multiple Mode — C6h The Set Multiple Mode command allows the host to access the drive via Read Multiple and Write Multiple ATA commands. Additionally, the command sets the block count (i.e., the number of sectors within the block) for the Read/Write Multiple command. The sector count per block is set in the Sector Count register. Table 65: Set Multiple Mode — C6h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|--|--| | Feature | | X | | | | | | | | | | Sector Count | | | | Sector | Count | | | <del></del> | | | | Sector Number | | X | | | | | | | | | | Cylinder Low | | X | | | | | | | | | | Cylinder High | | X | | | | | | | | | | Drive Head | X X X Drive X | | | | | | | | | | | Command | | C6h | | | | | | | | | PAGE 94 JUNE 13, 2008 DOCUMENT: 4000C-12DSR ### Set Sleep Mode — 99h, E6h The Set Sleep Mode command allows the host to set the device in sleep mode. When the onboard controller transitions to sleep mode, it clears the BSY bit and issues an interrupt. The device interface then becomes inactive. Sleep mode can be exited by issuing either a hardware or software reset. Table 66: Set Sleep Mode — 99h, E6h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Feature | | | | × | ( | | | | | Sector Count | | | | Х | | | | | | Sector Number | | | | X | | | | | | Cylinder Low | | | | Х | | | | | | Cylinder High | | | | X | | | | | | Drive Head | Χ | Χ | Χ | Drive | | > | ( | | | Command | | | | 99h o | r E6h | | | | ### Standby — 96h, E2h When the Standby command is issued by the host, it transitions the device into standby mode. If the Sector Count register is set to a value other than 0h, the Auto Powerdown function is enabled and the device returns to Idle mode. Table 67: Standby — 96h, E2h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Feature | | | | > | ( | | | | | Sector Count | | Ti | mer Co | unt (5m | s x Time | er Cour | nt) | | | Sector Number | | | | > | ( | | | | | Cylinder Low | | | | X | ( | | | | | Cylinder High | | | | > | ( | | | | | Drive Head | Х | Χ | Χ | Drive | | > | ( | | | Command | | 1 | 1 | 96h o | r E2h | | | | PAGE 96 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # Standby Immediate — 94h, E0h When the Standby Immediate command is issued by the host, it transitions the device into standby mode. Table 68: Standby Immediate — 94h, E0h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>7</sub> | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Feature | | | | × | ( | | | | | Sector Count | | | | X | ( | | | | | Sector Number | | | | X | ( | | | · | | Cylinder Low | | | | X | ( | | | · | | Cylinder High | | | | X | ( | | | · | | Drive Head | X | Χ | Χ | Drive | | > | ( | · | | Command | | | 1 | 94h o | r E0h | | | | #### Write Buffer — E8h The Write Buffer command allows the host to rewrite the contents of the 512- byte data buffer with the wanted data. Table 69: Write Buffer — E8h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>7</sub> | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Feature | | | | > | ( | | | | | Sector Count | | | | > | ( | | | | | Sector Number | | | | > | ( | | | | | Cylinder Low | | | | × | ( | | | | | Cylinder High | | | | × | ( | | | | | Drive Head | Х | Χ | Χ | Drive | | > | ( | | | Command | | | 1 | E8 | 3h | | | | PAGE 98 JUNE 13, 2008 DOCUMENT: 4000C-12DSR # Write DMA — CAh The Write DMA command allows the host to write data using the DMA transfer protocol. **Note:** This function does not apply to SiliconDrive IIs that have DMA disabled. Table 70: Write DMA — CAh | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------------------------|----------------|----------------|----------------|----------------|-------------------|----------------|----------------| | Feature | | | ı | > | ( | ı | | | | Sector Count | | | | Sector | Count | | | | | Sector Number | | | Sect | or Numb | er (LBA | <del>1</del> 7-0) | | | | Cylinder Low | | | Cylii | nder Lov | w(LBA1 | 5-8) | | | | Cylinder High | | | Cylin | der Higl | n(LBA2 | 3-16) | | | | Drive Head | X LBA X Drive Head Number(LBA27- | | | | | | | 7-24) | | Command | CAh | | | | | | | | ### Write Multiple — C5h The Write Multiple command operates in the same manner as the Write Sector command. When issued, the device sets the BSY bit within 400ns and generates an interrupt at the completion of a transferred block of sectors. The DRQ bit is set at the beginning of a block transfer. Table 71: Write Multiple — C5h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|---------|-------------------|----------------|----------------| | Feature | | I. | | > | ( | | | | | Sector Count | | | | Sector | Count | | | | | Sector Number | | | Secto | or Numb | er (LBA | <del>\</del> 7-0) | | | | Cylinder Low | | | Cylin | nder Lov | v(LBA1 | 5-8) | | | | Cylinder High | | | Cylin | der Higl | n(LBA2 | 3-16) | | | | Drive Head | Χ | LBA | Χ | Drive | Head | Numbe | er(LBA2 | 27-24) | | Command | C5h | | | | | | | | ### Write Sector(s) — 30h, 31h The Write Sector(s) command writes from 1 to 256 sectors as specified in the Sector Count register. A sector count of 0 requests 256 sectors. When issued, the device sets the BSY bit within 400ns and generates an interrupt at the completion of a transferred block of sectors. The DRQ bit is set at the beginning of a block transfer. Table 72: Write Sector(s) — 30h, 31h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|---------|-------------------|----------------|----------------| | Feature | | | | <b>&gt;</b> | ( | | | | | Sector Count | | | | Sector | Count | | | | | Sector Number | | | Sect | or Numb | er (LBA | <del>1</del> 7-0) | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | Cylinder High | | | Cylin | der High | (LBA2 | 3-16) | | | | Drive Head | Χ | LBA | Χ | Drive | Head | Numbe | r (LBA2 | 27-24) | | Command | | 1 | ı | 30h o | r 31h | | | | ### Write Long Sector(s) — 32h, 33h The Write Long Sector(s) command operates in the same manner as the Write Sector command — when issued, the device sets the BSY bit within 400ns and generates an interrupt at the completion of a transferred block of sectors. The DRQ bit is set at the beginning of a block transfer. Table 73: Write Long Sector(s) — 32h, 33h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | |---------------|----------------|----------------|----------------|----------------|---------|-------------------|----------------|----------------|--| | Feature | | | | > | ( | | ı | | | | Sector Count | | | | Sector | Count | | | · | | | Sector Number | | | Sect | or Numb | er (LBA | <del>1</del> 7-0) | | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | | Cylinder High | | | Cylin | der High | ı (LBA2 | 3-16) | | | | | Drive Head | Χ | LBA | Χ | Drive | Head | Numbe | r (LBA2 | 27-24) | | | Command | | 32h or 33h | | | | | | | | # Erase Sector(s) — C0h The Erase Sector(s) command is issued prior to the issuance of a Write Sector(s) or Write Multiple w/o Erase command. Table 74: Erase Sector(s) — C0h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | | |---------------|----------------|----------------|----------------|----------------|-------------------------|-------------------|----------------|----------------|--|--| | Feature | | | | > | ( | | | | | | | Sector Count | | | | Sector | Count | | | | | | | Sector Number | | | Sect | or Numb | er (LBA | <del>1</del> 7-0) | | | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | | | | | Cylinder High | | | Cylin | der High | ı (LBA2 | 3-16) | | | | | | Drive Head | Χ | LBA | Χ | Drive | ive Head Number (LBA27- | | | | | | | Command | C0h | | | | | | | | | | ### Request Sense — 03h The Request Sense command identifies the extended error codes generated by the preceding ATA command. The Request Sense command must be issued immediately following the detection of an error via the Error register. Table 75: Request Sense — 03h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------| | Feature | | | | × | ( | ı | | | | Sector Count | | | | X | ( | | | | | Sector Number | | | | X | | | | | | Cylinder Low | | | | X | ( | | | | | Cylinder High | | | | X | ( | | | | | Drive Head | 1 | 1 X 1 Drive X | | | | | | | | Command | | | | 03 | Sh | | | | The extended error codes are defined in the following table. Table 76: Extended Error Codes | <b>Extended Error Codes</b> | Description | |-----------------------------|----------------------------------------------------| | 00h | No error detected | | 01h | Self test is OK (no error) | | 09h | Miscellaneous error | | 20h | Invalid command | | 21h | Invalid address (requested head or sector invalid) | | 2Fh | Address overflow (address too large) | | 35h, 36h | Supply or generated voltage out of tolerance | | 11h | Uncorrectable ECC error | | 18h | Corrected ECC error | | 05h, 30h-32h, 37h,3Eh | Self test of diagnostic failed | | 10h, 14h | ID not found | | 3Ah | Spare sectors exhausted | | 1Fh | Data transfer error/aborted command | | 0Ch, 38h, 3Bh, 3Ch, 3Fh | Computed media format | | 03h | Write/erase failed | | | | #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. #### Translate Sector — 87h The Translate Sector command is not currently supported by the SiliconSystems' SiliconDrive II. If the host issues this command, the device responds with 0x00h in the data register. Table 77: Translate Sector — 87h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|---------------------------------|----------------|----------------|----------------|---------|-------------------|----------------|----------------| | Feature | | | ı | > | ( | | ı | | | Sector Count | | | | Sector | Count | | | | | Sector Number | | | Sect | or Numb | er (LBA | <del>(</del> 7-0) | | | | Cylinder Low | | | Cylir | nder Lov | v (LBA1 | 5-8) | | · | | Cylinder High | | | Cylin | der High | ı (LBA2 | 3-16) | | · | | Drive Head | 1 LBA 1 Drive Head Number (LBA) | | | | | | | 27-24) | | Command | 87h | | | | | | | | #### Wear-Level — F5h The Wear-Level command is supported as an NOP command for the purposes of backward compatibility with the ANSI AT attachment standard. This command sets the Sector Count register to 0x00h. Table 78: Wear-Level — F5h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|----------------|----------------|----------------|----------------|----------|----------------|----------------|----------------| | Feature | | X | | | | | | | | Sector Count | | | С | ompletion | on Statu | IS | | | | Sector Number | | X | | | | | | | | Cylinder Low | | X | | | | | | | | Cylinder High | | X | | | | | | | | Drive Head | X | Χ | Χ | Drive | | Fla | ag | | | Command | | | I | F5 | ih | | | | ### Write Multiple w/o Erase — CDh The Write Multiple w/o Erase command functions identically to the Write Multiple command, with the exception that the implied pre-erase (i.e., Erase Sector(s) command) is not issued prior to writing the sectors. Table 79: Write Multiple w/o Erase — CDh | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|--------------------------------------|------------------------|----------------|----------------|-------|----------------|----------------|----------------| | Feature | | X | | | | | | | | Sector Count | | | | Sector | Count | | | | | Sector Number | Sector Number (LBA7-0) | | | | | | | | | Cylinder Low | | Cylinder Low (LBA15-8) | | | | | | | | Cylinder High | Cylinder High (LBA23-16) | | | | | | | | | Drive Head | X LBA X Drive Head Number (LBA27-24) | | | | | 27-24) | | | | Command | CDh | | | | | | | | # Write Sector(s) w/o Erase — 38h The Write Sector(s) w/o Erase command functions similar to the Write Sector command, with the exception that the implied pre-erase (i.e., Erase Sector(s) command) is not issued prior to writing the sectors. Table 80: Write Sector(s) w/o Erase — 38h | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|--------------------------------------|------------------------|----------------|----------------|----------------|----------------|----------------|----------------| | Feature | X | | | | | | | | | Sector Count | | Sector Count | | | | | | | | Sector Number | Sector Number (LBA7-0) | | | | | | | | | Cylinder Low | | Cylinder Low (LBA15-8) | | | | | | | | Cylinder High | Cylinder High (LBA23-16) | | | | | | | | | Drive Head | X LBA X Drive Head Number (LBA27-24) | | | | | 27-24) | | | | Command | 38h | | | | | | | | DOCUMENT: 4000C-12DSR # Write Verify — 3Ch The Write Verify command verifies each sector immediately after it is written. This command performs identically to the Write Sector(s) command, with the added feature of verifying each sector written. Table 81: Write Verify — 3Ch | Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | $D_3$ | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | |---------------|-------------------------------------|------------------------|----------------|----------------|-------|----------------|----------------|----------------| | Feature | X | | | | | | | | | Sector Count | | | | Sector | Count | | | | | Sector Number | | Sector Number (LBA7-0) | | | | | | | | Cylinder Low | | Cylinder Low (LBA15-8) | | | | | | | | Cylinder High | Cylinder High (LBA23-16) | | | | | | | | | Drive Head | X LBA X Drive Head Number (LBA27-24 | | | | | 27-24) | | | | Command | | 1 | 1 | 30 | Ch | | | | ### SALES AND SUPPORT To order or obtain information on pricing and delivery, contact your SiliconSystems Sales Representative. ### PART NUMBERING #### NOMENCLATURE The following table defines the SiliconDrive II CF part numbering scheme. Table 82: Part Numbering Nomenclature #### **PART NUMBERS** The following table lists the SiliconDrive II's part numbers. Table 83: Part Numbers | Part Number | Capacity | |------------------|----------| | SSD-C16G(I)-4000 | 16GB | | SSD-C08G(I)-4000 | 8GB | | SSD-C04G(I)-4000 | 4GB | | SSD-C02G(I)-4000 | 2GB | | SSD-C01G(I)-4000 | 1GB | #### RoHS 6 of 6 Product Labeling — PB-Free Identification Label The Pb-free identification label indicates that the enclosed components/ devices and/or assemblies do not contain any lead (i.e., they are lead-free, as defined in RoHS directive 2002/95/ED). The above symbol is on all RoHS 6 of 6 compliant product labels, as seen in Figure 18. ### SAMPLE LABEL Figure 18: Sample Label #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. # **RELATED DOCUMENTATION** For more information, visit www.siliconsystems.com or contact your SiliconSystems Sales Representative. Table 84: Related Documentation | SiliconDrive II<br>Application-Specific<br>Technology | Document Number | | |-------------------------------------------------------|-----------------------------------------------------------------------------|--------------------| | SiProtect | Protection software for password-required, read/write, or read-only access. | SSANxx-SilDrvSec-R | | SiSweep | Ultra-fast data erasure | SSANxx-SilDrvSec-R | | SiPurge | Non-recoverable data erasure | SSANxx-SilDrvSec-R | | RELATED DOCUMENTATION | SSD-CXXX(I)-4000 DATA SHEET | |-----------------------|-----------------------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. Click here Click here SiliconSystems' performance tests, ratings, and product specifications are measured using specific computer systems and/or components and reflect the approximate performance of SiliconSystems' products as measured by those tests. Any difference in system hardware or software design or configuration, as well as system use, may affect actual test results, ratings, and product specifications. SiliconSystems welcomes user comments and reserves the right to revise this document and/or make updates to product specifications, products, or programs described without notice at any time. SiliconSystems makes no representations or warranties regarding this document. The names of actual companies and products mentioned herein are the trademarks of their respective owners. SiliconSystems™, SiliconDrive™, SiSecure™, PowerArmor™, SiSMART™, SiKey™, SiZone™, SiProtect™, SiSweep™, SiPurge™, SiScrub™, SiliconDrive Blade™, SiliconDrive Edge™, and the SiliconSystems logo are trademarks or registered trademarks of SiliconSystems, Inc. and may be used publicly only with the permission of SiliconSystems and require proper acknowledgement. Other listed names and brands are trademarks or registered trademarks of their respective owners. © Copyright 2008 by SiliconSystems, Inc. All rights reserved. No part of this publication may be reproduced without the prior written consent of SiliconSystems. #### SILICONSYSTEMS PROPRIETARY This document and the information contained within it is confidential and proprietary to SiliconSystems, Inc. All unauthorized use and/or reproduction is prohibited. PAGE 114 JUNE 13, 2008 DOCUMENT: 4000C-12DSR