

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China









# EZ-USB AT2LP™ USB 2.0 to ATA/ATAPI Bridge

# 1.0 Features (CY7C68300B/CY7C68301B and CY7C68320/CY7C68321)

- Fixed-function mass storage device—requires no firmware code
- Two power modes: Self-powered and USB bus-powered to enable bus powered CF readers and truly portable USB hard drives
- Certified compliant for USB 2.0 (TID# 40460273), the USB Mass Storage Class, and the USB Mass Storage Class Bulk-Only Transport (BOT) Specification
- Operates at high (480-Mbps) or full (12-Mbps) speed USB
- Complies with ATA/ATAPI-6 specification
- Supports 48-bit addressing for large hard drives
- · Supports ATA security features
- · Supports all ATA commands via ATACB function
- · Supports mode page 5 for BIOS boot support
- Supports ATAPI serial number VPD page retrieval for Digital Rights Management (DRM) compatibility
- Supports PIO modes 0, 3, 4, multiword DMA mode 2, and UDMA modes 2, 3, 4
- Uses one external serial EEPROM for storage of USB descriptors and device configuration data
- · ATA interface IRQ signal support
- Support for one or two ATA/ATAPI devices

- Support for CompactFlash and one ATA/ATAPI device
- Can place the ATA interface in high-impedance (Hi-Z) to allow sharing of the ATA bus with another controller (e.g., an IEEE-1394 to ATA bridge chip or MP3 Decoder)
- Support for board-level manufacturing test via USB interface
- · Low-power 3.3V operation
- Fully compatible with native USB mass storage class drivers
- Cypress mass storage class drivers available for Windows (98SE, ME, 2000, XP) and Mac OS X

## 1.1 Features (CY7C68320/CY7C68321 only)

- Supports HID interface or custom GPIOs to enable features such as single button backup, power-off, LED-based notification, etc.
- · Lead-free 56-pin QFN and 100-pin TQFP packages
- · CY7C68321 is ideal for battery-powered designs
- CY7C68320 is ideal for self- and bus-powered designs

# 1.2 Features (CY7C68300B/CY7C68301B only)

- Pin-compatible with CY7C68300A (using Backward Compatibility mode)
- Lead-free 56-pin SSOP and 56-pin QFN packages
- CY7C68301B is ideal for battery-powered designs
- CY7C68300B is ideal for self- and bus-powered designs

# 2.0 Block Diagram









## 3.0 Applications

The CY7C68300B/301B and CY7C68320/321 implement a USB 2.0 bridge for all ATA/ATAPI-6 compliant mass storage devices, such as the following.

- · Hard drives
- · CD-ROM, CD-R/W
- DVD-ROM, DVD-RAM, DVD+/–R/W
- MP3 players
- · Personal media players
- CompactFlash
- Microdrives
- · Tape drives
- · Personal video recorders

The CY7C68300B/301B and CY7C68320/321 support one or two devices in the following configurations.

- · ATA/ATAPI master only
- · ATA/ATAPI slave only
- ATA/ATAPI master and slave
- CompactFlash only
- ATA/ATAPI slave and CompactFlash or other removable IDE master

## 3.1 Additional Resources

- CY4615B EZ-USB AT2LP Reference Design Kit
- USB Specification version 2.0
- ATA Specification T13/1410D Rev 3B
- USB Mass Storage Class Bulk Only Transport Specification, www.usb.org

## 4.0 Introduction

The EZ-USB AT2LP™ (CY7C68300B/CY7C68301B and CY7C68320/CY7C68321) implements a fixed function bridge between one USB port and one or two ATA- or ATAPI-based

mass storage device ports. This bridge adheres to the *Mass Storage Class Bulk-Only Transport Specification* and is intended for bus- and self-powered devices.

The AT2LP is the latest addition to the Cypress USB mass storage portfolio, and is an ideal cost- and power-reduction path for designs that previously used the ISD-300A1, ISD-300LP, or EZ-USB AT2.

Specifically, the CY7C68300B/CY7C68301B includes a mode that makes it pin-for-pin compatible with the EZ-USB AT2 (CY7C68300A).

The USB port of the CY7C68300B/301B and CY7C68320/321 (AT2LP) are connected to a host computer directly or via the downstream port of a USB hub. Host software issues commands and data to the AT2LP and receives status and data from the AT2LP using standard USB protocol.

The ATA/ATAPI port of the AT2LP is connected to one or two mass storage devices. A 4-Kbyte buffer maximizes ATA/ATAPI data transfer rates by minimizing losses due to device seek times. The ATA interface supports ATA PIO modes 0, 3, and 4, multiword DMA mode 2 and Ultra DMA modes 2, 3, and 4.

The device initialization process is configurable, enabling the AT2LP to initialize ATA/ATAPI devices without software intervention.

## 5.0 68300A Compatibility

The CY7C68300B/301B and CY7C68320/321 are available in three package types that are pictured in the following sections. As mentioned above, the CY7C68300B/301B contains a backward compatibility mode that allows the CY7C68300B/301B to be used in existing EZ-USB AT2 (CY7C68300A) designs. Please refer to the logic flow below for more information on the pinout selection process.



Figure 5-1. Simplified Startup Flowchart (68300B only)



# 5.1 Pin Diagrams

|    |                                                                                                | 1  |
|----|------------------------------------------------------------------------------------------------|----|
| 1  | DD13 DD12                                                                                      | 56 |
| 2  | DD14 DD11                                                                                      | 55 |
| 3  | DD15 DD10                                                                                      | 54 |
| 4  | GND DD9                                                                                        | 53 |
| 5  | ATAPUEN (GND) DD8                                                                              | 52 |
| 6  | VCC (ATA_EN) VBUS_ATA_ENABLE                                                                   | 51 |
| 7  | GND VCC                                                                                        | 50 |
| 8  | IORDY RESET#                                                                                   | 49 |
| 9  | DMA RQ GND                                                                                     | 48 |
| 10 | AVCC ARESET#                                                                                   | 47 |
| 11 | XTALOUT (VBUS_PWR_VALID) DA2                                                                   | 46 |
| 12 | XTALIN CS1#                                                                                    | 45 |
| 13 | AGND CS0#                                                                                      | 44 |
| 14 | VCC ( <i>DA2</i> ) DRVPWRVLD                                                                   | 43 |
| 15 | DPLUS <b>EZ-USB AT2LP</b> DA1                                                                  | 42 |
| 16 | DMINUS CY7C68300B                                                                              | 41 |
| 17 | GND INTRQ I                                                                                    | 40 |
| 18 | vcc <b>CY7C68301B</b> vcc                                                                      | 39 |
| 19 | GND 56-pin SSOP DMACK#                                                                         | 38 |
| 20 | PWR500# ( <i>PU 10K</i> ) DIOR#                                                                | 37 |
| 21 | GND (Reserved) DIOW#                                                                           | 36 |
| 22 | SCL GND                                                                                        | 35 |
| 23 | SDA VCC                                                                                        | 34 |
| 24 | VCC NOTE: Labels in italics denote pin functionality GND during CY7C68300A compatibility mode. | 33 |
| 25 | DD0 DD7                                                                                        | 32 |
| 26 | DD1 DD6                                                                                        | 31 |
| 27 | DD2 DD5                                                                                        | 30 |
| 28 | DD3 DD4                                                                                        | 29 |
|    |                                                                                                |    |

Figure 5-2. 56-pin SSOP Pinout (CY7C68300B/CY7C68301B only)





Figure 5-3. 56-pin QFN Pinout (CY7C68300B/CY7C68301B)





Figure 5-4. 56-pin QFN Pinout (CY7C68320/CY7C68321)





Figure 5-5. 100-pin TQFP Pinout (CY7C68320/CY7C68321 only)



#### 5.2 **Pin Descriptions**

The following table lists the pinouts for the 56-pin SSOP, 56pin QFN and 100-pin TQFP package options for the AT2LP. Please refer to the Pin Diagrams in section 5.1 for differences

between the 68300B/01B and 68320/321 pinouts for the 56pin packages. For information on the CY7C68300A pinout, please refer to the CY7C68300A data sheet that is found in the "EZ-USB AT2" folder of the CY4615B reference design kit CD.

Table 5-1. AT2LP Pin Descriptions Note: (Italics pin names denote pin functionality during CY7C68300A-compatibility mode)

| 56<br>SSOP | 56<br>QFN         | 100<br>TQFP        | Pin Name                                    | Pin<br>Type        | Default State<br>at Start-up | Pin Description                                                                                                                                         |
|------------|-------------------|--------------------|---------------------------------------------|--------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | 50                | 96                 | DD13                                        | I/O <sup>[1]</sup> | Hi-Z                         | ATA Data bit 13.                                                                                                                                        |
| 2          | 51                | 97                 | DD14                                        | I/O <sup>[1]</sup> | Hi-Z                         | ATA Data bit 14.                                                                                                                                        |
| 3          | 52                | 98                 | DD15                                        | I/O <sup>[1]</sup> | Hi-Z                         | ATA Data bit 15.                                                                                                                                        |
| 4          | 53                | 99                 | GND                                         | GND                |                              | Ground.                                                                                                                                                 |
| 5          | 54 <sup>[3]</sup> | 100 <sup>[3]</sup> | ATAPUEN<br>( <i>NC</i> )                    | I/O                |                              | ATA pull-up voltage source for bus-powered applications (see section 5.3.10).                                                                           |
|            |                   |                    |                                             |                    |                              | <b>Alternate Function</b> : Input when the EEPROM configuration byte 8 has bit 7 set to one. The input value is reported through EP1IN (byte 0, bit 2). |
| 6          | 55                | 1                  | V <sub>CC</sub>                             | PWR                |                              | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                         |
| 7          | 56                | 2                  | GND                                         | GND                |                              | Ground.                                                                                                                                                 |
| 8          | 1                 | 3                  | IORDY                                       | <sub>[</sub> [1]   | Input                        | ATA Control.                                                                                                                                            |
| 9          | 2                 | 4                  | DMARQ                                       | <sub>[</sub> [1]   | Input                        | ATA Control.                                                                                                                                            |
| N/A        | N/A               | 5<br>6<br>7<br>8   | GND                                         |                    |                              | Ground.                                                                                                                                                 |
| 10         | 3                 | 9                  | AV <sub>CC</sub>                            | PWR                |                              | <b>Analog <math>V_{CC}</math>.</b> Connect to $V_{CC}$ through the shortest path possible.                                                              |
| 11         | 4                 | 10                 | XTALOUT                                     | Xtal               | Xtal                         | 24-MHz Crystal Output (see section 5.3.3).                                                                                                              |
| 12         | 5                 | 11                 | XTALIN                                      | Xtal               | Xtal                         | 24-MHz Crystal Input (see section 5.3.3).                                                                                                               |
| 13         | 6                 | 12                 | AGND                                        | GND                |                              | <b>Analog Ground</b> . Connect to ground with as short a path as possible.                                                                              |
| N/A        | N/A               | 13<br>14<br>15     | NC                                          |                    |                              | No Connect.                                                                                                                                             |
| 14         | 7                 | 16                 | V <sub>CC</sub>                             | PWR                |                              | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                         |
| 15         | 8                 | 17                 | DPLUS                                       | I/O                | Hi-Z                         | USB D+ Signal (see section 5.3.1).                                                                                                                      |
| 16         | 9                 | 18                 | DMINUS                                      | I/O                | Hi-Z                         | USB D- Signal (see section 5.3.1).                                                                                                                      |
| 17         | 10                | 19                 | GND                                         | GND                |                              | Ground.                                                                                                                                                 |
| 18         | 11                | 20                 | V <sub>CC</sub>                             | PWR                |                              | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                         |
| 19         | 12                | 21                 | GND                                         | GND                |                              | Ground.                                                                                                                                                 |
| N/A        | N/A               | 22                 | SYSIRQ                                      | I                  | Input                        | <b>Active HIGH</b> . USB interrupt request (see section 5.3.4). Tie to GND if functionality is not used.                                                |
| N/A        | N/A               | 23<br>24<br>25     | GND                                         | GND                |                              | Ground.                                                                                                                                                 |
| 20         | 13 <sup>[3]</sup> | 26 <sup>[3]</sup>  | PWR500# <sup>[2]</sup><br>( <i>PU 10K</i> ) | I/O                |                              | Active LOW. VBUS power granted indicator used in bus-powered designs (see section 5.3.11).                                                              |
|            |                   |                    |                                             |                    |                              | Alternate Function for 68320.                                                                                                                           |
| 21         | 14                | 27                 | GND (RESERVED)                              |                    |                              | Reserved. Tie to GND.                                                                                                                                   |

#### Notes:

- If byte 8, bit 4 of the EEPROM is set to '0', the ATA interface pins are only active when VBUS\_ATA\_EN is asserted. See section 5.3.9.
   A '#' sign after the pin name indicates that it is active LOW.
   The General Purpose inputs can be enabled on ATAPUEN, PWR500#, and DRVPWRVLD via EEPROM byte 8, bit 7 on CY7C68320/CY7C68321.



Table 5-1. AT2LP Pin Descriptions
Note: (Italics pin names denote pin functionality during CY7C68300A-compatibility mode) (continued)

| 56<br>SSOP | 56<br>QFN | 100<br>TQFP    | Pin Name             | Pin<br>Type        | Default State at Start-up | Pin Description                                                                                                                                                                        |
|------------|-----------|----------------|----------------------|--------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N/A        | N/A       | 28             | NC                   | 1                  | -                         | No Connect.                                                                                                                                                                            |
| 22         | 15        | 29             | SCL                  | 0                  | Active for                | Clock signal for I <sup>2</sup> C interface (see section 5.3.2).                                                                                                                       |
| 23         | 16        | 30             | SDA                  | I/O                | several ms at start-up.   | Data signal for I <sup>2</sup> C interface (see section 5.3.2).                                                                                                                        |
| N/A        | N/A       | 31<br>32       | NC                   |                    |                           | No Connect.                                                                                                                                                                            |
| 24         | 17        | 33             | V <sub>CC</sub>      | PWR                |                           | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                        |
| 25         | 18        | 34             | DD0                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 0.                                                                                                                                                                        |
| 26         | 19        | 35             | DD1                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 1.                                                                                                                                                                        |
| 27         | 20        | 36             | DD2                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 2.                                                                                                                                                                        |
| 28         | 21        | 37             | DD3                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 3.                                                                                                                                                                        |
| N/A        | N/A       | 38             | V <sub>CC</sub>      | PWR                |                           | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                        |
| N/A        | N/A       | 39             | GND                  | GND                |                           | Ground.                                                                                                                                                                                |
| N/A        | N/A       | 40             | NC                   | NC                 |                           | No Connect.                                                                                                                                                                            |
| N/A        | N/A       | 41             | GND                  |                    |                           | Ground.                                                                                                                                                                                |
| N/A        | N/A       | 42             | NC                   | NC                 |                           | No Connect.                                                                                                                                                                            |
| N/A        | N/A       | 43             | GND                  |                    |                           | Ground.                                                                                                                                                                                |
| 29         | 22        | 44             | DD4                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 4.                                                                                                                                                                        |
| 30         | 23        | 45             | DD5                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 5.                                                                                                                                                                        |
| 31         | 24        | 46             | DD6                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 6.                                                                                                                                                                        |
| 32         | 25        | 47             | DD7                  | I/O <sup>[1]</sup> | Hi-Z                      | ATA Data bit 7.                                                                                                                                                                        |
| 33         | 26        | 48             | GND                  | GND                |                           | Ground.                                                                                                                                                                                |
| 34         | 27        | 49             | V <sub>CC</sub>      | PWR                |                           | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                        |
| 35         | 28        | 50             | GND                  | GND                |                           | Ground.                                                                                                                                                                                |
| N/A        | N/A       | 51<br>52       | NC                   | NC                 |                           | No Connect.                                                                                                                                                                            |
| N/A        | N/A       | 53             | V <sub>CC</sub>      | PWR                |                           | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                        |
| 36         | 29        | 54             | DIOW# <sup>[2]</sup> | O/Z <sup>[1]</sup> | Driven HIGH<br>(CMOS)     | ATA Control.                                                                                                                                                                           |
| 37         | 30        | 55             | DIOR#                | O/Z <sup>[1]</sup> | Driven HIGH<br>(CMOS)     | ATA Control.                                                                                                                                                                           |
| 38         | 31        | 56             | DMACK#               | O/Z <sup>[1]</sup> | Driven HIGH<br>(CMOS)     | ATA Control.                                                                                                                                                                           |
| N/A        | N/A       | 57             | NC                   | NC                 |                           | No Connect.                                                                                                                                                                            |
| N/A        | N/A       | 58             | LOWPWR#              | 0                  |                           | USB suspend indicator (see section 5.3.7).  '0' = Chip active. VBUS power draw governed by PWR500# pin.  'Hi-Z' = Chip suspend. VBUS system current limited to USB suspend mode value. |
| N/A        | N/A       | 59<br>60<br>61 | NC                   | NC                 |                           | No Connect.                                                                                                                                                                            |
| N/A        | N/A       | 62             | VBUSPWRD             | I                  | Input                     | <b>Bus-powered operation selector</b> . Used in systems that are capable of being bus or self-powered to indicate the current power mode.                                              |
| N/A        | N/A       | 63<br>64       | NC                   | NC                 |                           | No Connect.                                                                                                                                                                            |
| N/A        | N/A       | 65             | GND                  | GND                |                           | Ground.                                                                                                                                                                                |



Table 5-1. AT2LP Pin Descriptions
Note: (Italics pin names denote pin functionality during CY7C68300A-compatibility mode) (continued)

| 56<br>SSOP | 56<br>QFN                                                   | 100<br>TQFP                      | Pin Name                                               | Pin<br>Type        | Default State at Start-up          | Pin Description                                                                                                                                                                                                                                                                    |
|------------|-------------------------------------------------------------|----------------------------------|--------------------------------------------------------|--------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 39         | 32                                                          | 66                               | V <sub>CC</sub>                                        | PWR                |                                    | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                                                                                                                    |
| 40         | 33                                                          | 67                               | INTRQ                                                  | [ <sup>[1]</sup>   | Input                              | ATA Interrupt request.                                                                                                                                                                                                                                                             |
| 41         | 34                                                          | 68                               | DA0                                                    | O/Z <sup>[1]</sup> | Driven HIGH<br>after 2 ms<br>delay | ATA Address.                                                                                                                                                                                                                                                                       |
| 42         | 35                                                          | 69                               | DA1                                                    | O/Z <sup>[1]</sup> | Driven HIGH<br>after 2 ms<br>delay | ATA Address.                                                                                                                                                                                                                                                                       |
| 43         | 36 <sup>[3]</sup>                                           | 70 <sup>[3]</sup>                | DRVPWRVLD<br>( <i>DA2</i> )                            | ı                  | Input                              | Device Presence Detect (see section 5.3.5). Configurable polarity, controlled by EEPROM address 0x08. This pin must be connected to GND if functionality is not utilized.  Alternate Function: Input when the EEPROM configuration byte 8 has bit 7 set to one. The input value is |
| 44         | 37                                                          | 71                               | CS0#                                                   | O/Z <sup>[1]</sup> | Driven HIGH<br>after 2 ms<br>delay | reported through EP1IN (byte 0, bit 0).  ATA Chip Select.                                                                                                                                                                                                                          |
| 45         | 38                                                          | 72                               | CS1#                                                   | O/Z <sup>[1]</sup> | Driven HIGH<br>after 2 ms<br>delay | ATA Chip Select.                                                                                                                                                                                                                                                                   |
| 46         | 39                                                          | 73                               | DA2<br>( <i>VBUS_PWR_VALID</i> )                       | O/Z <sup>[1]</sup> | Driven HIGH<br>after 2 ms<br>delay | ATA Address.                                                                                                                                                                                                                                                                       |
| 47         | 40                                                          | 74                               | ARESET#                                                | O/Z <sup>[1]</sup> |                                    | ATA Reset.                                                                                                                                                                                                                                                                         |
| 48         | 41                                                          | 75                               | GND                                                    | GND                |                                    | Ground.                                                                                                                                                                                                                                                                            |
| N/A        | N/A                                                         | 76                               | NC                                                     | NC                 |                                    | No Connect.                                                                                                                                                                                                                                                                        |
| 49         | 42                                                          | 77                               | RESET#                                                 | I                  | Input                              | <b>Chip Reset</b> (see section 5.3.13). This pin is normally tied to V <sub>CC</sub> through a 100K resistor, and to GND through a 0.1-µF capacitor, supplying a 10-ms reset.                                                                                                      |
| 50         | 43                                                          | 78                               | V <sub>CC</sub>                                        | PWR                |                                    | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                                                                                                                    |
| 51         | 44                                                          | 79                               | VBUS_ATA_ENABLE<br>(ATA_EN)                            | I                  | Input                              | VBUS detection (see section 5.3.9). Indicates to the CY7C68300B/CY7C68301B that VBUS power is present.                                                                                                                                                                             |
| 52         | 45                                                          | 80                               | DD8                                                    | I/O <sup>[1]</sup> | Hi-Z                               | ATA Data bit 8.                                                                                                                                                                                                                                                                    |
| 53         | 46                                                          | 81                               | DD9                                                    | I/O <sup>[1]</sup> | Hi-Z                               | ATA Data bit 9.                                                                                                                                                                                                                                                                    |
| 54         | 47                                                          | 82                               | DD10                                                   | I/O <sup>[1]</sup> | Hi-Z                               | ATA Data bit 10.                                                                                                                                                                                                                                                                   |
| 55         | 48                                                          | 83                               | DD11                                                   | I/O <sup>[1]</sup> | Hi-Z                               | ATA Data bit 11.                                                                                                                                                                                                                                                                   |
| N/A        | N/A                                                         | 84                               | GND                                                    |                    |                                    | Ground.                                                                                                                                                                                                                                                                            |
| N/A        | N/A                                                         | 85                               | V <sub>CC</sub>                                        | PWR                |                                    | V <sub>CC</sub> . Connect to 3.3V power source.                                                                                                                                                                                                                                    |
| N/A        | N/A                                                         | 86<br>87                         | NC                                                     | NC                 |                                    | No Connect.                                                                                                                                                                                                                                                                        |
| N/A        | 36 <sup>[3]</sup><br>13 <sup>[3]</sup><br>54 <sup>[3]</sup> | 88<br>89<br>90<br>91<br>92<br>93 | GPIO0<br>GPIO1<br>GPIO2_nHS<br>GPIO3<br>GPIO4<br>GPIO5 | I/O <sup>[3]</sup> |                                    | General purpose I/O pins (see section 5.3.6). The GPIO pins must be tied to GND if functionality is not utilized. If the hs_indicator config bit is set, the GPIO2_nHS pin will reflect the operating speed: '1' = full-speed operation. '0' = high-speed operation.               |
| N/A        | N/A                                                         | 94                               | GND                                                    | GND                |                                    | Ground.                                                                                                                                                                                                                                                                            |
| 56         | 49                                                          | 95                               | DD12                                                   | I/O <sup>[1]</sup> | Hi-Z                               | ATA Data bit 12.                                                                                                                                                                                                                                                                   |



## 5.3 Additional Pin Descriptions

# 5.3.1 DPLUS, DMINUS

DPLUS and DMINUS are the USB signaling pins; they should be tied to the D+ and D- pins of the USB connector. Because they operate at high frequencies, the USB signals require special consideration when designing the layout of the PCB. See section 15.0 for PCB layout recommendations. When RESET# is released, the internal pull-up on D+ is controlled by VBUS\_ATA\_ENABLE. When VBUS\_ATA\_ENABLE is HIGH, D+ is pulled up.

### 5.3.2 SCL, SDA

The clock and data pins for the  $I^2C$  port should be connected to the configuration EEPROM and to 2.2K pull-up resistors tied to  $V_{CC}$ . The SCL and SDA pins are active for several milliseconds at start-up.

## 5.3.3 XTALIN, XTALOUT

The AT2LP requires a 24-MHz (±100ppm) signal to derive internal timing. Typically, a 24-MHz (20-pF, 500-μW, parallel-

resonant fundamental mode) crystal is used, but a 24-MHz square wave from another source can also be used. If a crystal is used, connect its pins to XTALIN and XTALOUT, and also through 12-pF capacitors to GND as shown in *Figure 5-6*. If an alternate clock source is used, apply it to XTALIN and leave XTALOUT open.

#### 5.3.4 SYSIRQ

The SYSIRQ pin provides a way for systems to request service from host software by using the USB Interrupt pipe. If the AT2LP has no pending interrupt data to return, USB interrupt pipe data requests are NAKed. If pending data is available, the AT2LP returns 16 bits of data; this data indicates the HS\_MODE signal (that indicates whether AT2LP is operating in high-speed or full-speed), the VBUSPWRD pin, and the GPIO pins. *Table 5-2* gives the bitmap for the data returned on the interrupt pipe and *Figure 5-7* depicts the latching algorithm incorporated by AT2LP.

The SYSIRQ pin must be tied low if the HID function is used (refer to Section 6.0).



Figure 5-6. XTALIN / XTALOUT Diagram

Table 5-2. USB Interrupt Pipe Data Bitmap

| USB Interrupt Data Byte 1 |          |          |          |          |          |                |          | USB Interrupt Data Byte 0 |          |         |         |         |         |         |         |
|---------------------------|----------|----------|----------|----------|----------|----------------|----------|---------------------------|----------|---------|---------|---------|---------|---------|---------|
| 7                         | 6        | 5        | 4        | 3        | 2        | 1              | 0        | 7                         | 6        | 5       | 4       | 3       | 2       | 1       | 0       |
| RESERVED                  | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | JSB High-Speed | VBUSPWRD | RESERVED                  | RESERVED | GP10[5] | GP10[4] | GP10[3] | GP10[2] | GP10[1] | GPIO[0] |







Figure 5-7. SYSIRQ Latching Algorithm

## 5.3.5 DRVPWRVLD

When this pin is enabled via EEPROM byte 8, bit 0, the AT2LP will inform the host that a removable device, such as a CF card, is present. The CY7C68300B/CY7C68301B will use DRVPWRVLD to detect that the removable device is present. Pin polarity is controlled by bit 1 of EEPROM address 8. When DRVPWRVLD is deasserted, the AT2LP will report a "no media present" status (ASC = 0x3A, ASQ = 0x00) to the host. When the media has been detected again, the AT2LP will report a "media changed" status to the host (ASC = 0x28, ASQ = 0x00).

When a removable device is used, it is always the master device. Only one removable device may be attached to the AT2LP. If the system only contains a removable device, EEPROM byte 8, bit 6 must be set to '0' to disable ATA device detection at start-up. If a non-removable device is connected in addition to a removable media device, it must be configured as a slave (device address 1).

DRVPWRVLD can also be configured as an input. See Section 6.0 HID Functions for Button Controls.

#### 5.3.6 GPIO Pins

The GPIO pins allow for a general purpose Input/Output interface. There are several different interfaces to the GPIO pins:

- Configuration bytes 0x09 and 0x0A contain the default settings for the GPIO pins.
- The host can modify the settings of the GPIO pins during operation. This is done with vendor-specific commands described in Section 8.6.

 The status of the GPIO pins is also returned on the interrupt endpoint (EP1) in response to a SYSIRQ. See section 5.3.3 for SYSIRQ details.

GPIO2\_nHS also has an alternate function. If the "HS Indicator Enable" configuration (bit 2 of EEPROM address 8) is set, the GPIO2\_nHS pin will reflect the operating speed of the device (full- or high-speed USB).

## 5.3.7 LOWPWR#

LOWPWR# is an output pin that is driven to '0' when the AT2LP is active. LOWPWR# is placed in Hi-Z when the AT2LP is in a suspend state.

## 5.3.8 ATA Interface Pins

Design practices for signal integrity as outlined in the ATA/ATAPI-6 Specification should be followed with systems that utilize a ribbon cable interconnect between the CY7C68300B/CY7C68301B's ATA interface and the attached ATA/ATAPI device, especially if Ultra DMA Mode is utilized.

#### 5.3.9 VBUS ATA ENABLE

VBUS\_ATA\_ENABLE is typically used to indicate to the AT2LP that power is present on VBUS. This pin is polled by the AT2LP at start-up and then every 20ms thereafter. If this pin is '1', the internal 1.5K pull-up is attached to D+. If this pin is '0', the AT2LP will release the pull-up on D+ as required by the USB specification. Also, If EEPROM byte 8, bit 4 is '0', the ATA interface pins will be placed in a high impedance (Hi-Z) state when VBUS\_ATA\_ENABLE is '0'. If EEPROM byte 8, bit 4 is '1', the ATA interface pins will still be driven when VBUS\_ATA\_ENABLE is '0'.



#### 5.3.10 ATAPUEN

This output controls the required host pull-up resistors on the ATA interface. ATAPUEN is driven to '0' when the ATA bus is inactive. ATAPUEN is driven to '1' when the ATA bus is active. ATAPUEN is set to a Hi-Z state along with all other ATA interface pins if VBUS\_ATA\_ENABLE is deasserted and the ATA\_EN functionality (EEPROM byte 8, bit 4) is enabled. ATAPUEN can also be configured as an input. See Section 6.0 HID Functions for Button Controls

#### 5.3.11 PWR500#

The AT2LP asserts PWR500# to indicate that VBUS current may be drawn up to the limit specified by the bMaxPower field of the USB configuration descriptors. In the 100-pin package, PWR500# will only be asserted if VBUSPWRD and DRVPWRVLD are also asserted. In the 56-pin package, PWR500# only functions during bus-powered operation. If the AT2LP enters a low-power state, PWR500# is deasserted. When normal operation is resumed, PWR500# is restored accordingly. Naturally, the PWR500# pin should never be used to control power sources for the AT2LP. In the 68320 parts, PWR500# can also be configured as an input. If the Drive Power Valid Enable bit is set (EEPROM byte 8, bit 1), PWR500# will ONLY be driven when Drive Power Valid is active. See Section 6.0 HID Functions for Button Controls.

#### 5.3.12 VBUSPWRD

Some devices have the ability to be either self-powered or bus-powered. The VBUSPWRD input pin enables these devices to change between self-powered to bus-powered modes by changing the contents of the bMaxPower field and the self-powered bit in the configuration descriptor.

Note that current host drivers do not poll the device for this information, so this pin is only effective on a USB or power-up reset.

Table 5-3. Bus-Power Description

| VBUSPWRD value        | 1                                      | 0       | Not present<br>(56-pin)                |
|-----------------------|----------------------------------------|---------|----------------------------------------|
| PWR500#               | 1 when Config = 0<br>0 when Config = 1 | 1       | 1 when Config = 0<br>0 when Config = 1 |
| bMaxPower             | 250 (500mA)                            | 1 (2mA) | EEPROM value used                      |
| bmAttributes<br>bit 6 | 0                                      | 1       | EEPROM value used                      |

#### 5.3.13 RESET#

Asserting RESET# for 10 ms will reset the entire chip. This pin is normally tied to  $V_{CC}$  through a 100k resistor, and to GND through a 0.1- $\mu$ F capacitor, as shown in the figure below.



Figure 5-8. Typical Reset Circuit

Cypress does not recommend an RC reset circuit for buspowered devices. See the application note *EZ-USB FX2™/AT2™/SX2™ Reset and Power Considerations* at www.cypress.com for more information.

## 6.0 HID Functions for Button Controls

Cypress' CY7C68320/CY7C68321 introduces the capability to support Human Interface Device (HID) signaling to the host for such functions as buttons. The ability to add buttons to a mass storage solution opens new applications for backup and other device-side notification to the host.

Optional HID functions can be added to the EEPROM descriptors by setting bit 7 of byte 8 of the EEPROM to a value of '1'. When this bit is set, several pins adopt alternate functions for the 56-pin package. This allows the pins to be used as button inputs. If there is a HID descriptor in the EEPROM, these pins are polled by the hardware approximately every 17 ms. If a change is detected in the pin(s) state, a report is sent via EP1. The report format for byte 0 and byte 1 are shown in *Table 6-1*.

Table 6-1. EP1 Data Bitmap

| EP1 Data Byte 1 |          |          |          |          |          |                | EP1 Data Byte 0 |           |         |         |         |         |         |         |         |
|-----------------|----------|----------|----------|----------|----------|----------------|-----------------|-----------|---------|---------|---------|---------|---------|---------|---------|
| 7               | 6        | 5        | 4        | 3        | 2        | 1              | 0               | 7         | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| RESERVED        | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | USB High-Speed | VBUSPWRD        | DRVPWRVLD | GPIO[4] | GPIO[3] | GPIO[2] | GPIO[1] | GPIO[0] | ATAPUEN | PWR500# |



## 7.0 Functional Overview

## 7.1 USB Signaling Speed

AT2LP operates at the following two of the three rates defined in the *USB Specification Revision 2.0* dated April 27, 2000:

- Full-speed, with a signaling bit rate of 12 Mbits/sec
- · High-speed, with a signaling bit rate of 480 Mbits/sec.

AT2LP does not support the low-speed signaling rate of 1.5 Mbits/sec.

## 7.2 ATA Interface

The ATA/ATAPI port on the AT2LP is compatible with the *Information Technology–AT Attachment with Packet Interface–6 (ATA/ATAPI-6) Specification, T13/1410D Rev 2a.* The AT2LP supports both ATAPI packet commands as well as ATA commands (by use of ATA Command Blocks), as outlined in Section 7.2.1. Refer to the *USB Mass Storage Class (MSC) Bulk Only Transport (BOT)* Specification for information on Command Block formatting. Additionally, the AT2LP translates

ATAPI SFF-8070i commands to ATA commands for seamless integration of ATA devices with generic Mass Storage Class BOT drivers.

# 7.2.1 ATA Command Block (ATACB)

The ATA Command Block (ATACB) functionality provides a means of passing ATA commands and ATA register accesses to the attached device for execution. ATACB commands are transferred in the Command Block Wrapper Command Block (CBWCB) portion of the Command Block Wrapper (CBW). The ATACB is distinguished from other command blocks by having the first two bytes of the command block match the bVSCBSignature and bVSCBSubCommand values that are defined in *Table 7-1*. Only command blocks that have a valid bVSCBSignature and bVSCBSubCommand are interpreted as ATA Command Blocks. All other fields of the CBW and restrictions on the CBWCB remain as defined in the USB Mass Storage Class Bulk-Only Transport Specification. The ATACB must be 16 bytes in length. The following table and text defines the fields of the ATACB.

Table 7-1. ATACB Field Descriptions

| Byte | Field Name          | Field Description                                                                                                                                                                                                                                                                                                                                                                                   |
|------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | bVSCBSignature      | This field indicates to the CY7C68300B/CY7C68301B that the ATACB contains a vendor-specific command block. This value of this field must match the value in EEPROM address 0x04 for this vendor-specific command to be recognized.                                                                                                                                                                  |
| 1    | bVSCBSubCommand     | This field must be set to 0x24 for ATACB commands.                                                                                                                                                                                                                                                                                                                                                  |
| 2    | bmATACBActionSelect | This field controls the execution of the ATACB according to the bitfield values:                                                                                                                                                                                                                                                                                                                    |
|      |                     | Bit 7 IdentifyPacketDevice – This bit indicates that the data phase of the command will contain ATAPI (0xA1) or ATA (0xEC) IDENTIFY device data. Setting IdentifyPacketDevice when the data phase does not contain IDENTIFY device data will result in unspecified device behavior.  0 = Data phase does not contain IDENTIFY device data 1 = Data phase contains ATAPI or ATA IDENTIFY device data |
|      |                     | Bit 6 <i>UDMACommand</i> – This bit enables supported UDMA device transfers. Setting this bit when a non-UDMA capable device is attached will result in undetermined behavior.  0 = Do not use UDMA device transfers (only use PIO mode)  1 = Use UDMA device transfers                                                                                                                             |
|      |                     | Bit 5 <i>DEVOverride</i> – This bit determines whether the DEV bit value is taken from the value assigned to the LUN during start-up or from the ATACB.  0 = The DEV bit will be taken from the value assigned to the LUN during start-up  1 = The DEV bit will be taken from the ATACB field 0x0B, bit 4                                                                                           |
|      |                     | Bit 4 DErrorOverride – This bit controls the device error override feature. This bit should not be set during a bmATACBActionSelect TaskFileRead.  0 = Data accesses are halted if a device error is detected  1 = Data accesses are not halted if a device error is detected                                                                                                                       |
|      |                     | Bit 3 PErrorOverride – This bit controls the phase error override feature. This bit should not be set during a bmATACBActionSelect TaskFileRead.  0 = Data accesses are halted if a phase error is detected  1 = Data accesses are not halted if a phase error is detected                                                                                                                          |
|      |                     | Bit 2 <i>PollAltStatOverride</i> – This bit determines whether or not the Alternate Status register will be polled and the BSY bit will be used to qualify the ATACB operation.  0 = The AltStat register will be polled until BSY=0 before proceeding with the ATACB operation  1 = The ATACB operation will be executed without polling the AltStat register.                                     |



Table 7-1. ATACB Field Descriptions (continued)

| Byte  | Field Name               | Field Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                          | Bit 1 DeviceSelectionOverride – This bit determines when the device selection will be performed in relation to the command register write accesses.  0 = Device selection will be performed prior to command register write accesses                                                                                                                                                                                          |
|       |                          | 1 = Device selection will be performed following command register write accesses                                                                                                                                                                                                                                                                                                                                              |
|       |                          | Bit 0 TaskFileRead – This bit determines whether or not the taskfile register data selected in bmATACBRegisterSelect is returned. If this bit is set, the dCBWDataTransferLength field must be set to 8.  0 = Execute ATACB command and data transfer (if any)  1 = Only read taskfile registers selected in bmATACBRegisterSelect and return 0x00h for all others. The format of the 12 bytes of returned data is as follows |
|       |                          | <ul> <li>Address offset 0x00 (0x3F6) – Alternate Status</li> </ul>                                                                                                                                                                                                                                                                                                                                                            |
|       |                          | <ul> <li>Address offset 0x01 (0x1F1) – Features / Error</li> </ul>                                                                                                                                                                                                                                                                                                                                                            |
|       |                          | <ul> <li>Address offset 0x02 (0x1F2) – Sector Count</li> </ul>                                                                                                                                                                                                                                                                                                                                                                |
|       |                          | <ul> <li>Address offset 0x03 (0x1F3) – Sector Number</li> </ul>                                                                                                                                                                                                                                                                                                                                                               |
|       |                          | <ul> <li>Address offset 0x04 (0x1F4) – Cylinder Low</li> </ul>                                                                                                                                                                                                                                                                                                                                                                |
|       |                          | <ul> <li>Address offset 0x05 (0x1F5) – Cylinder High</li> </ul>                                                                                                                                                                                                                                                                                                                                                               |
|       |                          | <ul> <li>Address offset 0x06 (0x1F6) – Device / Head</li> </ul>                                                                                                                                                                                                                                                                                                                                                               |
|       |                          | <ul> <li>Address offset 0x07 (0x1F7) – Command / Status</li> </ul>                                                                                                                                                                                                                                                                                                                                                            |
| 3     | bmATACBRegisterSelect    | This field controls which of the taskfile register read or write accesses occur. Taskfile read data will always be 8 bytes in length, and unselected register data will be returned as 0x00. Register accesses occur in sequential order as outlined below (0 to 7).                                                                                                                                                          |
|       |                          | Bit 0 (0x3F6) Device Control / Alternate Status                                                                                                                                                                                                                                                                                                                                                                               |
|       |                          | Bit 1 (0x1F1) Features / Error                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                          | Bit 2 (0x1F2) Sector Count                                                                                                                                                                                                                                                                                                                                                                                                    |
|       |                          | Bit 3 (0x1F3) Sector Number                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |                          | Bit 4 (0x1F4) Cylinder Low                                                                                                                                                                                                                                                                                                                                                                                                    |
|       |                          | Bit 5 (0x1F5) Cylinder High                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |                          | Bit 6 (0x1F6) Device / Head                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |                          | Bit 7 (0x1F7) Command / Status                                                                                                                                                                                                                                                                                                                                                                                                |
| 4     | bATACBTransferBlockCount | · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4     | DATAGETransferBlockCount | This value indicates the maximum requested block size in 512-byte increments. This value must be set to the last value used for the "Sectors per block" in the SET_MULTIPLE_MODE command. Legal values are 0, 1, 2, 4, 8, 16, 32, 64, and 128 where 0 indicates 256 sectors per block. A command failed status will be returned if an illegal value is used in the ATACB.                                                     |
| 5–12  | bATACBTaskFileWriteData  | These bytes contain ATA register data used with ATA command or PIO write operations. Only registers selected in bmATACBRegisterSelect are required to hold valid data when accessed. The registers are as follows.                                                                                                                                                                                                            |
|       |                          | ATACB Address Offset 0x05 (0x3F6) – Device Control                                                                                                                                                                                                                                                                                                                                                                            |
|       |                          | ATACB Address Offset 0x06 (0x1F1) – Features                                                                                                                                                                                                                                                                                                                                                                                  |
|       |                          | ATACB Address Offset 0x07 (0x1F2) – Sector Count                                                                                                                                                                                                                                                                                                                                                                              |
|       |                          | ATACB Address Offset 0x08 (0x1F3) – Sector Number                                                                                                                                                                                                                                                                                                                                                                             |
|       |                          | ATACB Address Offset 0x09 (0x1F4) – Cylinder Low                                                                                                                                                                                                                                                                                                                                                                              |
|       |                          | ATACB Address Offset 0x0A (0x1F5) – Cylinder High                                                                                                                                                                                                                                                                                                                                                                             |
|       |                          | , , ,                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |                          | ATACB Address Offset 0x0B (0x1F6) – Device                                                                                                                                                                                                                                                                                                                                                                                    |
| 10 := |                          | ATACB Address Offset 0x0C (0x1F7) – Command                                                                                                                                                                                                                                                                                                                                                                                   |
| 13–15 | Reserved                 | These bytes must be set to 0x00 for ATACB commands.                                                                                                                                                                                                                                                                                                                                                                           |

# 8.0 Operating Modes



Figure 8-1. Operational Mode Selection

## 8.1 Operational Mode Selection Flow

During the power-up sequence, the AT2LP checks the I<sup>2</sup>C port for an EEPROM and checks to see if the ATA connector is configured for Board Manufacturing Test Mode. AT2LP then selects an operating mode as shown below.

 If an I<sup>2</sup>C EEPROM with a 0x4D4D signature is found, the CY7C68300B/CY7C68301B uses the same pinout and EE-PROM format as the CY7C68300A (EZ-USB AT2).

- If the first two bytes of the EEPROM contain 0x534B the AT2LP uses the values stored in the EEPROM to configure the USB descriptors for normal operation.
- If no EEPROM is detected, the AT2LP uses a VID/PID of 0x00/0x00. This is not a valid mode of operation.
- If an invalid EEPROM signature is read, the AT2LP defaults into Board Manufacturing Test Mode.

There is an additional method available to put the AT2LP into Board Manufacturing Test Mode to allow reprogramming of



EEPROMs without an ATA/ATAPI device attached. If the ATA Reset (ARESET#) line is LOW on power-up, the AT2LP will enter Board Manufacturing Test Mode. A convenient way to pull the ARESET# line LOW is to short pins 1 and 3 on the ATA connector, which will tie the ARESET# line to the pull-down on DD7.

#### 8.2 "No EEPROM Detected" Mode

When no EEPROM is detected at start-up, the AT2LP will enumerate with VID/PID/DID values that are all 0x00, which is not a valid mode of operation. These values can be factory programmed into the AT2LP for high-volume applications to avoid the need for an external EEPROM in some designs. Contact your local Cypress Semiconductor sales office for details.

## 8.3 Normal Mass Storage Mode

In Normal Mass Storage Mode, the chip behaves as a USB 2.0 to ATA/ATAPI bridge. This includes all typical USB device states (powered, configured, etc.). The USB descriptors are returned according to the values stored in the external EEPROM. An external EEPROM is required for Mass Storage Class Bulk-Only Transport compliance, since a unique serial number is required for each device. Also, Cypress requires customers to use their own Vendor and Product IDs for final products.

## 8.4 Board Manufacturing Test Mode

In Board Manufacturing Test Mode, the chip behaves as a USB 2.0 device but the ATA/ATAPI interface is not fully active.

In this mode, the AT2LP allows for reading from and writing to the EEPROM, and for board level testing through vendor specific ATAPI commands utilizing the CBW Command Block as described in the USB *Mass Storage Class Bulk-Only Transport Specification*. There is a vendor-specific ATAPI command for the EEPROM access (CfgCB) and one for the board level testing (MfgCB).

### 8.4.1 CfgCB

The cfg\_load and cfg\_read vendor-specific commands are passed down through the bulk pipe in the CBWCB portion of the CBW. The format of this CfgCB is shown below. Byte 0 will be a vendor-specific command designator whose value is configurable and set in the configuration data (EEPROM address 0x04). Byte 1 must be set to 0x26 to identify CfgCB. Byte 2 is reserved and must be set to zero. Byte 3 is used to determine the memory source to write/read. For the CY7C68300B/CY7C68301B, this byte must be set to 0x02, indicating the EEPROM is present. Bytes 4 and 5 are used to determine the start address. For the CY7C68300B/301B, this must always be 0x0000. Bytes 6 through 15 are reserved and must be set to zero.

The data transferred to the EEPROM must be in the format specified in *Table 8-6* of this data sheet. Maximum data transfer size is 255 bytes.

The data transfer length is determined by the CBW Data Transfer Length specified in bytes 8 through 11 (dCBWDataTransferLength) of the CBW (refer to *Table 8-1*). The type/direction of the command will be determined by the direction bit specified in byte 12, bit 7 (bmCBWFlags) of the CBW (refer to *Table 8-1*).

Table 8-1. Command Block Wrapper

|                       | Bits                      |                           |         |   |   |     |      |   |  |  |  |  |
|-----------------------|---------------------------|---------------------------|---------|---|---|-----|------|---|--|--|--|--|
| Offset                | 7                         | 6                         | 5       | 4 | 3 | 2   | 1    | 0 |  |  |  |  |
| 0–3                   |                           | DCBWSignature             |         |   |   |     |      |   |  |  |  |  |
| 4–7                   |                           | dCBWTag                   |         |   |   |     |      |   |  |  |  |  |
| <b>8–11</b> (08h–0Bh) | dCBWDataTransferLength    |                           |         |   |   |     |      |   |  |  |  |  |
| <b>12</b> (0Ch)       | bwCBWFLAGS                |                           |         |   |   |     |      |   |  |  |  |  |
|                       | Dir Obsolete Reserved (0) |                           |         |   |   |     |      |   |  |  |  |  |
| 13 (0Dh)              |                           | Reser                     | ved (0) |   |   | bCB | WLUN |   |  |  |  |  |
| 14 (0Eh)              |                           | Reserved (0) bCBWCBLength |         |   |   |     |      |   |  |  |  |  |
| 15-30 (0Fh1Eh)        |                           | CBWCB (CfgCB or MfgCB)    |         |   |   |     |      |   |  |  |  |  |

Table 8-2. Example CfgCB

| Offset | CfgCB Byte Descriptions                     |   |   |   | В | its |   |   |   |
|--------|---------------------------------------------|---|---|---|---|-----|---|---|---|
|        |                                             | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
| 0      | bVSCBSignature (set in configuration bytes) | 0 | 0 | 1 | 0 | 0   | 1 | 0 | 0 |
| 1      | bVSCBSubCommand (must be 0x26)              | 0 | 0 | 1 | 0 | 0   | 1 | 1 | 0 |
| 2      | Reserved (must be set to zero)              | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 |
| 3      | Data Source (must be set to 0x02)           | 0 | 0 | 0 | 0 | 0   | 0 | 1 | 0 |
| 4      | Start Address (LSB) (must be set to zero)   | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 |
| 5      | Start Address (MSB) (must be set to zero)   | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 |
| 6–15   | Reserved (must be set to zero)              | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 |



## 8.4.2 MfgCB

The mfg\_load and mfg\_read vendor-specific commands will be passed down through the bulk pipe in the CBWCB portion of the CBW. The format of this MFGCB is shown below. Byte 0 is a vendor-specific command designator whose value is configurable and set in the configuration data. Byte 1 must be 0x27 to identify MfgCB. Byte 2–15 are reserved and must be set to zero.

The data transfer length will be determined by the CBW Data Transfer Length specified in bytes 8 through 11 (dCBWDataTransferLength) of the CBW. The type/direction of the command is determined by the direction bit specified in byte 12, bit 7 (bmCBWFlags) of the CBW.

Table 8-3. Example MfgCB

| Offset | MfgCB Byte Description                           | Bits |   |   |   |   |   |   |   |  |
|--------|--------------------------------------------------|------|---|---|---|---|---|---|---|--|
|        |                                                  | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0      | 0 bVSCBSignature<br>(set in configuration bytes) | 0    | 0 | 1 | 0 | 0 | 1 | 0 | 0 |  |
| 1      | 1 bVSCBSubCommand<br>(hardcoded 0x27)            | 0    | 0 | 1 | 0 | 0 | 1 | 1 | 1 |  |
| 2–15   | 2–15 Reserved (must be zero)                     | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

#### 8.4.2.1 Mfg load

During a mfg\_load, the CY7C68300B/CY7C68301B goes into Manufacturing Test Mode. Manufacturing Test Mode is provided as a means to implement board or system level interconnect tests. During Manufacturing Test Mode operation, all outputs not directly associated with USB operation are controllable. Normal control of the output pins are disabled. Control of the select AT2LP IO pins and their three-state controls are mapped to the ATAPI data packet associated with this request. (See *Table 8-4* for an explanation of the required Mfg\_load data format.) This requires a write of seven bytes. To exit Manufacturing Test Mode, a hard reset (RESET#) is required.

Table 8-4. Mfg\_load Data Format

| Byte | Bit(s) | Function                                                        |
|------|--------|-----------------------------------------------------------------|
| 0    | 7      | ARESET#                                                         |
|      | 6      | Reserved                                                        |
|      | 5:4    | CS#[1:0]                                                        |
|      | 3:1    | DA[2:0]                                                         |
|      | 0      | Reserved                                                        |
| 1    | 7      | DD[15:0] Three-state (0 = Hi-Z all DD pins, 1 = drive DD pins). |
|      | 3:6    | Reserved                                                        |
|      | 2      | DMACK#                                                          |
|      | 1      | DIOR#                                                           |
|      | 0      | DIOW#                                                           |

Table 8-4. Mfg load Data Format (continued)

| Byte | Bit(s) | Function                 |
|------|--------|--------------------------|
| 2    | 7:0    | DD[7:0]                  |
| 3    | 7:0    | DD[15:8]                 |
| 4    | 7:6    | Reserved                 |
|      | 5:0    | GPIO Output Enable [5:0] |
| 5    | 7:6    | Reserved                 |
|      | 5:0    | GPIO Output Data [5:0]   |
| 6    | 7:0    | Reserved                 |

## 8.4.2.2 Mfg\_read

This USB request returns a "snapshot in time" of select AT2LP input pins. AT2LP input pins not directly associated with USB operation, can be sampled at any time during Manufacturing Test Mode operation. See *Table 8-5* for an explanation of the mfg\_read data format. The data length shall always be eight bytes.

Table 8-5. Mfg read Data Format

| Byte | Bit(s) | Data                                   |
|------|--------|----------------------------------------|
| 0    | 7      | ARESET# (output value only)            |
|      | 6      | VBUS_ATA_ENABLE                        |
|      | 5:1    | Reserved. This data should be ignored. |
|      | 0      | INTRQ                                  |
| 1    | 7      | DD[15:0] Three-state                   |
|      | 6      | Reserved. This data should be ignored. |
|      | 5      | Reserved. This data should be ignored. |
|      | 4      | DMARQ                                  |
| 1    | 3      | IORDY                                  |
|      | 2:0    | Reserved. This data should be ignored. |
| 2    | 7:0    | DD[7:0]                                |
| 3    | 7:0    | DD[15:8]                               |
| 4    | 7:6    | Reserved                               |
|      | 5:0    | GPIO Output Enable [5:0]               |
| 5    | 7:6    | Reserved                               |
|      | 5:0    | GPIO Output Data [5:0]                 |
| 6    | 7:0    | Reserved. This data should be ignored. |
| 7    | 7:0    | Reserved. This data should be ignored. |



## 8.5 EEPROM Organization

The contents of the 256-byte (2048-bit) I<sup>2</sup>C EEPROM are arranged as follows. In *Table 8-6*, the column labeled "Required Contents" contains the values that must be used for proper operation of the AT2LP. The column labeled "Suggested Contents" contains suggested values for the bytes that are defined by the customer. Some values, such as the Vendor ID, Product ID and device serial number, must be customized to meet USB compliance. The "AT2LP blaster" tool on the CY4615B CD can be used to edit and program these values into an AT2LP-based product (refer to *Figure 8-2*). The "AT2LP primer" tool can be used to program AT2LP-based

products in a manufacturing environment. See section 8.4 for details on how to use vendor-specific ATAPI commands to read and program the EEPROM.

The address pins on the serial EEPROM must be set such that the EEPROM is at address 2 (A0=0, A1=1, A2=0) or address 4 (A0=0, A1=0, A2=1) for memories that are internally byte-addressed memories.

**Note:** Devices running in Backward Compatibility Mode should use the 68300A EEPROM organization, and not the 68300B/301B/320/321 format shown in this document.



Figure 8-2. "AT2LP Blaster" Tool Screen



# Table 8-6. EEPROM Organization

| EEPROM<br>Address | Field Name                               | Field Description                                                                                                                                                                                                                                                                                                                                                                                                              | Required Contents | Suggested<br>Contents |
|-------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------|
| AT2LP Co          | nfiguration                              |                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                       |
| 0x00              |                                          | $\mbox{I}^2\mbox{C}$ EEPROM signature byte 0. This byte must be 0x53. For CY7C68300A compatibility mode, these bytes should be set to 0x4D4D.                                                                                                                                                                                                                                                                                  | 0x53              |                       |
| 0x01              | I <sup>2</sup> C EEPROM signature byte 1 | I <sup>2</sup> C EEPROM signature byte 1. This byte must be 0x4B                                                                                                                                                                                                                                                                                                                                                               | 0x4B              |                       |
| 0x02              | APM Value                                | ATA Device Automatic Power Management Value. If an attached ATA device supports APM and this field contains other than 0x00, the AT2LP will issue a SET_FEATURES command to Enable APM with this value during the drive initialization process. Setting APM Value to 0x00 disables this functionality. This value is ignored with ATAPI devices.                                                                               |                   | 0x00                  |
| 0x03              | Unused                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                |                   | 0x80                  |
| 0x04              | bVSCBSignature Value                     | Value in the first byte of the CBW CB field that designates that the CB is to be decoded as vendor specific ATA commands instead of the ATAPI command block. See section 7.0 for more detail on how this byte is used.                                                                                                                                                                                                         |                   | 0x24                  |
| 0x05              | Reserved                                 | Bits (7:6)                                                                                                                                                                                                                                                                                                                                                                                                                     |                   | 0x07                  |
|                   | Enable mode page 8                       | Bit (5) Set to 1 to enable the write caching mode page (page 8). If this page is enabled, Windows will disable write caching by default which will limit write performance.                                                                                                                                                                                                                                                    |                   |                       |
|                   | Disable wait for INTRQ                   | Bit (4) Set to 1 to poll status register rather than waiting for INTRQ. Setting this bit to 1 will improve USB BOT test results but may introduce compatibility problems with some devices.                                                                                                                                                                                                                                    |                   |                       |
|                   | BUSY Bit Delay                           | Bit (3) Enables a delay of up to 120 ms at each read of the DRQ bit where the device data length does not match the host data length. This allows the CY7C68300B/CY7C68301B to work with most devices that incorrectly clear the BUSY bit before a valid status is present.                                                                                                                                                    |                   |                       |
|                   | Short Packet Before Stall                | Bit (2) Determines if a short packet is sent prior to the STALL of an IN endpoint. The USB <i>Mass Storage Class Bulk-Only Specification</i> allows a device to send a short or zero-length IN packet prior to returning a STALL handshake for certain cases. Certain host controller drivers may require a short packet prior to STALL.  1 = Force a short packet before STALL.  0 = Don't force a short packet before STALL. |                   |                       |
|                   | SRST Enable                              | Bit (1) Determines if the AT2LP is to do an SRST reset during drive initialization. At least one reset must be enabled. Do not set SRST to 0 and Skip Pin Reset to 1 at the same time.  1 = Perform SRST during initialization.  0 = Don't perform SRST during initialization.                                                                                                                                                 |                   |                       |
|                   | Skip Pin Reset                           | Bit (0) Skip ARESET# assertion. When this bit is set, the AT2LP will bypass ARESET# during any initialization other than power up. Do not set SRST to 0 and Skip Pin Reset to 1 at the same time.  0 = Allow ARESET# assertion for all resets.  1 = Disable ARESET# assertion except for power-on reset cycles.                                                                                                                |                   |                       |



Table 8-6. EEPROM Organization (continued)

| EEPROM<br>Address | Field Name         | Field Description                                                                                                                                                                                                                                                                                                                                                                                                                              | Required Contents | Suggested<br>Contents |
|-------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------|
| 0x06              | ATA UDMA Enable    | Bit (7) Enable Ultra DMA data transfer support for ATAPI devices. If enabled, and if the ATAPI device reports UDMA support for the indicated modes, the AT2LP will utilize UDMA data transfers at the highest negotiated rate possible.  0 = Disable ATA device UDMA support.  1 = Enable ATA device UDMA support.                                                                                                                             |                   | 0xD4                  |
|                   | ATAPI UDMA Enable  | Bit (6) Enable Ultra DMA data transfer support for ATAPI devices. If enabled, and if the ATAPI device reports UDMA support for the indicated modes, the AT2LP will utilize UDMA data transfers at the highest negotiated rate possible.  0 = Disable ATAPI device UDMA support.  1 = Enable ATAPI device UDMA support.                                                                                                                         |                   |                       |
|                   | UDMA Modes         | Bit (5:0) These bits select which UDMA modes, if supported, are enabled. Setting to 1 enables. Multiple bits may be set. The AT2LP will operate in the highest enabled UDMA mode supported by the device. The AT2LP supports UDMA modes 2, 3, and 4 only. Bit Descriptions 5 Reserved. Must be set to 0. 4 Enable UDMA mode 4. 3 Reserved. Must be set to 0. 2 Enable UDMA mode 2. 1 Reserved. Must be set to 0. 0 Reserved. Must be set to 0. |                   |                       |
| 0x07              | Reserved           | Bits(7:3)                                                                                                                                                                                                                                                                                                                                                                                                                                      |                   | 0x07                  |
|                   | Multiword DMA mode | Must be set to 0. Bit (2) This bit selects multi-word DMA. If this bit is set and the drive supports it, multi-word DMA is used.                                                                                                                                                                                                                                                                                                               |                   |                       |
|                   | PIO Modes          | Bits(1:0) These bits select which PIO modes, if supported, are enabled. Setting to 1 enables. Multiple bits may be set. The AT2LP will operate in the highest enabled PIO mode supported by the device. The AT2LP supports PIO modes 0, 3, and 4 only. PIO mode 0 is always enabled by internal logic.  Bit Descriptions 1 Enable PIO mode 4. 0 Enable PIO mode 3.                                                                             |                   |                       |
| 0x08              | Pin Configurations |                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   | 0x78                  |
|                   | BUTTON_MODE        | Bit (7) Button mode. Set this bit to 1 to enable ATAPUEN, PWR500# and DRVPWRVLD to become button inputs returned on bits 2, 1, and 0 of EP1IN                                                                                                                                                                                                                                                                                                  |                   |                       |
|                   | SEARCH_ATA_BUS     | Bit (6) Enables a search performed at RESET to detect non- removable ATA and ATAPI devices. Systems with only a removable device (like CF readers) will set this bit to 0. Systems with one removable device and one non- removable device will set this bit to 1.                                                                                                                                                                             |                   |                       |
|                   | BIG_PACKAGE        | Bit (5) Package Select. Set this bit to 1 when using the 100-pin device.                                                                                                                                                                                                                                                                                                                                                                       |                   |                       |



Table 8-6. EEPROM Organization (continued)

| EEPROM<br>Address | Field Name                                    | Field Description                                                                                                                                                                                                                                                                                                                                               | Required Contents | Suggested<br>Contents |
|-------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------|
|                   | ATA_EN                                        | Bit (4) ATA sharing enable. Allows ATA bus sharing with other host devices. If ATA_EN=1 the ATA interface will be driven when VBUS_ATA_ENABLE is LOW. If ATA_EN=0 the ATA interface will be placed into Hi-Z state whenever VBUS_ATA_ENABLE is LOW.  '0' = ATA signals Hi-Z when VBUS_ATA_ENABLE is LOW.  '1' = ATA signals driven when VBUS_ATA_ENABLE is LOW. |                   |                       |
|                   | DISKRDY Polarity                              | Bit (3) DISKRDY active polarity. '0' = Active LOW polarity. '1' = Active HIGH polarity.                                                                                                                                                                                                                                                                         |                   |                       |
|                   | HS Indicator Enable                           | Bit (2) Enables GPIO2_nHS pin to indicate the current operating speed of the device (if output is enabled). '0' = Normal GPIO operation. '1' = High-speed indicator enable.                                                                                                                                                                                     |                   |                       |
|                   | Drive Power Valid Polarity                    | Bit (1) Controls the polarity of DRVPWRVLD pin '0' = Active LOW ("connector ground" indication) '1' = Active HIGH (power indication from device)                                                                                                                                                                                                                |                   |                       |
|                   | Drive Power Valid Enable                      | Bit (0) Enable for the DRVPWRVLD pin. When this pin is enabled, the AT2LP will enumerate a removable IDE device (normally CompactFlash) as the master device.  '0' = pin disabled (most systems)  '1' = pin enabled (CompactFlash systems)                                                                                                                      |                   |                       |
| 0x09              | Reserved General Purpose IO Pin Output Enable | Bits (7:6) Must be set to zero. Bits (5:0) GPIO[5:0] Hi-Z control. '0' = Output enabled (GPIO pin is an output). '1' = Hi-Z (GPIO pin is an input).                                                                                                                                                                                                             |                   | 0x00                  |
| 0x0A              | Reserved General Purpose IO Pin Data          | Bits (7:6) Must be set to zero. Bits (5:0) If the output enable bit is set, these bits select the value driven on the GPIO pins.                                                                                                                                                                                                                                |                   | 0x00                  |
| 0x0B              | Identify Device String Pointer LUN0           | If this value is 00, the Identify Device data will be taken from the device. If this string is non-zero, it is used as a pointer to                                                                                                                                                                                                                             |                   | 0x00                  |
| 0x0C              | Identify Device String Pointer<br>LUN1        | a 24 byte ASCII (non-Unicode) string in the EEPROM. This string will be used as the device identifier. This string is used by many operating systems as the user-visible name for the device.                                                                                                                                                                   |                   | 0x00                  |
| 0x0D              | Delay after reset                             | Number of 20-ms ticks to wait between RESET and attempting to access the drive.                                                                                                                                                                                                                                                                                 |                   | 0x00                  |
| 0x0E              | Reserved<br>Enable CF UDMA                    | Bits (7:4) Bit (3) '1' = Allow UDMA to be used with removable-media devices '0' = UDMA will not be used with removable-media devices Some CF devices will interfere with UDMA if the UDMA lines are connected to them. This bit tells the AT2LP if the UDMA lines are connected to the removable-media device.                                                  |                   | 0x00                  |
|                   | Fixed number of logical units = 2             | Bit (2) If bits 1 and 2 are both 0, the number of logical units will be determined by searching the ATA and CF buses for devices.                                                                                                                                                                                                                               |                   |                       |



 Table 8-6. EEPROM Organization (continued)

| EEPROM<br>Address | Field Name                        | Field Description                                                                                                                                                                                                                                                                                  | Required Contents | Suggested<br>Contents |
|-------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------|
|                   | Fixed number of logical units = 1 | Bit (1) If bits 1 and 2 are both 0, the number of logical units will be determined by searching the ATA and CF buses for devices.                                                                                                                                                                  |                   |                       |
|                   | Search ATA on VBUS removed        | Bit (0)<br>Search for ATA devices when VBUS returns. If this bit is set,<br>the ATA bus will be searched for ATA devices every time<br>AT2LP is plugged into a computer.                                                                                                                           |                   |                       |
| 0x0F              | Reserved                          | Must be set to 0x00.                                                                                                                                                                                                                                                                               | 0x00              |                       |
| Device De         | scriptor                          |                                                                                                                                                                                                                                                                                                    |                   |                       |
| 0x10              | bLength                           | Length of device descriptor in bytes.                                                                                                                                                                                                                                                              | 0x12              |                       |
| 0x11              | bDescriptor Type                  | Descriptor type.                                                                                                                                                                                                                                                                                   | 0x01              |                       |
| 0x12              | bcdUSB (LSB)                      | USB Specification release number in BCD.                                                                                                                                                                                                                                                           | 0x00              |                       |
| 0x13              | bcdUSB (MSB)                      |                                                                                                                                                                                                                                                                                                    | 0x02              |                       |
| 0x14              | bDeviceClass                      | Device class.                                                                                                                                                                                                                                                                                      | 0x00              |                       |
| 0x15              | bDeviceSubClass                   | Device subclass.                                                                                                                                                                                                                                                                                   | 0x00              |                       |
| 0x16              | bDeviceProtocol                   | Device protocol.                                                                                                                                                                                                                                                                                   | 0x00              |                       |
| 0x17              | bMaxPacketSize0                   | USB packet size supported for default pipe.                                                                                                                                                                                                                                                        | 0x40              |                       |
| 0x18              | idVendor (LSB)                    | Vendor ID. Cypress's Vendor ID may only be used for evalu-                                                                                                                                                                                                                                         |                   | Your                  |
| 0x19              | idVendor (MSB)                    | ation purposes, and not in released products.                                                                                                                                                                                                                                                      |                   | Vendor ID             |
| 0x1A              | idProduct (LSB)                   | Product ID.                                                                                                                                                                                                                                                                                        |                   | Your                  |
| 0x1B              | idProduct (MSB)                   |                                                                                                                                                                                                                                                                                                    |                   | Product ID            |
| 0x1C              | bcdDevice (LSB)                   | Device release number in BCD LSB (product release number).                                                                                                                                                                                                                                         |                   | Your release          |
| 0x1D              | bcdDevice (MSB)                   | Device release number in BCD MSB (silicon release number).                                                                                                                                                                                                                                         |                   | number                |
| 0x1E              | iManufacturer                     | Index to manufacturer string. This entry must equal half of the address value where the string starts or 0x00 if the string does not exist.                                                                                                                                                        |                   | 0x53                  |
| 0x1F              | iProduct                          | Index to product string. This entry must equal half of the address value where the string starts or 0x00 if the string does not exist.                                                                                                                                                             |                   | 0x69                  |
| 0x20              | iSerialNumber                     | Index to serial number string. This entry must equal half of the address value where the string starts or 0x00 if the string does not exist. The USB Mass Storage Class Bulk-Only Transport Specification requires a unique serial number (in upper case, hexadecimal characters) for each device. |                   | 0x75                  |
| 0x21              | bNumConfigurations                | Number of configurations supported. 1 for mass storage: 2 for HID: 3 for CSM                                                                                                                                                                                                                       |                   | 0x03                  |
| Device Qu         | alifier                           |                                                                                                                                                                                                                                                                                                    |                   |                       |
| 0x22              | bLength                           | Length of device descriptor in bytes.                                                                                                                                                                                                                                                              | 0x0A              |                       |
| 0x23              | bDescriptor                       | Type Descriptor type.                                                                                                                                                                                                                                                                              | 0x06              |                       |
| 0x24              | bcdUSB (LSB)                      | USB Specification release number in BCD.                                                                                                                                                                                                                                                           | 0x00              |                       |
| 0x25              | bcdUSB (MSB)                      | USB Specification release number in BCD.                                                                                                                                                                                                                                                           | 0x02              |                       |
| 0x26              | bDeviceClass                      | Device class.                                                                                                                                                                                                                                                                                      | 0x00              |                       |
| 0x27              | bDeviceSubClass                   | Device subclass.                                                                                                                                                                                                                                                                                   | 0x00              |                       |
| 0x28              | bDeviceProtocol                   | Device protocol.                                                                                                                                                                                                                                                                                   | 0x00              |                       |
| 0x29              | bMaxPacketSize0                   | USB packet size supported for default pipe.                                                                                                                                                                                                                                                        | 0x40              |                       |
| 0x2A              | bNumConfigurations                | Number of configurations supported.                                                                                                                                                                                                                                                                | 0x01              |                       |



Table 8-6. EEPROM Organization (continued)

| EEPROM<br>Address | Field Name               | Field Description                                                                                                                                                                                                                                                                                                                                                                                                                           | Required Contents | Suggested<br>Contents |
|-------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------|
| 0x2B              | bReserved                | Reserved for future use. Must be set to zero.                                                                                                                                                                                                                                                                                                                                                                                               | 0x00              |                       |
| Configura         | tion Descriptor          |                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   | •                     |
| 0x2C              | bLength                  | Length of configuration descriptor in bytes.                                                                                                                                                                                                                                                                                                                                                                                                | 0x09              |                       |
| 0x2D              | bDescriptorType          | Descriptor type.                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x02              |                       |
| 0x2E              | bTotalLength (LSB)       | Number of bytes returned in this configuration. This includes                                                                                                                                                                                                                                                                                                                                                                               | 0x20              |                       |
| 0x2F              | bTotalLength (MSB)       | the configuration descriptor plus all the interface and endpoint descriptors.                                                                                                                                                                                                                                                                                                                                                               | 0x00              |                       |
| 0x30              | bNumInterfaces           | Number of interfaces supported.                                                                                                                                                                                                                                                                                                                                                                                                             |                   | 0x01                  |
| 0x31              | bConfiguration Value     | The value to use as an argument to Set Configuration to select the configuration. This value must be set to 0x01.                                                                                                                                                                                                                                                                                                                           | 0x01              |                       |
| 0x32              | iConfiguration           | Index to the configuration string. This entry must equal half of the address value where the string starts, or 0x00 if the string does not exist.                                                                                                                                                                                                                                                                                           |                   | 0x00                  |
| 0x33              | bmAttributes             | Device attributes for this configuration. Bit (7) Reserved. Must be set to 1. Bit (6) Self-powered. Must be set to 1. Bit (5) Remote wake-up. Must be set to 0. Bits (4–0) Reserved. Must be set to 0.                                                                                                                                                                                                                                      | 0xC0              |                       |
| 0x34              | bMaxPower                | Maximum power consumption for this configuration. Units used are mA*2 (i.e., 0x31 = 98 mA, 0xF9 = 498 mA). 0x00 reported for self-powered devices.  Note: A value of 0x00 or 0x01 results in the 56-pin package configuring itself for self-powered mode, whereas a value greater than 0x01 results in the 56-pin package reporting itself as bus-powered. This is regardless of what address 0x33 is set to reflect in the 56-pin package. |                   | 0x01                  |
| Interface a       | and Endpoint Descriptors |                                                                                                                                                                                                                                                                                                                                                                                                                                             | I.                | Į.                    |
| Interface D       | Pescriptor               |                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   |                       |
| 0x35              | bLength                  | Length of interface descriptor in bytes.                                                                                                                                                                                                                                                                                                                                                                                                    | 0x09              |                       |
| 0x36              | bDescriptorType          | Descriptor type.                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x04              |                       |
| 0x37              | bInterfaceNumber         | Interface number.                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x00              |                       |
| 0x38              | bAlternateSetting        | Alternate setting.                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x00              |                       |
| 0x39              | bNumEndpoints            | Number of endpoints.                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x02              |                       |
| 0x3A              | bInterfaceClass          | Interface class.                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x08              |                       |
| 0x3B              | bInterfaceSubClass       | Interface subclass.                                                                                                                                                                                                                                                                                                                                                                                                                         |                   | 0x06                  |
| 0x3C              | bInterfaceProtocol       | Interface protocol.                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x50              |                       |
| 0x3D              | iInterface               | Index to first interface string. This entry must equal half of the address value where the string starts or 0x00 if the string does not exist.                                                                                                                                                                                                                                                                                              |                   | 0x00                  |
| USB Bulk          | Out Endpoint             |                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   |                       |
| 0x3E              | bLength                  | Length of this descriptor in bytes.                                                                                                                                                                                                                                                                                                                                                                                                         | 0x07              |                       |
| 0x3F              | bDescriptorType          | Endpoint descriptor type.                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x05              |                       |
| 0x40              | bEndpointAddress         | This is an Out endpoint, endpoint number 2.                                                                                                                                                                                                                                                                                                                                                                                                 | 0x02              |                       |
| 0x41              | bmAttributes             | This is a bulk endpoint.                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x02              |                       |
| 0x42              | wMaxPacketSize (LSB)     | Max data transfer size. To be set by speed (Full speed                                                                                                                                                                                                                                                                                                                                                                                      |                   | 0x00                  |
| 0x43              | wMaxPacketSize (MSB)     | 0x0040; High speed 0x0200)                                                                                                                                                                                                                                                                                                                                                                                                                  |                   | 0x02                  |
| 0x44              | bInterval                | High-speed interval for polling (maximum NAK rate). Set to zero for full speed.                                                                                                                                                                                                                                                                                                                                                             | 0x00              |                       |



 Table 8-6. EEPROM Organization (continued)

| EEPROM<br>Address | Field Name               | Field Description                                                               | Required Contents | Suggested<br>Contents |
|-------------------|--------------------------|---------------------------------------------------------------------------------|-------------------|-----------------------|
| USB Bulk I        | n Endpoint               |                                                                                 |                   | •                     |
| 0x45              | bLength                  | Length of this descriptor in bytes.                                             | 0x07              |                       |
| 0x46              | bDescriptorType          | Endpoint descriptor type.                                                       | 0x05              |                       |
| 0x47              | bEndpointAddress         | This is an In endpoint, endpoint number 8.                                      | 0x88              |                       |
| 0x48              | bmAttributes             | This is a bulk endpoint.                                                        | 0x02              |                       |
| 0x49              | wMaxPacketSize (LSB)     | Max data transfer size. Automatically set by AT2 (Full speed                    |                   | 0x00                  |
| 0x4A              | wMaxPacketSize (MSB)     | 0x0040; High speed 0x0200)                                                      |                   | 0x02                  |
| 0x4B              | bInterval                | High-speed interval for polling (maximum NAK rate). Set to zero for full speed. | 0x00              |                       |
| (Optional)        | HID Interface Descriptor |                                                                                 |                   |                       |
| 0x4C              | bLength                  | Length of HID interface descriptor                                              | 0x09              |                       |
| 0x4D              | bDescriptorTypes         | Interface descriptor type                                                       | 0x04              |                       |
| 0x4E              | bInterfaceNumber         | Number of interfaces (2)                                                        | 0x02              |                       |
| 0x4F              | bAlternateSetting        | Alternate setting                                                               | 0x00              |                       |
| 0x50              | bNumEndpoints            | Number of endpoints used by this interface                                      | 0x01              |                       |
| 0x51              | bInterfaceClass          | Class code                                                                      | 0x03              |                       |
| 0x52              | bInterfaceSubClass       | Sub class                                                                       | 0x00              |                       |
| 0x53              | bInterfaceSubSubClass    | sub sub class                                                                   | 0x00              |                       |
| 0x54              | iInterface               | Index of string descriptor                                                      | 0x00              |                       |
| USB Interr        | upt In Endpoint          |                                                                                 | I                 | l                     |
| 0x5E              | bLength                  | Length of this descriptor in bytes.                                             | 0x07              |                       |
| 0x5F              | bDescriptorType          | Endpoint descriptor type.                                                       | 0x05              |                       |
| 0x60              | bEndpointAddress         | This is an In endpoint, endpoint number 1.                                      | 0x81              |                       |
| 0x61              | bmAttributes             | This is an interrupt endpoint.                                                  | 0x03              |                       |
| 0x62              | wMaxPacketSize (LSB)     | Max data transfer size.                                                         | 0x02              |                       |
| 0x63              | wMaxPacketSize (MSB)     |                                                                                 | 0x00              |                       |
| 0x64              | bInterval                | Interval for polling (max. NAK rate).                                           |                   | 0x10                  |
| (Optional)        | HID Descriptor           |                                                                                 | I.                | l                     |
| 0x55              | bLength                  | Length of HID descriptor                                                        | 0x09              |                       |
| 0x56              | bDescriptorType          | Descriptor Type HID                                                             | 0x21              |                       |
| 0x57              | bcdHID (LSB)             | HID Class Specification release number (1.10)                                   | 0x10              |                       |
| 0x58              | bcdHID (MSB)             |                                                                                 | 0x01              |                       |
| 0x59              | bCountryCode             | Country Code                                                                    | 0x00              |                       |
| 0x5A              | bNumDescriptors          | Number of class descriptors (1 report descriptor)                               | 0x01              |                       |
| 0x5B              | bDescriptorType          | Descriptor Type                                                                 | 0x22              |                       |
| 0x5C              | wDescriptorLength (LSB)  | Length of HID report descriptor                                                 | 0x22              |                       |
| 0x5D              | wDescriptorLength (MSB)  |                                                                                 | 0x00              |                       |
| Terminato         | r Descriptors            |                                                                                 | 1                 | l                     |
| 0x65              | Terminator               |                                                                                 | 0x00              |                       |
| (Optional)        | HID Report Descriptor    | 1                                                                               | 1                 | 1                     |
| 0x66              | Usage_Page               | Vendor defined - FFA0                                                           | 0x06              |                       |
| 0x67              |                          |                                                                                 | 0xA0              |                       |
| 0x68              |                          | 1                                                                               | 0xFF              |                       |



 Table 8-6. EEPROM Organization (continued)

| EEPROM<br>Address | Field Name               | Field Description                                                                     | Required Contents | Suggested<br>Contents |
|-------------------|--------------------------|---------------------------------------------------------------------------------------|-------------------|-----------------------|
| 0x69              | Usage                    | Vendor defined                                                                        | 0x09              |                       |
| 0x6A              |                          |                                                                                       | 0xA5              |                       |
| 0x6B              | Collection               | Application                                                                           | 0xA1              |                       |
| 0x6C              |                          |                                                                                       | 0x01              |                       |
| 0x6D              | Usage                    | Vendor defined                                                                        | 0x09              |                       |
| 0x6E              |                          |                                                                                       | 0xA6              |                       |
| Input Rep         | ort                      |                                                                                       | •                 | I.                    |
| 0x6F              | Usage                    | Vendor defined                                                                        | 0x09              |                       |
| 0x70              |                          |                                                                                       | 0xA7              |                       |
| 0x71              | Logical_Minimum          | -128                                                                                  | 0x15              |                       |
| 0x72              |                          |                                                                                       | 0x80              |                       |
| 0x73              | Logical_Maximum          | 127                                                                                   | 0x25              |                       |
| 0x74              |                          |                                                                                       | 0x7F              |                       |
| 0x75              | Report_Size              | 8 bits                                                                                | 0x75              |                       |
| 0x76              |                          |                                                                                       | 0x08              |                       |
| 0x77              | Report_Count             | 2 fields                                                                              | 0x95              |                       |
| 0x78              |                          |                                                                                       | 0x02              |                       |
| 0x79              | Input                    | Input (Data, Variable, Absolute)                                                      | 0x81              |                       |
| 0x7A              |                          |                                                                                       | 0x02              |                       |
| Output Re         | port                     |                                                                                       | 1                 |                       |
| 0x7B              | Usage                    | Usage - vendor defined                                                                | 0x09              |                       |
| 0x7C              | -                        |                                                                                       | 0xA9              |                       |
| 0x7D              | Logical_Minimum          | Logical Minimum (-128)                                                                | 0x15              |                       |
| 0x7E              |                          |                                                                                       | 0x80              |                       |
| 0x7F              | Logical_Maximum          | Logical Maximum (127)                                                                 | 0x25              |                       |
| 0x80              |                          |                                                                                       | 0x7F              |                       |
| 0x81              | Report_Size              | Report Size 8 bits                                                                    | 0x75              |                       |
| 0x82              |                          |                                                                                       | 0x08              |                       |
| 0x83              | Report_Count             | Report Count 2 fields                                                                 | 0x95              |                       |
| 0x84              |                          |                                                                                       | 0x02              |                       |
| 0x85              | Output                   | Output (Data, Variable, Absolute                                                      | 0x91              |                       |
| 0x86              |                          |                                                                                       | 0x02              |                       |
| 0x87              |                          | End Collection                                                                        | 0xC0              |                       |
| (optional)        | Standard Content Securit | y Interface Descriptor                                                                |                   | l .                   |
| 0x88              | bLength                  | Byte length of this descriptor                                                        | 0x09              |                       |
| 0x89              | bDescriptorType          | Interface Descriptor type                                                             | 0x0D              |                       |
| 0x8A              | bInterfaceNumber         | Number of interface.                                                                  | 0x02              |                       |
| 0x8B              | bAlternateSetting        | Value used to select an alternate setting for the interface identified in prior field |                   |                       |
| 0x8C              | bNumEndpoints            | Number of endpoints used by this interface (excluding                                 | 0x02              |                       |
| 0x8D              | bInterfaceClass          | endpoint 0) that are CSM dependent                                                    |                   | 0x0D                  |
| 0x8E              | bInterfaceSubClass       | Must be set to zero                                                                   | 0x00              |                       |
| 0x8F              | bInterfaceProtocol       | Must be set to zero                                                                   | 0x00              |                       |
| 0x90              | iInterface               | Index of a string descriptor that describes this Interface                            |                   |                       |