

# UHC124 USB Host Controller Data Sheet

TransDimension Inc. 2 Venture Irvine, CA 92618 www.transdimension.com

Phone: (949) 727-2020 Fax: (949) 727-3232 <u>sales@transdimension.com</u> <u>techsupport@transdimension.com</u>

TransDimension Document Number: MU1002

Rev. 1.05, February, 2002

# **Revision History**

| Version Number | <b>Release Date</b> | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0.5            | Aug., 1999          | First release                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 0.75           | Nov., 1999          | <ul> <li>Changed UhcControl register</li> <li>Re-organized Interrupt Modes</li> <li>Moved batch interrupt control/status to<br/>UhcInterruptEnable/UhcInterruptStatus</li> <li>Removed XDInterruptEnable field</li> <li>Pinout provided</li> <li>Added section on oscillator and PLL</li> <li>Added section on the root hub</li> <li>Added USB host state transition section</li> </ul>                                                          |  |  |
| 0.80           | Dec., 1999          | Revised XDControl and XDStatus                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 0.90           | Jun., 2000          | Revised all sections                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 0.92           | Jul., 2000          | Added sections on interface and software                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 0.93           | Aug., 2000          | <ul> <li>Added chip pin assignment table and diagram</li> <li>Modified Sections 9 &amp; 10 examples</li> <li>Modified electrical specifications for logic signals</li> </ul>                                                                                                                                                                                                                                                                     |  |  |
| 0.95           | Sept., 2000         | <ul> <li>Changed pin assignments for DP<sub>n</sub>, DM<sub>n</sub> (n = 1, 2, 3, and 4)</li> <li>Swapped Bits 7 &amp; 5 of XDControl</li> </ul>                                                                                                                                                                                                                                                                                                 |  |  |
| 0.97           | Feb., 2001          | • Made modifications for typos, etc.                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 0.98           | Apr., 2001          | <ul> <li>Modified legal statements</li> <li>Removed "Advanced Information"</li> <li>Removed "Confidential"</li> <li>Modified chip marking to match product</li> <li>Added a section on double buffering</li> <li>Corrected V<sub>OH</sub> and V<sub>OL</sub> specifications</li> <li>Corrected bus cycle specifications</li> <li>Added recommended landing pattern</li> <li>Added soldering profile</li> <li>Added storage conditions</li> </ul> |  |  |
| 1.00           | May, 2001           | <ul> <li>Corrected several typos</li> <li>Modified text on integrating the UHC124 to generic USB host software</li> <li>Added/corrected electronic and timing specifications</li> <li>Corrected Maximum Absolute Ratings</li> <li>Added procedures of entering power save state</li> </ul>                                                                                                                                                       |  |  |
| 1.01           | May, 2001           | • Change "TDI Part Number:" on the cover page to<br>"TDI Document Number:"                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 1.02           | August, 2001        | Format change, added Sales Offices.                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| 1.03           | Sept. 2001          | Format change.                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 1.04           | October 2001        | Colorized the block diagram and updated feature list                                                                                                                                                                                                                                                                                                                                                                                             |  |  |

| 1.04A                                                      | December<br>2001 | • Updated sales contact list on last page.                  |  |  |
|------------------------------------------------------------|------------------|-------------------------------------------------------------|--|--|
| 1.05                                                       | February<br>2002 | • Refered readers to our website for all sales rep. offices |  |  |
| Note: This data sheet is subject to change without notice. |                  |                                                             |  |  |

"AS THE DEVICE AND ITS DOCUMENTATION ARE PROVIDED IS" TRANSDIMENSION HEREBY DISCLAIMS ALL WARRANTIES, EXPRESS, STATUTORY AND IMPLIED, APPLICABLE TO THE SOFTWARE AND ITS DOCUMENTATION AND ANY RELATED PRODUCTS, INCLUDING, BUT NOT LIMITED TO, ANY WARRANTY OF MERCHANTABILITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE. TRANSDIMENSION ASSUMES NO LIABILITY FOR ANY ACT OR OMISSION OF LICENSEE. IN NO EVENT SHALL TRANSDIMENSION BE LIABLE FOR DIRECT, SPECIAL, INDIRECT, INCIDENTAL, PUNITIVE, EXEMPLARY OR CONSEQUENTIAL DAMAGES, INCLUDING, WITHOUT LIMITATION, LOSS OF PROFITS OR REVENUE, LOSS OF PRODUCTS, DATA OR ANY ASSOCIATED EQUIPMENT, COST OF CAPITAL, COST OF SUBSTITUTED EQUIPMENT OR PARTS, FACILITIES OR SERVICES, DOWN-TIME OR LABOR COSTS, EVEN IF TRANSDIMENSION HAS BEEN ADVISED OF THE POSSIBILITY THEREOF. The device and any related products are not designed, authorized, or warranted to be suitable for use in lifesupport devices or systems or other critical applications. Any such use and subsequent liabilities that may arise from such use are totally the responsibilities of the Licensee.

© 2002, TransDimension Inc., All rights reserved.

All product names are trademarks or registered trademarks of their respective owners.

# Contents

| 1. | Features and Block Diagram 1                                                                |                                                                                                                                                                                                                                                                                                      |                                                                |  |
|----|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|
|    | 1.1<br>1.2<br>1.3<br>1.4                                                                    | Features of UHC124<br>Block Diagram<br>Pin Assignments<br>Abbreviations                                                                                                                                                                                                                              | 2<br>3                                                         |  |
| 2. | System                                                                                      | n Overview                                                                                                                                                                                                                                                                                           | 6                                                              |  |
|    | 2.1<br>2.2<br>2.3<br>2.4<br>2.5<br>2.6<br>2.7<br>2.8<br>2.9<br>2.10<br>2.11<br>2.12<br>2.13 | Interface with MCUs<br>Control Memory and Transaction Descriptors<br>Batch Processing<br>Data Memory<br>Double Buffering<br>Interrupt to MCU<br>Root Hub<br>External Crystal/Oscillator.<br>About UHCI and OHCI<br>USB Host API<br>RTOS Support<br>System Suspend and Resume<br>Power Saving State   | 6<br>7<br>9<br>9<br>10<br>10<br>10<br>10<br>11<br>12<br>12     |  |
| 3. | Signal                                                                                      | Definitions                                                                                                                                                                                                                                                                                          | 13                                                             |  |
|    | 3.1<br>3.2<br>3.3<br>3.4<br>3.5                                                             | Oscillator and PLL<br>MCU Interface<br>USB Root Hub Ports<br>Test Modes<br>Power and Ground                                                                                                                                                                                                          | 13<br>14<br>14                                                 |  |
| 4. | Memo                                                                                        | ry Map                                                                                                                                                                                                                                                                                               | 15                                                             |  |
| 5. | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br>5.10<br>5.11                 | Overview<br>UhcControl Register<br>UhcTransSelect Register<br>UhcTransDone Register<br>UhcIntpStatus Register<br>UhcIntpEnable Register<br>UhcIntpEnable Register<br>UhcFmInterval Register<br>UhcFmRemaining Register<br>UhcFmNumber Register<br>UhcMaxOverhead Register<br>UhcMagicNumber Register | 16<br>16<br>20<br>21<br>21<br>23<br>24<br>25<br>25<br>26<br>26 |  |
| 6. | Transaction Descriptor                                                                      |                                                                                                                                                                                                                                                                                                      |                                                                |  |

|     | 6.1          | Overview                                       | 28 |
|-----|--------------|------------------------------------------------|----|
|     | 6.2          | XDControl                                      | 29 |
|     | 6.3          | XDStatus                                       | 30 |
|     | 6.4          | XDDevAddress                                   | 31 |
|     | 6.5          | XDEndpoint                                     |    |
|     | 6.6          | XDBufAddress                                   |    |
|     | 6.7          | XDBufLength                                    |    |
|     | 6.8          | XDXferCount                                    | 33 |
| 7.  | Root         | Hub                                            | 34 |
|     | 7.1          | Down Stream Ports                              | 34 |
|     | 7.2          | Port Power Management                          |    |
|     | 7.3          | Root Hub as a USB Device                       |    |
|     | 7.4          | Hub Characteristics                            | 37 |
|     | 7.5          | Port Manipulation                              | 38 |
|     | 7.6          | Port Status Change Endpoint (EP1)              | 38 |
| 8.  | Host (       | Controller Functional States                   | 40 |
|     | 8.1          | UHC124 States and State Transitions            | 40 |
|     | 8.2          | UsbOperational                                 |    |
|     | 8.3          | UsbReset                                       |    |
|     | 8.4          | UsbSuspend                                     |    |
|     | 8.5          | UsbResume                                      |    |
|     | 8.6          | PowerSave                                      |    |
| 9.  |              | vare Setup and Interface to MCU                |    |
|     | 9.1          | Power Supply                                   | 13 |
|     | 9.2          | PowerOnReset and MasterReset.                  |    |
|     | 9.3          | Crystal Oscillator                             |    |
|     | 9.4          | Root Hub Ports                                 |    |
|     | 9.5          | Memory Access                                  |    |
|     | 9.6          | Test Modes                                     |    |
| 10. |              | are Issues                                     |    |
| 101 | 10.1         | Resets                                         |    |
|     | 10.1         | Transaction Specification                      |    |
|     | 10.2         | Batch Dispatching                              |    |
|     | 10.5         | Transaction/Batch Scheduling                   |    |
|     | 10.4         | Transaction Status Interpretation and Handling |    |
|     | 10.5         | USB Requests (Control Transfers)               |    |
|     | 10.0         | UHC124 Operation                               |    |
|     | 10.7         | Software Support                               |    |
| 11. |              | cycle Timing                                   |    |
|     |              |                                                |    |
|     | 11.1<br>11.2 | Memory Write Cycle                             |    |
| 10  |              |                                                |    |
| 12. | Electi       | ical Ratings                                   | 03 |

|     | 12.1  | Absolute Maximum Ratings                | 65 |  |  |  |  |  |
|-----|-------|-----------------------------------------|----|--|--|--|--|--|
|     | 12.2  | Recommended/Normal Operating Conditions |    |  |  |  |  |  |
|     | 12.3  |                                         |    |  |  |  |  |  |
|     | 12.4  | A.C. Characteristics                    | 66 |  |  |  |  |  |
| 13. | Packa | ging, Soldering and Storage             | 67 |  |  |  |  |  |
|     | 13.1  | Package Diagram                         |    |  |  |  |  |  |
|     | 13.2  | Packaging Dimensions                    | 68 |  |  |  |  |  |
|     | 13.3  | Landing Pattern                         | 69 |  |  |  |  |  |
|     | 13.4  | Soldering Profile                       | 70 |  |  |  |  |  |
|     | 13.5  | Storage Conditions                      |    |  |  |  |  |  |
| 14. | Sales | Offices:                                | 71 |  |  |  |  |  |

# 1. Features and Block Diagram

#### 1.1 Features of UHC124

- USB host controller for embedded applications (set-top box, PDA, cell phone, digital camera, Bluetooth USB HCI physical bus, etc.)
- USB Specification 2.0 (low and full speed) fully compliant
- Patent pending design
- Standard 8-bit microprocessor bus interface
- Supports batch processing of up to 16 USB transactions without interrupting the MCU
- Supports both full speed (12 Mbps) and low speed (1.5 Mbps) USB transfers
- Supports all four types of USB transfers (control, bulk, interrupt, and isochronous with maximum packet size of 1023 bytes)
- Supports double and circular buffering for all four types of Host controller transactions
- Direct device-to-device data transfer in one Frame
- Separate transaction descriptor and data memory space
- Hardware generated Start of Frame (SOF)
- 2 KB data memory
- Support in-place processing in the data memory used for applications requiring peer-topeer data transfer between USB devices
- Supports transaction spill over
- Power management with host suspend, remote wakeup, and power saving modes
- Fully qualified, market proven root hub with four downstream ports and integrated analog transceivers
- Supports OHCI/UHCI compliant USB host stack
- USB device driver software available including printer, speaker, mass storage device, hub, modem, ethernet, mouse, keyboard, digital camera, video camera, cell phone, STB, PDA, etc.
- Embedded RTOS software available for popular microprocessors, RISCs, CISCs, and DSPs using WinCE, Linux, VxWorks, Nucleus, Lynx, QNX, pSOS, PowerTV, SMX, ThreadX, VRTX, ITRON, MS-DOS operating systems
- 6 MHz crystal/oscillator to reduce cost and EMI
- Single 3.3V power supply
- Shipping industrial grade operating temperature range devices
- Military and Automotive grade available upon request
- 64 pin LQFP package

## 1.2 Block Diagram



# 1.3 Pin Assignments

| 1  | V <sub>DD</sub> | 17 | OSC <sub>1</sub>  | 33 | V <sub>DD</sub>   | 49 | V <sub>SS</sub>  |
|----|-----------------|----|-------------------|----|-------------------|----|------------------|
| 2  | $A_0$           | 18 | $OSC_2$           | 34 | $DP_1$            | 50 | D <sub>4</sub>   |
| 3  | $A_1$           | 19 | LPF               | 35 | $DM_1$            | 51 | D <sub>5</sub>   |
| 4  | A <sub>2</sub>  | 20 | V <sub>DD</sub>   | 36 | V <sub>SS</sub>   | 52 | D <sub>6</sub>   |
| 5  | A <sub>3</sub>  | 21 | TEST <sub>0</sub> | 37 | $DP_2$            | 53 | D <sub>7</sub>   |
| 6  | A <sub>4</sub>  | 22 | TEST <sub>1</sub> | 38 | DM <sub>2</sub>   | 54 | /RESET           |
| 7  | A <sub>5</sub>  | 23 | TEST <sub>2</sub> | 39 | DP <sub>3</sub>   | 55 | /WR              |
| 8  | A <sub>6</sub>  | 24 | TEST <sub>3</sub> | 40 | DM <sub>3</sub>   | 56 | /RD              |
| 9  | A <sub>7</sub>  | 25 | $/OC_1$           | 41 | DP <sub>4</sub>   | 57 | TMS <sub>0</sub> |
| 10 | A <sub>8</sub>  | 26 | /OC <sub>2</sub>  | 42 | DM <sub>4</sub>   | 58 | TMS <sub>1</sub> |
| 11 | A <sub>9</sub>  | 27 | /OC <sub>3</sub>  | 43 | TEST <sub>4</sub> | 59 | TMS <sub>2</sub> |
| 12 | A <sub>10</sub> | 28 | /OC <sub>4</sub>  | 44 | D <sub>0</sub>    | 60 | TMS <sub>3</sub> |
| 13 | A <sub>11</sub> | 29 | /PO <sub>1</sub>  | 45 | D <sub>1</sub>    | 61 | /INT             |
| 14 | MODE            | 30 | /PO <sub>2</sub>  | 46 | D <sub>2</sub>    | 62 | ADS              |
| 15 | /CS             | 31 | /PO <sub>3</sub>  | 47 | D <sub>3</sub>    | 63 | GNDP             |
| 16 | V <sub>SS</sub> | 32 | /PO <sub>4</sub>  | 48 | V <sub>DD</sub>   | 64 | V <sub>SS</sub>  |



Fig. 2 UHC124 LQFP 64-pin package (top view)

# 1.4 Abbreviations

The following are some abbreviations used in this document.

| Application Programming Interface   |
|-------------------------------------|
| Control Memory                      |
| Data Memory                         |
| Full Speed Bit Time                 |
| Host Controller                     |
| Host Controller Driver              |
| Host Controller Functional State    |
| Interrupt Service Routine           |
| Open Host Controller Interface      |
| Phase Locked Loop                   |
| Real Time Operating System          |
| Start of Frame                      |
| Universal Host Controller Interface |
| Transaction Descriptor              |
|                                     |

# 2. System Overview

The UHC124 is a low-cost, high-performance, non-PCI USB host controller with unique, patentpending features that are indispensable for achieving high data throughput and low interrupt rates. It is the only one on the market that is designed from the ground up for embedded applications with full USB specification compliance. It is optimized for cost, performance and ease of development. The software/hardware co-designed architecture enables high performance while maintaining simplicity and flexibility that are critical for embedded applications. It can be interfaced to CISC or RISC microprocessors, microcontrollers, or digital signal processors (DSPs) and is ideal for providing USB host functions to a wide range of applications including mobile devices, cell phones, PDAs, point-of-sale systems, test equipment, set-top boxes, Internet appliances, as well as serving as an interface for USB to Bluetooth controllers.

TransDimension offers complete solutions using the UHC124 including development kits, embedded USB host software and UHCI software interfaces to various real time operating systems optimized for the UHC124. The complete solutions offer the advantages of shortened time-to-market, simplified procurement and technical support from one source.

In the following, it is assumed that the reader has basic knowledge of microprocessor based systems, as well as USB Specification 1.1. References to specific chapters and sections of USB Specification 1.1 are cited in a pair of brackets. For instance, [9.3:183, 11.16:266] refers to "9.3 USB Device Request" on page 183, and "11.16 Requests" on page 266 of USB 1.1 Specification.

#### 2.1 Interface with MCUs

UHC124 may be interfaced with a microprocessor-based system using either one of the two following methods:

- For MCUs with standard external data buses, UHC124 can be interfaced directly via 8 bits of its data bus and 12 bits of its address bus. When UHC124 operates under this mode, its internal memory blocks, as well as its control/status registers, are mapped into the processor's address space.
- For MCUs without an external data bus, UHC124 may be interfaced using an 8-bit output port and an 8-bit bi-directional port. Under this mode, a built-in, auto incrementing address register allows accessing to a large block of UHC124 memory with a single (address) write cycle, followed by as many read/write cycles as the number of data bytes to be transferred from/to the UHC124.

Careful design of both hardware and software interfaces may allow a MCU with external data buses to take advantage of UHC124's auto-incremented addressing. See Section 9 for details.

#### 2.2 Control Memory and Transaction Descriptors

The 256 bytes of *Control Memory* (CM) are evenly divided into 16 sections, each of which (16 bytes) specifies a *Transaction Descriptor* (XD) holding the following control information for a USB transaction:

- Targeted USB device address (0-127) and endpoint number (0-15)
- Transaction type (SETUP, IN, or OUT)
- Starting address of the data block in UHC124 data memory
- Number of bytes to be transferred
- Whether the transaction is targeted to an isochronous endpoint
- Speed (data rate) of the targeted USB device
- Data sequence DATA0/1 (for an OUT transaction)

Upon completion of a transaction, the XD contains information about:

- Transaction status (Ack, Nak, Stall, Timeout, Error, or Overflow)
- Data sequence (for an IN transaction)
- Number of bytes actually transferred (for an IN transaction)

The sixteen XDs are hereafter referred to as XD<sub>0</sub>, XD<sub>1</sub>, ..., XD<sub>9</sub>, XD<sub>A</sub>, XD<sub>B</sub>, ..., XD<sub>E</sub>, and XD<sub>F</sub>.

#### 2.3 Batch Processing

The *Host Controller Driver* (HCD) may organize up to 16 USB transactions into a *transaction batch*, or simply a *batch*. A batch may contain transactions for full-speed (FS: 12 Mbit/sec) and low-speed (LS: 1.5 Mbit/sec) USB devices, of four types of endpoints (control, bulk, interrupt and isochronous) and all transaction types (SETUP, IN and OUT).



Fig. 3 USB transaction and UHC124 transaction batch

For instance, five transactions are grouped together to form a transaction batch (Fig. 3) with

- an isochronous, IN transaction of 1,023 bytes for real time imaging via XD<sub>2</sub>;
- a full speed, bulk OUT transaction of 64 bytes for a printer via XD<sub>3</sub>;
- a SETUP transaction sent to a low speed device via XD<sub>8</sub>;
- a low speed, IN interrupt transaction for a keyboard via XD<sub>C</sub>; and
- a full speed, IN interrupt transaction for a hub via XD<sub>D</sub>.

Compared with other USB host controller designs, batch processing is a very important and unique feature of UHC124. Our software/hardware co-design solves the serious shortcomings of other embedded USB host controller designs that generate an interrupt upon completion of *every* USB transaction. These naïve designs:

- result in significant loss of USB bus bandwidth since the invocation (interrupt latency time) and execution of the interrupt service routine (ISR), (or of certain portion of the ISR at the minimum,) cannot overlap with USB bus activity. This problem is more obvious and damaging when data packet sizes are small, which is typical for many USB applications, making double buffering impractical.
- waste MCU's time due to processor/RTOS overhead for ISR invocation and execution.

With its batch processing capability, a single register write to the UHC124 can dispatch altogether up to 16 transactions, and a single interrupt is generated only after the completion of all of them. The system throughput is therefore significantly improved maximizing the bandwidth on the USB. At the same time, the number of interrupts to the MCU is greatly reduced, saving processor resources for non-USB activities.

Before a batch is dispatched, a set of XDs must be allocated. Such a XD, designated for a transaction, must then be specified (See Section 10). The batch is *dispatched* under the control of user software (see Section 5 for details). XDs in a batch are processed by the UHC124 in sequence - the one with the lowest index is processed first.

Multiple batches may be dispatched and processed by the UHC124 within a single USB frame (1 ms  $\pm$  0.5  $\mu$ S). For easy programming, UHC124 allows transactions to *spill over* the USB frame boundaries - if transactions scheduled for a batch cannot be completed in the current frame, they will be transparently attempted following a hardware-generated *Start of Frame* (SOF).



Fig. 4 Transactions in a batch "spill over" the boundary of a USB frame

The Host Controller Driver (HCD) may use the *UhcMaxOverhead* Register (see Section 5) to limit the number of transactions in a frame to any number, giving user the flexibility of spreading multiple transactions over several frames using a single batch.

The HCD, however, should take careful consideration of the total time required for a scheduled, yet to be dispatched transaction batch, as well as on the real time remaining in the current frame, if frame sensitive isochronous and interrupt transactions are present in the embedded application.

Instructions will be given in Section 10 on how to calculate time required for a single transaction, and that for a batch of multiple transactions.

#### 2.4 Data Memory

The 2,048 bytes of data memory (DM) built into the UHC124 serve as data buffers shared between the MCU and USB system. Unless the data packet is known to be of zero length, a block of DM of proper size must be allocated for the transaction. The starting address and the length of this memory block (in bytes) must be specified in the XD.

For a SETUP or OUT transaction, data must be written into this allocated buffer area *before* the transaction can be dispatched along with a batch. For an IN transaction, on the other hand, data will become available *after* the transaction is completed, provided that no exceptions occurred during transaction processing, where an exception is a device Stall, device Nak, Timeout, or data transfer Error as defined in USB Specification [8.5:162].

#### 2.5 Double Buffering

Double buffering, and its more general form circular buffering, are effective ways to maximize the USB system throughput. Note that UHC124 supports dual port memory access to its entire addressing space (control registers, CM and DM). Together with its batch processing capability, double buffering becomes attractive even for transactions with small data packets.



Fig. 5 Double buffering of two XD clusters

Depending on the application, user software may organize XDs into two or more *XD clusters*. USB transactions associated with a cluster are dispatched as a batch. In Fig. 5 two XD clusters are employed for double buffering. Note that a XD (XD<sub>1</sub>) is included in more than one cluster. While one batch for Cluster A is being processed by the UHC124, another batch for Cluster B is dealt by user software by which completed transactions are processed, and new ones prepared. Once the batch for Cluster A is completed, the user software enables the batch for Cluster B.

In the presence of isochronous transfers, XD clusters must be scheduled in such a way that each USB frame contains exactly one transaction for each active isochronous endpoint. Under the circumstance, a XD cluster must not take longer than approximately 950  $\mu$ S on the USB bus.

For UHC124, the software overhead involved to swap two operating XD clusters is minimum – only one 16-bit register (UhcTransSelect) and an 8-bit register (UhcControl) need to be updated. See Section 5 for descriptions on these registers.

#### 2.6 Interrupt to MCU

Under user software control, the UHC124 may generate an interrupt (active low) to the MCU upon any one of the following conditions and/or events:

- Root hub port status change
- Batch completion (i.e., all transactions in the batch have been processed)
- Batch stop. Software may elect to stop a batch after a transaction if:
  - any one of the transactions in the batch is successfully completed;
  - any one of the transactions in the batch fails (device Stall, Timeout or data/packet Error); or
  - the targeted USB device has returned a Nak for any one of the transactions in the batch
- Host controller error
- Start of frame

The first three conditions provide flexibility to balance required high data throughput and the demand on MCU resources. All five interrupt sources can be masked.

#### 2.7 Root Hub

The UHC124 employs a fully qualified, market proven 4-port USB hub, AT43312A by Atmel Corp., (San Jose, CA) as its root hub. USB transceivers are built-in for all four downstream ports. Technical details for the root hub are given in Section 7.

#### 2.8 External Crystal/Oscillator

A PLL (Phase Locked Loop) is integrated on-chip to generate, from a single 6 MHz crystal or crystal oscillator, the 48 MHz, 12 MHz and 6 MHz clock signals required by UHC124 internal circuitry minimizing EMI. Section 9 gives instructions to construct a working oscillator circuit as well as an external compensating RC network for the internal PLL.

#### 2.9 About UHCI and OHCI

UHC124 is fully compliant with USB Specification 2.0 (for full speed and low speed operation). However, it is not UHCI/OHCI because it is not intended for the PCI bus. OEMs may develop or license, a HCD providing a software interface that appear to the rest of the USB host stack as if there were a UHCI or an OHCI compliant host controller.

In Fig. 6, a carefully crafted USB host engine "steals" a small fraction of the MCU's time, to support UHCI/OHCI operation. The UHCI support for the UHC124 is readily available from TransDimension. Please contact sales@transdimension.com for OCHI support.



Fig. 6 Software interface compatible to UHCI/OHCI

#### 2.10 USB Host API

OEMs may license from TransDimension an OS-independent *UHC124 Programming Interface Library*, supporting direct UHC124 operation and efficient USB host control independent of any RTOS. This solution is attractive for embedded systems with dedicated USB devices. Note that OEMs may have to write device drivers using functions in this library.



Fig. 7 Embedded USB host application written with UHC124 Programming Interface Library

#### 2.11 RTOS Support

Many modern RTOS' (real time operating system) are now supporting USB host operation with their own USB host stacks. TransDimension has made the UHC124 working under several widely used RTOS', WinCE, VxWorks, Linux, etc., and on various hardware platforms (X86/ISA, Arm, StrongArm, MIPs, etc.) Developers should be aware that under the situation, it is in principle the responsibility of the chosen RTOS to provide various USB device drivers (such as the one for HID devices).

#### 2.12 System Suspend and Resume

Under the control of user software, the UHC124 may bring the USB system into *suspend* state, as dictated by USB 1.1 specification [7.1.7.4:122]. While the oscillator for UHC124 is still running, all USB bus activities, including SOF generation, are stopped. The system may be brought out of the suspend state by HCD software, or by a *remote wakeup* [9.2.5.2: 181] originated from a downstream USB device.

#### 2.13 Power Saving State

Under the control of user software, the UHC124 may enter the *power saving* state, in which all internal clocks are stopped, and the PLL is disabled. A small quiescent current (about 200  $\mu$ A) is consumed by the UHC124. Reactivating the system requires a master reset or a power on reset. See Section 8.6 for details.

# 3. Signal Definitions

Abbreviations of signal types:

- I = Input
- O = Output
- B = Bi-directional
- V = Power supply, ground
- 3.1 Oscillator and PLL

| Name             | Туре | Pin No. | Description                                                                                |
|------------------|------|---------|--------------------------------------------------------------------------------------------|
| OSC <sub>1</sub> | Ι    | 17      | Oscillator Input: input to the inverting oscillator amplifier.                             |
| OSC <sub>2</sub> | 0    | 18      | Oscillator Output: output of the inverting oscillator amplifier.                           |
| LPF              | Ι    | 19      | PLL Filter: connecting to a passive RC network; see Section 9 on proper usage of this pin. |

#### 3.2 MCU Interface

| Name                                                             | Туре   | Pin No.        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>11</sub> :A <sub>0</sub>                                  | Ι      | 13:2           | Address Bus: A <sub>11</sub> (pin 13) selects CM or DM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| D <sub>7</sub> :D <sub>4</sub><br>D <sub>3</sub> :D <sub>0</sub> | В      | 53:50<br>47:44 | Data Bus: D <sub>7</sub> is the most significant bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| /CS                                                              | Ι      | 15             | Chin Salaati aatiya law                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                  | I<br>T |                | Chip Select: active low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| /WR                                                              | l      | 55             | Memory Write Strobe: active low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| /RD                                                              | I      | 56             | Memory Read Strobe: active low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| MODE                                                             | Ι      | 14             | Memory Access Mode.<br>$MODE = 1$ : Non-multiplexed memory access. $D_7:D_0$ are<br>connected to the MCU's data bus, $A_{11}:A_0$ to its address bus;<br>MODE = 0: Multiplexed memory access with auto-<br>incremented address. When accessing a block of UHC124<br>memory, the 12-bit starting address is first latched into the<br>chip by writing the least significant 8-bits of the address into<br>$D_7:D_0$ while holding ADS high, and placing the most<br>significant 4-bits of the address on $A_{11}:A_8$ . Data is then<br>retrieved out of, or stored into UHC124 memory with<br>successive read or write operations through $D_7:D_0$ , while pin<br>ADS is pulled low. The memory address is automatically<br>incremented internally for each subsequent memory access.<br>$A_7:A_0$ are not used under this mode. |

| ADS    | Ι | 62 | Address/Data Select: see discussion on signal MODE; When $MODE = 1$ , this pin has no effect, and it should be tied to $V_{SS}$ for noise immunity. |
|--------|---|----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| /INT   | 0 | 61 | Interrupt: generated for microprocessor; active low.                                                                                                |
| /RESET | Ι | 54 | Master Reset: resets entire USB system; active low.                                                                                                 |
| GNDP   | Ι | 63 | Voltage Reference: for built-in power on reset (POR), connect to $V_{SS}$ (ground) for normal operation.                                            |

# 3.3 USB Root Hub Ports

| Name             | Туре | Pin No. | Description                                                                                                |
|------------------|------|---------|------------------------------------------------------------------------------------------------------------|
| $DP_1$           |      | 34      | Port Data for USB I/O:                                                                                     |
| DP <sub>2</sub>  | В    | 37      |                                                                                                            |
| DP <sub>3</sub>  | D    | 39      | DP <sub>1</sub> :DP <sub>4</sub> and DM <sub>1</sub> :DM <sub>4</sub> are the differential signal pairs to |
| DP <sub>4</sub>  |      | 41      | connect downstream USB devices [7.1:107].                                                                  |
| $DM_1$           |      | 35      |                                                                                                            |
| $DM_2$           | В    | 38      |                                                                                                            |
| DM <sub>3</sub>  | D    | 40      |                                                                                                            |
| $DM_4$           |      | 42      |                                                                                                            |
| /OC1             |      | 25      | Over Current Indicator: input signal to indicate to the root                                               |
| $/OC_2$          | T    | 26      | hub that over current is detected at the port; active low. If                                              |
| /OC <sub>3</sub> | 1    | 27      | $/OC_n$ is asserted, the root hub will de-assert $/PO_n$ , and report                                      |
| /OC <sub>4</sub> |      | 28      | the status in the root hub's port status register.                                                         |
| /PO <sub>1</sub> |      | 29      | Power On Switch: output signal to turn on the external                                                     |
| /PO <sub>2</sub> | 0    | 30      | voltage supplying power to a port; active low. /POn is de-                                                 |
| /PO <sub>3</sub> | 0    | 31      | asserted when a power supply problem is detected at /OC <sub>n</sub> ,                                     |
| /PO <sub>4</sub> |      | 32      | where n is 1, 2, 3, or 4.                                                                                  |

# 3.4 Test Modes

| Name                                     | Туре | Pin No.      | Description                                                                                                                 |
|------------------------------------------|------|--------------|-----------------------------------------------------------------------------------------------------------------------------|
| TMS <sub>3</sub> :<br>TMS <sub>0</sub>   | Ι    | 60:57        | Test Mode Select: used only for factory testing; connect to $V_{SS}$ for normal operation.                                  |
| TEST <sub>4</sub> :<br>TEST <sub>0</sub> | В    | 43,<br>24:21 | Test Signal I/O: used only for factory testing; working in output mode during normal operation, they must be left floating. |

## 3.5 Power and Ground

| Name            | Туре | Pin No.         | Description                                         |
|-----------------|------|-----------------|-----------------------------------------------------|
| V <sub>DD</sub> | V    | 1,20<br>33,48   | 3.3V Power Supply. All four pins must be connected. |
| V <sub>SS</sub> | V    | 16,36<br>49, 64 | Ground. All four pins must be connected.            |

# 4. Memory Map

The UHC124's control memory (CM), data memory (DM), and its registers are organized into a 4 kB block, which, at the developer's discretion, may be mapped into a MCU's memory space.

| 00011 | C + 1D + (1(1 + 1))                |
|-------|------------------------------------|
| 000H  | Control Registers (16 bytes)       |
|       |                                    |
| 00FH  |                                    |
| 010H  | Reserved                           |
|       |                                    |
|       |                                    |
|       |                                    |
| 3FFH  |                                    |
| -     |                                    |
| 400H  | Control Memory (CM, 256 bytes) for |
|       | 16 Transaction Descriptors (XDs),  |
|       | each of which is 16 bytes.         |
|       |                                    |
| 4FFH  |                                    |
| 500H  | Reserved                           |
| 00011 |                                    |
| 6FFH  |                                    |
| •     |                                    |
| 700H  | Magic Reset (used only for factory |
|       | test).                             |
| 7FFH  |                                    |
| 800H  | Data Memory (DM, 2048 bytes)       |
|       |                                    |
|       |                                    |
|       |                                    |
|       |                                    |
|       |                                    |
|       |                                    |
|       |                                    |
| FFFH  |                                    |

Fig. 8 UHC124 memory map (memory block sizes not to scale)

Reading from a location in a reserved segment of UHC124 addressing space returns 00H, while writing to such a location has no effect.

Note that the MCU and UHC124's control circuitry share the entire addressing space of the UHC124. An arbitration mechanism inside the chip allows dual port access.

The lowest 16 bytes of this addressing space are system control/status registers described in detail in the next section.

# 5. Control Registers

#### 5.1 Overview

This section discusses UHC124 control registers:

| •<br>•<br>•<br>•<br>• | UhcControl<br>UhcTransSelect<br>UhcTransDone<br>UhcIntpStatus<br>UhcIntpEnable<br>UhcFmInterval<br>UhcFmRemaining<br>UhcFmNumber<br>UhcFmNumber | 000-001H<br>002-003H<br>004-005H<br>006H<br>007H<br>008-009H<br>00A-00BH<br>00C-00DH<br>00FH | system level control<br>batch transaction select<br>transaction status check<br>interrupt status report<br>interrupt enable/disable<br>frame interval<br>frame remaining<br>frame number<br>maximum frame overhead |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •                     | UhcFmNumber                                                                                                                                     | 00C-00DH                                                                                     | frame number                                                                                                                                                                                                       |
|                       | UhcMaxOverhead                                                                                                                                  | 00EH                                                                                         | maximum frame overhead                                                                                                                                                                                             |
|                       | UhcMagicNumber                                                                                                                                  | 00FH                                                                                         | chip/version id, port status change                                                                                                                                                                                |

#### 5.2 UhcControl Register

This register defines the operating states of the UHC124, and is used by the HCD to issue commands such as to initiate a soft reset, to dispatch a transaction batch, and to bring the UHC124 from one host controller functional state (HCFS) to another.

Setting (writing a '1' to) a specific bit of the UhcControl register is a *command* to the UHC124, whereas writing a 0 to that bit has no effect. A total of seven commands can be applied to the UHC124 through this register:

| • | PowerSave      | write '1' to Bit 7 | enter power save state       |
|---|----------------|--------------------|------------------------------|
| ٠ | SoftReset      | write '1' to Bit 5 | soft reset                   |
| • | USBReset       | write '1' to Bit 4 | USB system reset             |
| ٠ | USBSuspend     | write '1' to Bit 3 | enter suspend state          |
| ٠ | USBResume      | write '1' to Bit 2 | resume from suspend state    |
| ٠ | USBOperational | write '1' to Bit 1 | enter operational state      |
| • | BatchOn        | write '1' to Bit 0 | dispatch a transaction batch |

Writing to register UhcControl (000H) with multiple bits set to '1', (such as 06H whose bit pattern contains two 1's,) introduces ambiguity and/or inconsistency into the system, and is therefore ignored by the UHC124.

Moreover, only a valid command under the current HCFS is accepted by the UHC124. For instance, command USBResume does not make sense unless the USB system is currently suspended. See Section 8 on HCFS definitions and valid state transitions.

Developers should be aware that since the clocks for the MCU are in general not synchronized with that of UHC124's, a command takes up to 167 ns to become effective.

Reading the register retrieves the UHC124's current HCFS:

| ٠ | POWERSAVE      | Bit 7 | Power saving state (always read 0)    |
|---|----------------|-------|---------------------------------------|
| ٠ | USBRESET       | Bit 4 | USB system reset in progress          |
| ٠ | USBSUSPEND     | Bit 3 | system in suspend state               |
| ٠ | USBRESUME      | Bit 2 | system is resuming from suspend state |
| • | USBOPERATIONAL | Bit 1 | system in normal operation state      |
| ٠ | BATCHON        | Bit 0 | a batch is being processed by UHC124  |

In the following, a word containing letters of mixed upper and lower cases, such as USBSuspend, is a *command* issued to UHC124 (by writing a '1' to some bit of UhcControl). The very same word in upper case (small caps), such as USBSUSPEND, is the corresponding *HCFS* that the system currently assumes, which is obtained by reading the UhcControl register.

In addition, HC denotes the Host Controller (UHC124), and HCD stands for Host Control Driver, which is used interchangeably with phase "user software".

| Register Address: | 000H | (low byte)  |
|-------------------|------|-------------|
|                   | 001H | (high byte) |

| Reset: Signals vary | (see bit descriptions below) |
|---------------------|------------------------------|
|---------------------|------------------------------|

| D:4  | Bit Default |     | Read/Write | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-------------|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIL  | Bit Default | HCD | HC         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:8 | 00H         |     |            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7    | 0           | R/W | R/W        | PowerSave/POWERSAVE:<br>When a '1' is written into this bit, the UHC124 enters<br>POWERSAVE state immediately if the current state is<br>USBSUSPEND (see section 8.6 for more detailed steps).<br>The UHC124's internal clocks are all stopped in<br>POWERSAVE state.<br>To exit the POWERSAVE state (i.e., to have the bit cleared),<br>MasterReset (/RESET) must be applied which restarts<br>clocks, and places the UHC124 in USBRESET state.<br>Since it is impossible to access memory or registers in the<br>POWERSAVE state, this bit is always 0 when read. |
| 6    | 0           |     |            | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|   |   | 1   | 1   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     |     | SoftReset:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5 | 0 | W   | R   | This bit is set by the HCD to initiate a <i>software reset</i> , which<br>brings the UHC124 into USBSUSPEND state. SoftReset<br>initializes all UHC124 registers and state machines - except<br>UhcFmInterval, UhcFmNumber, UhcFmRemaining and<br>UhcMaxOverhead. A batch in progress will be aborted.<br>Unlike USBReset (Bit 4), SoftReset takes less than 200 ns<br>to accomplish, and it does not reset the root hub and all<br>downstream ports.<br>This bit is always 0 when read.                                                                                                     |
|   |   |     |     | USBReset/USBRESET:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4 | 1 | R/W | R/W | Setting this bit to 1 initializes all UHC124 registers, state<br>machines, the root hub and all downstream ports, regardless<br>of the UHC124's current HCFS. The HCD must ensure that<br>the UHC124 remains in USBRESET state for a minimum of<br>50 ms per USB Specification 1.1 [10.2.8.1:214].<br>PowerOnReset (generated internally by the UHC124 when<br>power is applied to it the first time) and MasterReset<br>(/RESET pin) have almost the same effect as that of<br>USBReset, except that for PowerOnReset and MasterReset,<br>memory access is disabled during the first 12 ms. |
|   |   |     |     | This bit is cleared upon user issuing a SoftReset command, or a USBOperational command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|   |   | [   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     |     | USBSuspend/USBSUSPEND:                                                                                                                                                                                                                                                                                                                                                                                                                     |
|   |   |     |     | Setting this bit to '1' while the UHC124 is in USBOPERATIONAL state brings it to USBSUSPEND state, which disables batch dispatching and SOF generation. This in turn, in less than 5 ms, makes the root hub and connected devices to enter their respective suspend state [7.1.7.4:122]. If there is a batch in progress, USBSUSPEND will be entered after its completion.                                                                 |
| 3 | 0 |     | -   | Another way to bring UHC124 into USBSUSPEND state is through SoftReset.                                                                                                                                                                                                                                                                                                                                                                    |
| 5 | 0 | R/W | R/W | The UH124C is brought out of USBSUSPEND (to enter USBRESUME) upon a RemoteWakeup originated by a downstream USB device, or by the HCD issuing a USBResume command.                                                                                                                                                                                                                                                                         |
|   |   |     |     | It is also possible to exit from USBSUSPEND, and enter<br>USBOPERATIONAL directly by writing a '1' into Bit 1 of the<br>UhcControl register. This method is effective when The<br>UHC124 remains in USBSUSPEND state for less than 3 ms,<br>and none of the devices, including the root hub, have yet<br>actually been suspended. A typical use of this feature is to<br>resume normal USB operation immediately following a<br>SoftReset. |
|   |   |     |     | This bit is cleared upon PowerOnReset, MasterReset, and USBReset. It is set after SoftReset.                                                                                                                                                                                                                                                                                                                                               |
|   |   |     |     | USBResume/USBRESUME:                                                                                                                                                                                                                                                                                                                                                                                                                       |
|   |   |     |     | When set to '1' while the system is in USBSUSPEND, the UHC124 enters USBRESUME state, in which batch dispatching and SOF generation are still being disabled.                                                                                                                                                                                                                                                                              |
| 2 | 0 | R/W | R/W | A RemoteWakeup from a downstream device while the system is in USBSUSPEND will also cause the UHC124 to enter USBRESUME automatically.                                                                                                                                                                                                                                                                                                     |
|   |   |     |     | The system remains in USBRESUME state for about 20 ms before it automatically falls into USBOPERATIONAL.                                                                                                                                                                                                                                                                                                                                   |
|   |   |     |     | This bit is cleared upon PowerOnReset, MasterReset, USBReset, and SoftReset.                                                                                                                                                                                                                                                                                                                                                               |

| r | 1 | 1                                                                                                           | 1   | []                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|---|-------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |                                                                                                             |     | USBOperational/USBOPERATIONAL:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1 | 0 | R/W                                                                                                         | R/W | Setting this bit to '1' while the UHC124 is in USBRESET or<br>USBSUSPEND enters state USBOPERATIONAL, which enables<br>SOF generation and batch dispatching.<br>The user software may notice that the first batch dispatched<br>after entering USBOPERATIONAL may take longer time to<br>complete. This is because transactions in a batch cannot be<br>processed by the UHC124 until the first SOF is generated,<br>which may take up to 1 ms to occur.<br>Caution must be taken when USBOPERATIONAL is entered<br>directly from USBSUSPEND – it is possible that the system<br>has been in that state for longer than 3 ms, and some or all<br>of its connected devices have already entered their<br>respective suspend state. A transaction aimed to such a<br>(suspended) device will inevitably result in a transaction<br>TimeOut. This problem can be resolved automatically with<br>USB's error recovery protocol [8.7:172].<br>This bit is cleared upon PowerOnReset, MasterReset,<br>USBReset, and SoftReset. |
|   |   |                                                                                                             |     | BatchOn/BATCHON:<br>Setting this bit to '1' while the system is in<br>USBOPERATIONAL dispatches a transaction batch. It is reset<br>to 0 if any one of the following condition occurs:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0 | 0 | 0 R/W R/W 1. All selected transaction<br>2. A stop condition for a is satisfied (see Bit StopOnFail of XDCo | ,   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   |   |                                                                                                             |     | This bit is cleared upon PowerOnReset, MasterReset, USBReset, and SoftReset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## 5.3 UhcTransSelect Register

| Register Address: | 002H (low byte)                                    |
|-------------------|----------------------------------------------------|
|                   | 003H (high byte)                                   |
| Reset:            | PowerOnReset, MasterReset, USBReset and SoftReset. |

This register is used to select a subset of transactions, out of 16 XDs in CM, to form a transaction batch. XDn, located at 4n0H - 4nFH of the UHC124's addressing space, is included in the batch if Bit n of UhcTransSelect is set to '1', where n = 0, 1, ..., 9, A, ..., E, F, in hex.

Note that once dispatched, transactions selected in a batch are processed by the UHC124, one at a time, starting from the XD with the lowest index.

#### 5.4 UhcTransDone Register

| Register Address: | 004H (low byte)                                    |
|-------------------|----------------------------------------------------|
|                   | 005H (high byte)                                   |
| Reset:            | PowerOnReset, MasterReset, USBReset and SoftReset. |

This register is used to monitor the progress of a transaction batch. If Bit n of UhcTransDone is set by the UHC124, it indicates that the transaction associated with XDn has been processed. UhcTransDone is cleared by the UHC124 as soon as a BatchOn command is issued to the UhcControl register.

Upon completion or termination of a batch, Bit 0 of UhcControl is set back to '0', the status of a transaction involved in this batch, as far as its progressing status is concerned, can be derived from information provided in UhcTransSelect and UhcTransDone:

| Bit n of<br>UhcTransSelect | Bit n of<br>UhcTransDone | Transaction Status                                                                                                                                                                                                                                                                                  |
|----------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                          | 0                        | Transaction associated with XDn was not selected for the batch.                                                                                                                                                                                                                                     |
| 1                          | 1                        | Transaction associated with XDn was selected<br>for the batch, and has been processed by the<br>UHC124. Status of the transaction is in<br>XDStatus of XDn. (See next section for<br>detailed discussion of XDs).                                                                                   |
| 1                          | 0                        | Two possibilities: (i) transaction associated<br>with XDn was selected for the batch, but has<br>not been processed; (ii) The batch stopped in<br>response to an anticipated outcome of an<br>earlier transaction. See description on XD<br>(next section) for details on batch stop<br>conditions. |
| 0                          | 1                        | System error (not suppose to happen).                                                                                                                                                                                                                                                               |

#### 5.5 UhcIntpStatus Register

Register Address:006HReset:PowerOnReset, MasterReset, USBReset, and SoftReset.

This register reports the following system events and conditions that may cause an interrupt on the /INT pin:

| ٠ | BatchStopped   | Bit 7 | batch stopped before all transactions are processed |
|---|----------------|-------|-----------------------------------------------------|
| ٠ | BatchCompleted | Bit 6 | all transactions in a batch have been processed     |
| ٠ | HostError      | Bit 3 | a host error occurred                               |
| ٠ | ResumeDetected | Bit 2 | entering USBRESUME state                            |
| • | PortChange     | Bit 1 | status change occurred on one of the root hub ports |
| ٠ | StartOf Frame  | Bit 0 | start of a USB frame                                |
|   |                |       |                                                     |

A bit is asserted (set to '1') as soon as the designated event occurs, or condition holds. User software may acknowledge the event by writing a '1' to the bit, which will have the bit cleared.

All bits will remain '1' after asserted, and be cleared explicitly by user software (writing '1' to them). In addition, Bit 7 (BatchStopped) and Bit 6 (BatchCompleted) will also be automatically cleared by UHC124 upon a BatchOn command applied to the UhcControl register.

| D:4 |         | Read/Write |    |                                                                                                                                                                                                                                                                                                                    |
|-----|---------|------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Default | HCD        | HC | Description                                                                                                                                                                                                                                                                                                        |
| 7   | 0       | R/W        | W  | BatchStopped:<br>This bit is set when a batch is stopped due to a software<br>anticipated stop condition that occurred as the result of a<br>transaction (Success, Nak, or Failure). See description on<br>XDControl in the next section for details.<br>The UHC124 clears this bit automatically upon dispatching |
| 6   | 0       | R/W        | W  | of a new transaction batch.<br>BatchCompleted:<br>This bit is set when all selected XDs in a batch have been<br>processed.<br>The UHC124 clears this bit automatically upon dispatch of a<br>new transaction batch.                                                                                                |
| 5:4 | 00      |            |    | Reserved.                                                                                                                                                                                                                                                                                                          |
| 3   | 0       | R/W        | W  | HostError:<br>This bit is set when the UHC124 detects a host controller<br>error – often caused by a transaction with an illegal data<br>packet that would take more than 1 ms to complete.                                                                                                                        |

| 2 | 0 | R/W | W | ResumeDetected:<br>This bit is set when the UHC124 enters USBRESUME state<br>(from USBSUSPEND) in response to a USBResume<br>command, or to a RemoteWakeup originated from a<br>downstream USB device.                                                                                                                                                                                                                                                      |
|---|---|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | 0 | R/W | W | <ul><li>PortChange:</li><li>This bit is set whenever there is a status change in the root hub, or in any of its four downstream ports.</li><li>It is the responsibility of user software to identify the port (or root hub itself) that has had the change (see description on MagicNumber register), and to find out what happened. The latter requires issuing of a hub class request to retrieve the status of that port (or of the root hub).</li></ul> |
| 0 | 0 | R/W | W | StartOfFrame:<br>This bit is set by the UHC124 at the beginning of each USB frame. The actual SOF packet is generated approximately 12 FSBT (approximately 1 µs) after the bit is asserted.                                                                                                                                                                                                                                                                 |

5.6 UhcIntpEnable Register

Register Address:007HReset:PowerOnReset, MasterReset, USBReset, and SoftReset.

Bits in UhcIntpEnable have a one-to-one correspondence with those in UhcIntpStatus. A level triggered interrupt is generated (pin /INT is pulled low) when any one of designated events/conditions is reported by UIntpStatus, *and* the corresponding interrupt source is enabled in UhcIntpEnable.

Setting '1' to a bit of this register enables the corresponding interrupt source.

| D:4 D | D - f 14 | Read/Write |    |                                  |
|-------|----------|------------|----|----------------------------------|
| Bit   | Default  | HCD        | HC | Description                      |
| 7     | 0        | R/W        | R  | BatchStopped Interrupt Enable.   |
| 6     | 0        | R/W        | R  | BatchCompleted Interrupt Enable. |
| 5:4   | 00       |            |    | Reserved.                        |
| 3     | 0        | R/W        | R  | HostError Interrupt Enable.      |
| 2     | 0        | R/W        | R  | ResumeDetect Interrupt Enable.   |
| 1     | 0        | R/W        | R  | PortChange Interrupt Enable.     |
| 0     | 0        | R/W        | R  | StartOfFrame Interrupt Enable.   |

#### 5.7 UhcFmInterval Register

| Register Address: | Low byte: 008H                           |
|-------------------|------------------------------------------|
|                   | High byte: 009H                          |
| Reset:            | PowerOnReset, MasterReset, and USBReset. |

The least significant 14 bits of the UhcFmInterval register determine the duration of a USB frame in terms of its full speed (12 Mbit per second) bit times (FSBTs). This register can be used to fine-tune the frame duration for certain applications.

Note that USB specification requires that the frame to be 1 ms  $\pm$  0.5 µs [7.1.12:126], which translates to 12,000  $\pm$  6 counts for the 12 MHz clock. Setting this register to a value out of this range may cause compatibility problems for most USB devices, especially hubs. Moreover, user software may not change the frame internal more than 1 FSBT during less than 6 frames. To read/write from/to this register, user software must first read/write its LSB (008H), followed by another read/write of its MSB (009H).

| D:4   | Dit Default | Read/ | Write | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Default     | HCD   | HC    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:14 |             |       |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13:0  | 2EDFH       | R/W   | R     | <ul> <li>FrameInterval:</li> <li>The register should be set to a value that is 1 less than the number of FSBTs constituting the desired USB frame.</li> <li>After a PowerOnReset, a MasterReset (/RESET pin) or a USBReset, the register is default to 2EDFH (11,999 in decimal), corresponding to a USB frame of 12,000 FSBTs, or exactly 1 ms.</li> <li>If the register is updated by user software, the new value will not take effect until the start of the next frame.</li> </ul> |

#### 5.8 UhcFmRemaining Register

| Register Address: | 00AH (low byte)                          |
|-------------------|------------------------------------------|
|                   | 00BH (high byte)                         |
| Reset:            | PowerOnReset, MasterReset, and USBReset. |

This register is a 14-bit down counter, whose value can be read "on the fly" by user software to determine the instantaneous time relative to the beginning of the current USB frame.

To read from this register, user software must first issue a read to its LSB (00AH), followed by another one for the MSB (00BH).

| Bit Default Read/Write Descrip | Description |     |     |                                                                                                                                                                                                                                                                                            |
|--------------------------------|-------------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                            | Delault     | HCD | HC  | Description                                                                                                                                                                                                                                                                                |
| 15:14                          | 00          |     |     | Reserved                                                                                                                                                                                                                                                                                   |
| 13:0                           | 000H        | R   | R/W | FrameRemaining:<br>The value of this register decrements once per full speed<br>bit time. It is reloaded with the value of UhcFmInterval<br>once it reaches 0. The frame boundary is the bit boundary<br>on which the value of this register changes from '0' to that<br>of UhcFmInterval. |

#### 5.9 UhcFmNumber Register

| Register Address: | 00CH (low byte)                          |
|-------------------|------------------------------------------|
|                   | 00DH (high byte)                         |
| Reset:            | PowerOnReset, MasterReset, and USBReset. |

This register is an 11-bit counter, whose value is broadcast over the USB system riding SOF packets.

While reading this register, the HCD must read the low byte (00CH) first.

| D:4   | Default | Read/ | Write | Description                                                                                                                                                 |
|-------|---------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Delault | HCD   | HC    | Description                                                                                                                                                 |
| 15:11 | 00000   |       |       | Reserved.                                                                                                                                                   |
| 10: 0 | 000H    | R     | R/W   | FrameNumber:<br>The register is incremented by 1 at each frame boundary,<br>following which a SOF packet carrying the current frame<br>number is generated. |

#### 5.10 UhcMaxOverhead Register

| Register Address: | 00EH                                     |
|-------------------|------------------------------------------|
| Reset:            | PowerOnReset, MasterReset, and USBReset. |

This register is used to fine-tune the time usable for USB transactions in a frame. As illustrated in Fig. 9, USB transactions can only be carried out in a frame after the SOF packet, and before  $EOF_M$ . The value of UhcMaxOverhead ranges from 10 to 255. Setting the register to a value less than 10 is not recommended.

Before a transaction is processed by the UHC124, user software may wish to estimate the time required for the transactions to be successfully carried out, or timeout, before  $EOF_M$  in the current frame. If there is not enough time, some transactions will "spill over" to the next frame. In other words, it will not be processed until after the next SOF packet.



Fig. 9 USB frame under UHC124 (time not to scale)

| Γ | D:4  | Default | Read/Write |    | Description                                                                                                          |
|---|------|---------|------------|----|----------------------------------------------------------------------------------------------------------------------|
|   | Bit  |         | HCD        | HC | Description                                                                                                          |
|   | 7: 0 | С0Н     | R/W        | R  | MaxOverhead:<br>Number of USB Full Speed Bit Times (FSBTs) between $EOF_M$ and $EOF_1$ (10-255 decimal). See Fig. 9. |

5.11 UhcMagicNumber Register

Register Address:00FHReset:PowerOnReset, MasterReset, USBReset, and SoftReset.

This register is used to read the UHC124's chip identification (DBH), as well as to retrieve PortChange, i.e., which down stream port, or the root hub itself, has a status change. Operation of UhcMagicNumber register is illustrated with the following state diagram:



Fig. 10 Operation of UhcMagicNumber register (00FH)

The following steps must be followed to read PortChange:

- 1. Read the register;
- 2. Write 55H to the register;
- 3. Write AAH to the register; and finally
- 4. Read the register retrieving a byte containing PortStatusChange and HubStatusChange:

| D:4 | Default | Read/Write |    | Description                                                                                            |
|-----|---------|------------|----|--------------------------------------------------------------------------------------------------------|
| Bit |         | HCD        | HC | Description                                                                                            |
| 7:5 | 000     |            |    | Reserved.                                                                                              |
| 4:1 | 0000    | R          | W  | PortStatusChange:<br>Bit n is asserted if there has been a status change on Port n<br>of the root hub. |
| 0   | 0       | R          | W  | HubStatusChange:<br>Asserted if there has been a status change on the root hub.                        |

Note that this byte reflecting port/hub status change is identical to that obtained through an IN transaction via EP1, an IN interrupt endpoint, of the root hub [11.13.1:257]. An asserted status change bit can be cleared only through a ClearPortFeature request as described in the USB specification [11.13.2:257].

## 6. Transaction Descriptor

#### 6.1 Overview

The 256 bytes of UHC124's addressing space starting from 400H are reserved as Control Memory (CM), which holds 16 transaction descriptors (XD) denoted as  $XD_0$ ,  $XD_1$ ,  $XD_2$ , ...  $XD_9$ ,  $XD_A$ , ...,  $XD_F$ .

| XD              | Location    |
|-----------------|-------------|
| $XD_0$          | 400H - 40FH |
| $XD_1$          | 410H - 41FH |
| XD <sub>2</sub> | 420H - 42FH |
| XD <sub>3</sub> | 430H - 43FH |
| $XD_4$          | 440H - 44FH |
| $XD_5$          | 450H - 45FH |
| $XD_6$          | 460H - 46FH |
| XD <sub>7</sub> | 470H - 47FH |
| $XD_8$          | 480H - 48FH |
| XD <sub>9</sub> | 490H - 49FH |
| XD <sub>A</sub> | 4A0H - 4AFH |
| $XD_B$          | 4B0H - 4BFH |
| XD <sub>C</sub> | 4C0H - 4CFH |
| XD <sub>D</sub> | 4D0H - 4DFH |
| $XD_E$          | 4E0H - 4EFH |
| XD <sub>F</sub> | 4F0H - 4FFH |

Each XD consists of the following fields:

| XDControl    | 1 byte  | @ offset 0 | transaction control             |
|--------------|---------|------------|---------------------------------|
| XDStatus     | 1 byte  | @ offset 1 | transaction status              |
| XDDevAddress | 1 byte  | @ offset 2 | device address (0-127)          |
| XDEndpoint   | 1 byte  | @ offset 3 | endpoint number (0-15)          |
| XDBufAddress | 2 bytes | @ offset 4 | address of data area (800-FFFH) |
| XDBufLength  | 2 bytes | @ offset 6 | data length (0-1,023)           |
| XDXferCount  | 2 bytes | @ offset 8 | number of bytes not transferred |

Upon a BatchOn command, the XDs selected for the batch are loaded, one at a time, into the chip's USB Host Control Logic (Fig. 1), and processed. As long as the BATCHON bit of UhcControl is set, the user software should not attempt to modify any selected, yet to be processed XDs. See discussion on registers UhcTransSelect and UhcTransDone in the previous section for details.

# 6.2 XDControl

## XD Offset: 0

XDControl contains information needed to process the transaction. It must be specified before the transaction is dispatched along with a batch.

| Bit | Description                                                                                                                                                                                                                                                                                                                                           |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | StopOnSucc:                                                                                                                                                                                                                                                                                                                                           |
|     | When this bit is set, the current batch stops after the transaction of this XD if the transaction has been successful.                                                                                                                                                                                                                                |
| 7   | For IN, this means that the device returns a data packet to the host with<br>no error. For SETUP and non-isochronous OUT, this means that the host<br>received an ACK from the device. For isochronous OUT, the transaction<br>is always considered successful after it is dispatched.                                                                |
|     | If the batch must be continued after this transaction, regardless of its outcome, set Bits 7:5 to 000.                                                                                                                                                                                                                                                |
|     | StopOnNak:                                                                                                                                                                                                                                                                                                                                            |
| 6   | When this bit is set, the current batch stops after the transaction of this XD if device has responded with a Nak.                                                                                                                                                                                                                                    |
| 5   | <ul> <li>StopOnFail:</li> <li>When this bit is set, the current batch stops after the transaction associated with this XD when one of following occurs:</li> <li>device has returned Stall;</li> <li>device has failed to respond within 18 bit times (Timeout); or</li> <li>there has been an Error in the packet returned by the device.</li> </ul> |
|     | DevSpeed:                                                                                                                                                                                                                                                                                                                                             |
| 4   | Data rate for the targeted device – 0: full speed (12 Mbits/sec); 1: low speed (1.5 Mbits/sec).                                                                                                                                                                                                                                                       |
| 3   | Isochronous:         This bit is set to '1' if the transaction is isochronous.                                                                                                                                                                                                                                                                        |
|     | OutDataSeq:                                                                                                                                                                                                                                                                                                                                           |
| 2   | Data sequence toggle for a non-isochronous, OUT transaction - 0: DATA0; 1: DATA1 [8.6:168].                                                                                                                                                                                                                                                           |
|     | This bit is irrelevant for IN transactions. For SETUP or isochronous OUT transactions, this bit should be set to '0'.                                                                                                                                                                                                                                 |

|     | TransType:                                                                                                                 |
|-----|----------------------------------------------------------------------------------------------------------------------------|
| 1:0 | Type of the transaction – 00: SETUP (host to device); 01: OUT (host to device); 10: IN (device to host); and 11: reserved. |

### 6.3 XDStatus

### XD Offset: 1

The UHC124 returns the status of the transaction in this location of the XD after the transaction is completed. User software may read this byte upon completion of the batch when BATCHON of UhcControl is no longer asserted, or at the minimum, after this transaction is processed (To determine whether a transaction in a batch has been processed, registers UhcTransSelect and UhcTransDone must be consulted, see previous section for details.)

| Bit | Description                                                                                                                                                                                                                                                              |  |  |  |  |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7   | Reserved.                                                                                                                                                                                                                                                                |  |  |  |  |
|     | Stall:                                                                                                                                                                                                                                                                   |  |  |  |  |
| 6   | This bit is asserted by the UHC124 as the result of a Stall packet received from the endpoint of the USB device.                                                                                                                                                         |  |  |  |  |
|     | Error:                                                                                                                                                                                                                                                                   |  |  |  |  |
| 5   | <ul> <li>The bit is asserted by the UHC124 if during the transaction</li> <li>a CRC error occurred for the data packet of an IN transaction;</li> <li>a PID error occurred; or</li> <li>a corrupted packet (such as missed bit stuffing bits) is encountered.</li> </ul> |  |  |  |  |
|     | Overflow:                                                                                                                                                                                                                                                                |  |  |  |  |
| 4   | This bit is set when the UHC124 receives more data from the device than that specified in XDBufLength. Note that excessive data is truncated.<br>This bit is irrelevant for SETUP and OUT transactions.                                                                  |  |  |  |  |
| 3   | Timeout:<br>This bit is set by the UHC124 as it fails to receive any response from the device 18 bit times after the token packet in an IN transaction, or after                                                                                                         |  |  |  |  |
| 2   | <ul><li>the device bounded data packet in a SETUP or OUT transaction.</li><li>Nak:</li><li>The bit is set if the UHC124 has received a Nak packet from the device for this transaction.</li></ul>                                                                        |  |  |  |  |

|   | InDataSeq:                                                                                                                                   |
|---|----------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | This bit is set by the UHC124 for an IN transaction - 0: a DATA0 data packet has been received; 1: a DATA1 data packet has been received.    |
|   | It is irrelevant for OUT transactions.                                                                                                       |
|   | Ack:                                                                                                                                         |
| 0 | This bit is asserted if the UHC124 has received an Ack packet from the device for a SETUP transaction, or a non-isochronous OUT transaction. |
|   | It is irrelevant for IN transactions and isochronous OUT transactions.                                                                       |

## 6.4 XDDevAddress

### XD Offset: 2

| Bit | Description                                                                             |
|-----|-----------------------------------------------------------------------------------------|
| 7   | Reserved.                                                                               |
| 6:0 | DevAddress:<br>This is the 7-bit address of the USB device targeted by the transaction. |

### 6.5 XDEndpoint

### XD Offset: 3

| Bit | Description                                                                                   |
|-----|-----------------------------------------------------------------------------------------------|
| 7:4 | Reserved.                                                                                     |
| 3:0 | Endpoint:<br>This is the 4-bit endpoint number of the USB device targeted by the transaction. |

# 6.6 XDBufAddress

| XD Offset: | 4 | (low byte)  |
|------------|---|-------------|
|            | 5 | (high byte) |

| Bit   | Description                                                                                                                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:12 | Reserved.                                                                                                                                                                                                     |
|       | BufAddress:                                                                                                                                                                                                   |
| 11:0  | This is the starting address of the data area allocated for the transaction.<br>The 12-bit address specified here is relative to 000H. (Thus a valid value<br>for the field must fall between 800H and FFFH.) |

# 6.7 XDBufLength

| XD Offset: | 6 | (low byte)  |
|------------|---|-------------|
|            | 7 | (high byte) |

| Bit   | Description                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15:10 | Reserved.                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|       | BufLength:<br>This is the length of the data (in bytes) for the transaction.                                                                                                                                                                                                                                                                             |  |  |  |  |
| 9:0   | Note that for an IN transaction, the data packet may contain more data<br>than anticipated. In this case, the Overflow bit of XDStatus is asserted,<br>and the excessive data bytes are truncated. It is therefore recommended<br>to always employ here the size of the endpoint buffer for IN transactions,<br>even if it may not be completely filled. |  |  |  |  |
|       | For EP0, the size of the endpoint buffer is given in field bMaxPacketSize0 of the device descriptor [9.6.1:196]; and for other endpoints, it is presented to the host in field wMaxPacketSize of the corresponding endpoint descriptor [9.6.4:203].                                                                                                      |  |  |  |  |

# 6.8 XDXferCount

| XD Offset: | 8 | (low byte)  |
|------------|---|-------------|
|            | 9 | (high byte) |

| Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:10 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9:0   | XferCount:<br>This contains the result of a down counter in the USB Host Controller<br>Logic (Fig. 1). At the beginning of the transaction, the counter was<br>loaded with the value of XDBufLength. The counter is then decremented<br>by one for every byte transferred. If more bytes than that indicated by<br>BufLength are actually transferred, XferCount is set to zero, and the<br>Overflow bit in XDStatus is asserted. |
|       | The content of this down counter is copied to XferCount only <i>after</i> the transaction is completed. Thus it may not be read "on the fly" while the transaction is in progress. Moreover, XferCount is meaningful only for IN transactions – it is always zero for SETUP and OUT transactions.                                                                                                                                 |

# 7. Root Hub

The UHC124 employs the AT43312A (by Atmel) as its root hub. It supports the following standard descriptors: Device Descriptor, Configuration Descriptor, Interface Descriptor, Endpoint Descriptor, and Hub Descriptor. Other supported standard requests and hub class requests include ClearHubFeature, ClearPortFeature, GetBusState, GetHubDescriptor, GetHubStatus, GetPortStatus, SetHubDescriptor, SetHubFeature, SetPortFeature. See USB Specification 1.1 [11.16:266] for details.

### 7.1 Down Stream Ports

Each of the four downstream ports of the root hub can be connected to a full speed or a low speed device. 15 k $\Omega$  pull-down resistors are required at DP<sub>n</sub> and DM<sub>n</sub> data lines (n = 1, 2, 3, or 4). To satisfy the impedance matching requirement, a 22  $\Omega$  resistor must be inserted between a USB data line (DP<sub>n</sub> or DM<sub>n</sub>) and its corresponding pin at the Type A connector. See Fig. 13 in Section 9 for a schematic description.

Per USB specification, the speed of the USB device attached to a downstream port is determined at the time of enumeration, depending on which data line  $(DP_n \text{ or } DM_n)$  is pulled high [7.1.5:113].

If a port is connected to a low speed device, the root hub will not propagate any traffic to that port unless it is prefixed with a preamble PID. However, low speed packets (following the preamble PID) are propagated down stream to both low and full speed devices. A packet targeted to a low speed device is placed on the bus four FSBT after the preamble PID [11.8.4:252].

### 7.2 Port Power Management

Over-current conditions can be detected on a per port basis, and be furnished to the UHC124's root hub through its  $/OC_n$  pins (active low, n = 1, 2, 3 or 4). As soon as  $/OC_n$  is asserted, the root hub sets the PORT\_OVER\_CURRENT bit of the port's *status word* and the C\_PORT\_OVER\_CURRENT bit of the port's *status change word* [11.16.2.6:273], and at the same time, the power to the offending port is turned off.

An external switching device is needed to perform the actual "turn-on" and "turn-off" (of the power) for each port. Any type of switching device is acceptable as long as it has a sufficiently low voltage drop even when the device connecting to the port absorbs full power. In its simplest form, this switch can be a P-channel MOSFET, though power-switching ICs specially designed for USB, such as TPS2044/2054 by TI and MIC2524/2527 by Micrel are recommended.

The USB specification requires that the voltage drop at the power switch and board traces be no more than 100 mV. A good conservative maximum drop at the power switch itself should be no more than 75mV. Careful design and selection of the power switch and PCB layout is required to meet the specifications.

Each port has its own power control pin /PO<sub>n</sub> (active low, n = 1, 2, 3 or 4), which is asserted only when a SetPortFeature request with feature PORT\_POWER is issued to the specific port. /PO<sub>n</sub> is de-asserted upon anyone of the following conditions:

- 1. PowerOnReset, MasterReset or USBReset;
- 2. Over current condition; or
- 3. Request of ClearPortFeature with feature PORT\_POWER.

#### 7.3 Root Hub as a USB Device

As a special case of a USB device, the UHC124 root hub has two endpoints: Endpoint 0 (EP0), and Endpoint 1 (EP1). EP0 is used for root hub enumeration, for port manipulation, and for retrieving information about its configuration and hub/port status. By definition, all transfers to/from EP0 are control transfers, more specifically, standard USB requests and hub class requests. EP1, is an interrupt IN endpoint for reporting hub/port status change, which is to be polled by user software every 255 ms.

Like any other USB device, the root hub must be enumerated before it can be used, which involves, at the minimum, the following two steps:

1. Set address.

Since the root hub is always the first USB device in the system, device address 01H is conventionally reserved for it, although for the UHC124, any address between 1-127 is also valid.

This step is done through standard USB request SET\_ADDRESS via default address 00H [9.4.6:192].

2. Set configuration.

The root hub of the UHC124 has only one configuration (configuration number 1). User software must explicitly set the configuration of the root hub to 1 before any hub class requests are issued.

This step is accomplished through standard USB request SET\_CONFIGURATION via the device address assigned in the previous step (most likely, 01H) [9.4.7:193].

It is a good practice to verify, after this step, the effectiveness of the newly assigned device address and configuration setting. This is done through standard USB request GET\_CONFIGURATION using the address assigned in Step 1 [9.4.2:189].

Device descriptor, configuration descriptors, and endpoint descriptors for a USB device carry detailed information for its identification, characterization, and usage. Their pre-defined contents for the UHC124 root hub are given below. They are presented only for reference purposes - it is not necessary to have them retrieved in a user application.

The device description for UHC124's root hub can be obtained using standard USB request GET\_DESCRIPTOR with DEVICE as its descriptor type, using DEV1 as the device address. If the device has yet to be assigned an address, it responses to DEV0 (device address 0) [9.6.1:196].

| Device Descriptor  |        |      |                    |                          |
|--------------------|--------|------|--------------------|--------------------------|
| Field              | Offset | Size | UHC124<br>Root Hub | Remark                   |
| bLength            | 0      | 1    | 12H                | total length - 18 bytes. |
| bDescriptorType    | 1      | 1    | 01H                | DEVICE (1).              |
| bcdUSB             | 2      | 2    | 0110H              | USB ver (1.10).          |
| bDeviceClass       | 4      | 1    | 09H                | not used.                |
| bDeviceSubClass    | 5      | 1    | 00H                | not used.                |
| bDeviceProtocol    | 6      | 1    | 00H                | not used.                |
| bMaxPacketSize0    | 7      | 1    | 08H                | EP0 max packet size (8). |
| idVendor           | 8      | 2    | 03EBH              | hub vendor               |
| idProduct          | 10     | 2    | 3312H              | part id (3312).          |
| bcdDevice          | 12     | 2    | 0300H              | version id (3.00).       |
| iManufacture       | 14     | 1    | 00H                | not used.                |
| iProduct           | 15     | 1    | 00H                | not used.                |
| iSerialNumber      | 16     | 1    | 00H                | not used.                |
| bNumConfigurations | 17     | 1    | 01H                | single configuration.    |

Per USB specification, standard request GET\_DESCRIPTOR with CONFIGURATION as the descriptor type and a configuration index retrieves not only a configuration descriptor of the device, but also interface descriptor(s), endpoint descriptor(s), as well as other class descriptors under the configuration [9.6.2:199]. Specifically, the UHC124 root hub returns, upon this request, a total of 25 bytes containing a configuration descriptor [9.6.2:199], an interface descriptor [9.6.3:201], and a single endpoint descriptor [9.6.4:203].

In the following, the "m:n" notation is used in column Offset, where m gives the location of data relative to the beginning of its specific descriptor , and n is that relative to the beginning of the 25 bytes returned by the UHC124 upon the request.

| Configuration Descripto | 1               |      |                    |                             |
|-------------------------|-----------------|------|--------------------|-----------------------------|
| Field                   | Offset<br>(m:n) | Size | UHC124<br>Root Hub | Remark                      |
| bLength                 | 0:0             | 1    | 09H                | length of conf. desc. (9).  |
| bDescriptorType         | 1:1             | 1    | 02H                | CONFIGURATION (2).          |
| wTotalLength            | 2:2             | 2    | 0019H              | total bytes returned (25).  |
| bNumInterfaces          | 4:4             | 1    | 01H                | number of interfaces (1).   |
| bConfigurationValue     | 5:5             | 1    | 01H                | the only configuration (1). |
| iConfiguration          | 6:6             | 1    | 00H                | not used.                   |
| bmAttributes            | 7:7             | 1    | E0H                | self pwr., remote wakeup.   |
| bMaxPower               | 8:8             | 1    | 20H                | max power (64 mA).          |

Configuration Descriptor

| Interface Descriptor |                 |      |                    |                           |
|----------------------|-----------------|------|--------------------|---------------------------|
| Field                | Offset<br>(m:n) | Size | UHC124<br>Root Hub | Remark                    |
| bLength              | 0:9             | 1    | 09H                | length of intf. desc (9). |
| bDescriptorType      | 1:10            | 1    | 04H                | INTERFACE (4).            |
| bInterfaceNumber     | 2:11            | 2    | 00H                | interface number (0).     |
| bAlternateSetting    | 3:12            | 1    | 00H                | no alternate settings.    |
| bNumEndpoints        | 4:13            | 1    | 01H                | EP1 only.                 |
| bInterfaceProtocol   | 5:14            | 1    | 09H                | hub protocol.             |
| bInterfaceClass      | 6:15            | 1    | 00H                | not used.                 |
| bInterfaceSubClass   | 7:16            | 1    | 00H                | not used.                 |
| iInterface           | 8:17            | 1    | 00H                | not used.                 |

#### Interface Descriptor

#### Endpoint Descriptor for EP1

| Field            | Offset<br>(m:n) | Size | UHC124<br>Root Hub | Remark                 |
|------------------|-----------------|------|--------------------|------------------------|
| bLength          | 0:18            | 1    | 07H                | length of ep desc (7). |
| bDescriptorType  | 1:19            | 1    | 05H                | ENDPOINT (5).          |
| bEndpointAddress | 2:20            | 1    | 81H                | EP1:IN.                |
| bmAttributes     | 3:21            | 1    | 03H                | Interrupt.             |
| wMaxPacketSize   | 4:22            | 2    | 0001H              | data buffer size (1).  |
| bInterval        | 5:24            | 1    | FFH                | interval (255 ms).     |

### 7.4 Hub Characteristics

A USB hub is characterized by its *Hub Descriptor*, which can be retrieved by issuing a hub class request for GET\_DESCRIPTOR with 29H as its descriptor type [11.16.2.4:271]. UHC124 root hub returns the following upon this request:

| Hub Descriptor      |        |      |                    |                                                               |
|---------------------|--------|------|--------------------|---------------------------------------------------------------|
| Field               | Offset | Size | UHC124<br>Root Hub | Remark                                                        |
| bLength             | 0      | 1    | 09H                | length of hub desc. (9).                                      |
| bDescriptorType     | 1      | 1    | 29H                | HUB (29H).                                                    |
| bNbrPorts           | 2      | 1    | 04H                | four downstream ports.                                        |
| wHubCharacteristics | 3      | 2    | 0009H              | Individual power<br>switching and over current<br>protection. |
| bPwrOn2PwrGood      | 5      | 1    | 32H                | pwr on to good (100 ms).                                      |
| bHubContrCurrent    | 6      | 1    | 40H                | max hub current (64 mA).                                      |
| DeviceRemovable     | 7      | 1    | 00H                | all 4 ports                                                   |
| PortPwrCtlMask      | 8      | 1    | 1EH                | for compatibility of 1.0.                                     |

### Hub Descriptor

### 7.5 Port Manipulation

UHC124 has four downstream ports that can be manipulated once the root hub is enumerated.

Power must be turned on for all four downstream ports, even if a device is already attached and/or self-powered. This can be done though hub class request SetPortFeature with feature POWER\_ON for each port [11.16.2.6.1.6:276]. 10 ms of waiting time is required to ensure power is indeed switched on.

Once a device is attached to a port, the port needs to be enabled. This is done by hub class request SetPortFeature with feature PORT\_RESET [11.16.2.6.1.5:276]. Host software then waits for up to 50 ms. Hub class request GetPortStatus can be used to read port status, making sure it has a device attached, and is actually reset and enabled [11.16.2.6:273].

Never enable a port unless there is a device attached. It is a good practice to start device enumeration, (assigning an address, as its first step,) right after the port (it attaches to) is enabled. Do not allow a situation where multiple ports are enabled, but devices connecting to these ports still default to DEV0. Because they will all response to the host as DEV0, signals on the USB bus may become corrupted.

### 7.6 Port Status Change Endpoint (EP1)

EP1 of the root hub is an interrupt endpoint, which is used by user software to retrieve status change information for the root hub and its four ports.

The UHC124 root hub samples the changes at the end of every frame anticipating an interrupt IN transfer out of this endpoint during the next frame period. The sampled information is organized in the *Port Status Change Register*, using a bitmap scheme described below [11.13.4:259]:

| Bit | Function             | Description                                           |
|-----|----------------------|-------------------------------------------------------|
| 7:5 | Reserved             | default values.                                       |
| 4   | Port 4 status change | asserted if a Port 4 status change has been detected. |
| 3   | Port 3 status change | asserted if a Port 3 status change has been detected. |
| 2   | Port 2 status change | asserted if a Port 2 status change has been detected. |
| 1   | Port 1 status change | asserted if a Port 1 status change has been detected. |
| 0   | Hub status change    | asserted if a hub status change has been detected.    |

User software periodically (every 255 ms) initiates IN transactions to EP1 of the root hub. Such a transaction results in a Nak if none of the bits in the Port Status Change Register is asserted. Otherwise, content of this register (one byte) will be returned.

User software must then find out what happened on which port with GetHubStatus [11.16.2.5:271] or GetPortStatus requests [11.16.2.6:273]. Once the cause of reported status change is identified, request ClearHubFeature [11.16.2.1:269] or ClearPortFeature

[11.16.2.2:269] must be explicitly issued to acknowledge the hub/port status change, which in turn clears its port bit in the root hub's Port Status Change Register.

The Port Status Changes Register of UHC124's root hub can also be accessed through the UhcMagicNumber register (00FH). See Section 5 for details.

## 8. Host Controller Functional States

#### 8.1 UHC124 States and State Transitions

At any time, UHC124 is in one of the following states, identifiable with UhcControl register bits:

(impossible to read in POWERSAVE state)

Bit 7

Bit 1

- PowerSave
- USBRESET Bit 4
- USBSUSPEND Bit 3
- USBRESUME Bit 2
- USBOPERATIONAL Bit 1

The system may change its current state in response either to a command issued by user software (HCD), or to an external event (such as RemoteWakeup or MasteReset). Recall that a user command is applied to UHC124 by writing a '1' to the specific bit of the UhcControl register:

- PowerSave Bit 7
- SoftReset Bit 5
- USBReset Bit 4
- USBSuspend Bit 3
- USBResume Bit 2
- USBOperational



Fig. 11 UHC124 functional state transitions

Fig. 11 illustrates all valid transitions among all host controller functional states discussed in detail below.

#### 8.2 UsbOperational

This is the normal operating state for the UHC124. In this state, SOF packets are generated at set frame intervals, and transaction batches, dispatched by user software, are processed.

State USBOPERATIONAL is normally entered by issuing command USBOperational while the system is in state USBRESET. It is also possible to enter this state directly, with the same command, from USBSUSPEND, allowing quick resumption of normal operation after a SoftReset. Caution must be taken in this case so that the command is applied within 3 ms - before the root hub and other USB devices actually go into their respective suspend modes.

#### 8.3 UsbReset

The UHC124 enters this state upon a PowerOnReset, a MasterReset or a USBReset, regardless of the current system state. When in USBRESET state, all downstream ports of the root hub are placed in SE0 state, resetting all connected devices. The user software (HCD) must ensure that the system remains in USBRESET state for a minimum 50 ms [7.1.7.3:122].

#### 8.4 UsbSuspend

This state is entered following a SoftReset, or from USBOPERATIONAL upon command UsbSuspend. Normally, the UsbSuspend command becomes effective immediately, except when it is applied while a transaction batch is in progress, in which case the UHC124 enters USBSUSPEND only after the batch is completed. SoftReset, on the other hand, aborts such a batch instantly.

When the UHC124 is in USBSUSPEND state, batch dispatching and SOF generation are disabled. Thus power consumption for the entire USB subsystem is reduced. However, internal clocks are not stopped because the UHC124 is anticipating a RemoteWakeup from a downstream device, or a USBResume command from user software.

User software should in general ensure that the UHC124 stays in USBSUSPEND for at least 5 ms so that all connected devices actually enter their respective suspend state. One exception is when USBSUSPEND is entered due to a SoftReset, and the previous state was USBOPERATIONAL. In this case, user software may wish to go back to state USBOPERATIONAL immediately, and not to allow devices to actually become suspended. This can be achieved by issuing a USBOPerational command in less than 3 ms after the SoftReset.

The UHC124 goes out of USBSUSPEND (to enter USBRESUME) upon detection of a RemoteWakeup from a downstream USB device, or in response to a USBResume command.

#### 8.5 UsbResume

The UHC124 enters this state upon a user UsbResume command, or in response to a RemoteWakeup from a connected device.

Under USBRESUME, SOF generation and transaction batch dispatching are still disabled. UHC124 sends USB resume signal downstream for 20 ms before it falls into, automatically, the USBOPERATIONAL state.

#### 8.6 PowerSave

The UHC124 enters POWERSAVE state upon receiving a PowerSave command while the system is in USBSUSPEND state. The following procedure should be followed:

- Enter USBSUSPEND state. This is done by issuing command UsbSuspend while the system is in state USBOPERATIONAL; or alternatively, by issuing a SoftReset.
- Wait for at least 5 ms to ensure that the root hub and all connected devices have indeed entered their respective suspend states.
- Enter the POWERSAVE state.

In the POWERSAVE state, all internal clocks of the UHC124 are stopped. The system therefore cannot be awaked by a RemoteWakeup event, nor can it be commanded by user software. The only way to exit the POWERSAVE state is for the microprocessor to apply a MasterReset (/RESET pin), bringing the UHC124 into the USBRESET state.

# 9. Hardware Setup and Interface to MCU

### 9.1 Power Supply

To provide the best operating condition for UHC124, careful consideration of power supply circuit is recommended. Use short, low impedance connections to  $V_{DD}$  and  $V_{SS}$ . High quality 0.1  $\mu$ F decoupling capacitors soldered as close as possible to the package pins are highly recommended.

### 9.2 PowerOnReset and MasterReset

Pin 63 (GNDP) should be tied to  $V_{SS}$  (ground) to ensure operation of the internal POR circuitry. For a reliable MasterReset, pin 54 (/RESET) must be brought low for at least 200 ns.

The UHC124 is disabled for the first 12 ms after a PowerOnReset or a MasterReset, during which time the internal PLL circuit is stabilized.

### 9.3 Crystal Oscillator

To assure quick start of the internal PLL circuitry, a crystal with a high Q, or low ESR, should be used. To meet the USB frequency accuracy and stability requirements, the crystal should have an accuracy and stability of better than 100 PPM. Even though the oscillator circuit would work with a ceramic resonator, its use is out of the question because a resonator would not have the frequency accuracy and stability required by USB specification.

An external 6 MHz series resonance quartz crystal is required. The oscillator is a special low power design and in most cases no external capacitors and resistors are necessary. If the crystal cannot tolerate the drive levels of the oscillator, a series resistor between  $OSC_2$  and the crystal pin is recommended.



Fig. 12 Oscillator and PLL related circuit

For proper operation of the PLL, an external low pass filter consisting of a 100  $\Omega$  resistor, a 0.01  $\mu$ F capacitor and a 0.002 $\mu$ F capacitor must be connected as shown in the above figure.

The clock can also be externally sourced. In this case, connect the clock source to  $OSC_1$  pin, while leaving  $OSC_2$  pin floating. A CMOS device is required to maintain good noise margins.

#### 9.4 Root Hub Ports

Each of the four root hub ports facilitate the +5V power supply and a pair of differential data lines for a USB device, as dictated by USB specification [7.1:107, 7.2:134]. The connection between a UHC124 downstream port to its Type A connector is given in Fig. 13. Note that ferrite beads are inserted into power lines preventing high frequency noise from entering the host controller. Requirements for power switches are decribed in Section 7.



Fig. 13 UHC124 down stream port

#### 9.5 Memory Access

UHC124's memory write cycle and read cycle are illustrated in Fig. 14 and Fig. 15, respectively.



Fig. 14 UHC124 write cycle

In Fig. 14, the write cycle starts when both /CS and /WR are asserted low. Valid address and data must be placed on the address bus and data bus, respectively by the MCU, no later than 12.6 ns after that, and they must last at least 73 ns relative to the beginning of the cycle. Both /CS and

/WR should assert, simultaneously, for at least 80 ns. A minimum of 25 ns is needed before another read or write cycle can start. Writing to an invalid address has no effect.



Fig. 15 UHC124 read cycle

In Fig. 15, the read cycle starts when both /CS and /RD assert logic low. Valid data will be placed on the data bus, by the UHC124, no later than 73 ns after that, and it will last to the point when /CS or /RD is de-asserted. Both /CS and /RD should hold low, simultaneously, for at least 80 ns. A minimum of 25 ns is needed before another read or write cycle can start. Again, valid address should be placed on the address bus in less than 12.6 ns entering the read cycle. 00H is returned by the UHC124 for an invalid address.

The UHC124 supports two memory access modes, based on the logic level held at Pin 14 (MODE).

• MODE = 0 (for MCUs without external bus)

In this mode, the effective memory access address is held in the 12-bit MemAddr register *inside* UHC124. Moreover, the register is incremented automatically each time a memory write or read is carried out.

To read/write a block of memory, a write cycle must be issued first by the MCU while pin 62 (ADS for address data select) is held high,  $A_{11}:A_8$  of the UHC124 are placed with the most significant 4 bits of the address, and  $D_7:D_0$  to contain the least significant 8 bits of that. This latches the starting address of the data block into the UHC124's MemAddr register. Successive read/write cycles while holding the ADS pin low will retrieve/store data, one byte at a time, from/to UHC124 through bi-directional data pins  $D_7:D_0$ .

Note that under this mode, UHC124 address pins  $A_7:A_0$  are not used. This mode is suitable for many RISC based MCUs with no external buses.

In Fig. 16, UCH124 is interfaced with an MCU via three ports:

- bi-directional port PC for actual data transfer (D<sub>7</sub>:D<sub>0</sub>);
- output port PB to provide higher 4-bit address A<sub>11</sub>:A<sub>8</sub>, and control signals (/CS, /RD, /WR, and ADS);

- one output pin of PA for UHC124 master reset (/RESET), and
- one input pin of PA for UHC124 interrupt (/INT).



Fig. 16 UHC124 interfaced to a MCU using i/o ports (MODE = 0)

The following is pseudo C code for two UHC124 memory access routines: UH\_BlkRead() and UH\_BlkWrite(), based on the interface scheme of Fig. 16. Explicit delays under several hundred nanoseconds may not be necessary for most micro-controllers. If speed is an issue, these routines should be written in assembly language.

```
/* MCU/compiler dependent data types */
typedef unsigned int U16;
typedef unsigned char U8;
```

```
/* Port PB – output */
#define CSn
                          0x80
                                        /* PB7: chip select */
                                        /* PB6: write strobe */
#define WRn
                          0x40
#define RDn
                          0x20
                                        /* PB5: read strobe */
                                        /* PB4: address/data select (1 - addr, 0 - data) */
#define ADS
                          0x10
#define ADDH
                          0xf
                                        /* PB<sub>3</sub>:PB<sub>0</sub>: most significant 4 bits of address */
/* Port A – only two bits are used */
#define UHCRSTn
                                        /* Bit 7: UHC124 master reset (output) */
                          0x80
#define UHCINTn
                          0x1
                                        /* Bit 0: UHC124 interrupt (input) */
                                        /* called only once when user software starts */
void UH Init(void)
   outp(PB, CSn | WRn | RDn);
                                        /* initial settings */
   outp(PA, inp(PA) & ~UHCRST);
                                        /* assert MasterReset */
   wait(50 ms)
                                 /* wait for some time */
   outp(PA, inp(PA) | UHCRST);
                                        /* MasterReset done */
}
```

```
static void UH Addr(U16 addr)
                                              /* latch an address into MemAddr */
{
   U8 d = (addr >> 8) & ADDH;
                                              /* higher 4 bits of addr */
   outp(PC, addr & 0xff);
                                              /* lower 8 bits of addr posted on PC */
                                              /* address write with ADS = 1 * /
   outp(PB, d | ADS | RDn);
   wait(80 ns);
                                              /* wait for some time */
   outp(PB, d | RDn | WRn | CSn);
                                              /* end of address write cycle */
                                              /* wait for some time */
   wait(25 nS);
}
static U8 UH Read(void)
                                              /* read a data byte from UHC124 */
ł
   U8 d;
                                              /* start read cycle with ADS = 0 * /
   outp(PB, WRn);
                                              /* wait for some time */
   wait(80 ns);
   d = inp(PC);
                                              /* retrieve data */
   outp(PB, RDn | WRn | CSn);
                                              /* end of data read cycle */
                                              /* wait for some time */
   wait(25 nS);
   return(d);
}
static void UH Write(U8 data)
                                              /* write a data byte into UHC124 */
{
   outp(PC, data);
                                              /* data posted on data bus */
   outp(PB, RDn);
                                              /* start write cycle with ADS = 0 * /
                                              /* wait for some time */
   wait(80 ns);
   outp(PB, RDn | WRn | CSn);
                                              /* end of data write cycle*/
                                              /* wait for some time */
   wait(25 nS);
}
/* read a block of data from UHC124 memory */
void UH BlkRead(U16 addr, U8 *data, U16 len)
{
   UH Addr(addr);
   while (len-) * data++ = UH Read();
}
/* write a block of data into UHC124 memory */
void UH BlkWrite(U16 addr, U8 *data, U16 len)
{
   UH Addr(addr);
   while (len--) UH Write(*data++);
}
```

• MODE = 1 (for MCUs with separated or multiplexed address and data bus)

In this mode, a memory cycle is issued while  $A_{11}$ :  $A_0$  of the UHC124 is holding the effective 12-bit address. Memory access addresses are not incremented automatically.

For MCUs with separated address bus and data bus, the hardware interfacing is glue-less and straightforward (Fig. 17). The UHC124's 4 kB addressing space can be memory mapped into the MCU, and effectively covered by the /CS. Although pin ADS has no function in this mode, it should be grounded to prevent noise getting into the chip.



Fig. 17 UHC124 interfaced with a MCU with separate address bus and data bus (MODE = 1)

For MCUs with multiplexed lower 8-bit address and data bus, the interface is standard as exemplified in Fig. 18.



Fig. 18 UHC124 interfaced with a MCU with multiplex address and data bus (MODE = 1)

• MODE = 0 (for MCUs with external address and data buses)

It is also possible to take advantage of the UHC124's address auto-incrementing capability in systems that have external buses, with or without multiplexed address/data for the least significant 8 bits. In this case, the UHC124 is mapped into an addressing space much smaller than 4 kB.



Fig. 19 UHC124 interfaced with MCU with external bus (MODE = 0)

In Fig. 19,  $A_4$  of the MCU is used to indicate whether data posted on  $D_7:D_0$  is actually the lower 8-bit of a UHC124 address. The higher 4-bit address for UHC124 is furnished by  $A_3:A_0$  from the MCU. The UHC124 only occupies 32 bytes of the MCU's addressing space.

Two memory access routines, again UH\_BlkRead() and UH\_BlkWrite(), in pseudo C code are written based on this interface scheme, assuming /CS covers the required 32-byte addressing space, and initialization of the system has been done correctly.

| <b>typedef unsigned int</b> U16;<br><b>typedef unsigned char</b> U8;                      | /* processor/compiler dependent data type */                                                 |
|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| # <b>define</b> ADS 0x10<br># <b>define</b> UHC124 0x4000                                 | /* A <sub>4</sub> is connected to ADS */<br>/* start addr of 32-byte block covered by /CS */ |
| <pre>void UH_BlkRead(U16 addr, U8 *da {</pre>                                             |                                                                                              |
| *(UHC124   ADS   (( <i>addr</i> >> 8) & while ( <i>len</i> ) * <i>data</i> ++ = *(UHC12)} |                                                                                              |

/\* store a block of data into UHC124 - starting from address addr \*/
void UH\_BlkWrite(U16 addr, U8 \*data, U16 len)
{
 \*(UHC124 | ADS | ((addr >> 8) & 0xf)) = addr & 0xff; /\* latch starting address \*/
while (len--) \*(UHC124) = \*data++; /\* write data \*/
}

Under MODE = 0, caution and measures must be taken when there is a possibility of interrupt(s) between an instruction latching the address and that performing an auto-incremented UHC124 memory access. If the ISR also accesses the chip, the content of the MemAddr register will be altered causing malfunction of the continuing foreground process. The situation also applies to context switching between processes by a RTOS in a multi-tasking environment.

### 9.6 Test Modes

A number of UHC124 pins (TMS<sub>3</sub>:TMS<sub>0</sub>, TEST<sub>4</sub>:TEST<sub>0</sub>) are designated solely for the purpose of factory testing. For normal operation, TMS<sub>3</sub>:TMS<sub>0</sub> must be grounded, and TEST<sub>4</sub>:TEST<sub>0</sub> must be left floating.

# **10. Software Issues**

It should be emphasized that UHC124 supports USB host functions only at the transaction level. It is the OEM's responsibility to write their own, or to license from TransDimension, higher-level USB host control software (HCD, USBDI, USBD, etc.), which is out of the scope of this document.

## 10.1 Resets

• PowerOnReset and MasterReset

PowerOnReset is applied whenever the power is turned on for UHC124. MasterReset is introduced through the UHC124's /RESET (pin 54), which must be asserted for at least 200 ns.

The effects of the two are identical, which initializes all control registers, timer/counters and internal state machines, and then brings the system into USBRESET state. The frame number after such a reset restarts at 000H.

To ensure reliable operation, memory access is disabled and all registers are held still for the first 12 ms after such a reset, during which time the internal PLL circuitry is stabilized.

Per USB specification, the system must remain in USBRESET for at least 50 ms to ensure all connected devices are reset reliably [7.1.7.3:122]. After the 50 ms waiting period, user software should issues a USBOperational command (writing a '1' to bit 1 of UhcControl) to get out of state USBRESET, and then (re)enumerates all connected devices, starting from the root hub.

• USBReset

Command USBReset is issued by writing a '1' to Bit 4 of the UhcControl register. The effect of USBReset is almost the same as that of PowerOnReset or MasterReset, except that it does not prohibit the UHC124 from operating: immediately following a USBReset, user software may access all memory locations, including registers. However, no transaction batches, not even the ones for root hub enumeration, can be dispatched until another 50 ms, when user software brings the system into USBOPERATIONAL state.

• SoftReset

A SoftReset is issued by writing a '1' to Bit 5 of the UhcControl register, which only resets certain control registers and state machines. It has no effect on frame related timers and counters (see Section 5 for details). A SoftReset places the system into USBSUSPEND state.

SoftReset is used to make sure all internal state machines are promptly re-synchronized so they will work correctly from that time on, without the burden of resetting and then reenumerating all connected devices.

Very often, it is not the intention of user software to actually suspend any connected device after a SoftReset. To remedy the situation, command USBOperational is permitted and effective while UHC124 is in state USBSUSPEND. Note that since SOF generation is disabled in USBSUSPEND, connected devices may suspend themselves in 5 ms. To prevent this from happening, the USBOperational command should be issued within 3 ms after SoftReset.

### 10.2 Transaction Specification

To issue a transaction, user software must first allocate a transaction descriptor (XD). All 16 XDs are functionally equivalent. However, a selected XD with the lowest index has the highest priority in a transaction batch.

The table below lists information needed to specify a transaction. Section 6 should be consulted for details on various fields of an XD.

| Item                   | XD Offset          | Bits                                              | Remark                                                                         |
|------------------------|--------------------|---------------------------------------------------|--------------------------------------------------------------------------------|
| Device<br>Address      | XDDevAddress (2)   | DevAddress (6:0)                                  | DEV0 (0) is used for a device that has yet been enumerated.                    |
| Endpoint<br>Number     | XDEndPoint (3)     | Endpoint (3:0)                                    | EP0 (0) is always a control endpoint for a device.                             |
| Transaction<br>Type    | XDControl (0)      | TransType (1:0)                                   | 00: SETUP; 01: OUT; 10: IN.                                                    |
| Isochronous            | XDControl (0)      | Isochronous (3)                                   | 1: isochronous; 0: control, bulk, interrupt (non-isochronous).                 |
| Device<br>Speed        | XDControl (0)      | DevSpeed (4)                                      | 1: low speed; 0: full speed.                                                   |
| OUT Data<br>Sequence   | XDControl (0)      | OutDataSeq (2)                                    | 1: DATA1; 0: DATA0. Not used<br>for SETUP, IN, or isochronous<br>transactions. |
| Data Buffer<br>Address | XDBufAddress (4-5) | BufAddress (11:0)                                 | Make sure there is enough space in data memory.                                |
| Data Buffer<br>Length  | XDBufLength (6-7)  | BufLength (9:0)                                   | Use endpoint buffer size for an IN transaction to avoid overflow.              |
| Stop<br>Condition      | XDControl (0)      | StopOnSucc (7)<br>StopOnNak (6)<br>StopOnFail (5) | Conditions are inclusively ORed.                                               |

For a SETUP or OUT transaction, data must be placed by user software in its reserved data memory area before the transaction is dispatched along with a batch. For an IN transaction, on the other hand, it is the UHC124 that places data (received from a device) into this designated area. Modifying an XD involved in a dispatched, yet to be completed batch is not recommended.

Fig. 20 illustrates two transactions:  $XD_3$  with a data area of 8 bytes starting from C48H in data memory; and 12 bytes are reserved for  $XD_A$  starting at 814H.



Fig. 20 XDs and their relations to Data Memory areas

Note that in this example, both data buffer areas start at an address aligned on 4-byte boundaries. This practice is encouraged for software compatibility with other 16-bit or 32-bit USB host controllers, even though such a data buffer, for the UHC124, can begin at any address.

## 10.3 Batch Dispatching

Several transactions can be grouped together to form a transaction batch, and then dispatched:

- Write into the UhcTransSelect register (002-003H) such that Bit n of this register is set to '1' if and only if  $XD_n$  is included in the batch.
- Issue a BatchOn command, i.e., writing a '1' to Bit 0 of the UhcControl register (000H). Make sure that the system is in state USBOPERATIONAL.

The activation, progression, and completion of the batch may be verified and/or monitored with:

- BATCHON, i.e., Bit 1 of UhcControl register (000H);
- TransDone register (004-005H); and
- BatchStopped (Bit 7) and BatchCompleted (Bit 6) of the UhcIntpStatus register (006H).

## 10.4 Transaction/Batch Scheduling

The following table gives estimated time required for the UHC124 to process various types of USB transactions, serving as guidelines for transaction/batch scheduling, where n in the table is the number of bytes in a data packet.

| Transaction Type             | Token | Data      | Handshake | Overhead | Total     |
|------------------------------|-------|-----------|-----------|----------|-----------|
| Full speed (non-isochronous) | 35    | 35 + 8n   | 19        | 8        | 97 + 8n   |
| Low speed (OUT/SETUP)        | 320   | 300 + 64n | 152       | 64       | 836 + 64n |
| Low speed (IN)               | 320   | 280 + 64n | 172       | 64       | 836 + 64n |
| Isochronous                  | 35    | 35 + 8n   | N/A       | 6        | 76 + 8n   |

The unit used in the above table is FSBT (full speed bit time, or approximately 83.333 ns). There are 12,000 FSBTs in a USB frame, which lasts 1 ms  $\pm$  0.5  $\mu$ s. Potential timeout for data packets or handshake packets from device have been taken into account.

Note that if a transaction has failed, it may take less time than predicted. On the other hand, an IN transaction may bring more data than anticipated. Thus the buffer size of the endpoint, rather than the actual number of bytes to be retrieved, should be used when estimating the time required for an IN transaction.

A SOF packet takes 35 FSBTs. However, it does not show on the USB bus until 12 FSBTs, measured relative to the start of the frame. The usable time for USB transactions in a frame starts from approximately 47 FSBTs through (35+UhcMaxOverhead) FSBTs. The UhcMaxOverhead register defaults to 192 (C0H), and should not be set to less than 10. See Fig. 9 in Section 5 for an illustration.

If a transaction batch cannot be completed in a frame, the remaining transactions will be "spilled over" transparently to the next one. This is convenient for applications not involving any isochronous transfers. If isochronous transfers are present, transactions scheduled in each frame must be carefully budgeted. In general, they should take less than 950  $\mu$ s (or about 11,000 FSBT), based on transaction time estimations as described.

It is not recommended that user software include multiple transactions targeted to the same endpoint in the same batch. In fact, many low speed devices cannot handle more than one transaction in the same frame.

#### 10.5 Transaction Status Interpretation and Handling

The outcome of a transaction may be examined in XDStatus (Offset 1) of the transaction descriptor. Three flowcharts (Fig. 21 for SETUP, Fig. 22 for OUT, and Fig. 23 for IN transactions) are presented which explain how to interpret, and to react upon results in XDStatus. The handling methods (as labeled alphabetically in these charts) are based on USB specification, and are detailed as follows.

A. Endpoint Stall

Most likely, the endpoint targeted is not prepared to deal with such a transaction. For instance, an endpoint designated to receive data from host returns Stall upon receiving an IN token. User software should investigate the situation, and handle it accordingly.

B. Timeout or Error

For a SETUP or OUT transaction, Timeout occurs because the host controller has received no handshake packet (of any type) from the device 18 bit times after the data packet is sent.

For an IN transaction, Timeout is asserted because the device has failed to respond with the expected data packet 18 bit times after the token packet is sent.

Error occurs for an IN transaction if CRC16 check failed for its data packet, or a corrupted data packet is received. A SETUP or OUT transaction asserts the Error bit in XDStatus if the handshake packet was corrupted beyond recognition.

USB specification requires the host controller to re-try, up to three times, non-isochronous transactions that result in either Timeout or Error.

C. Nak

An endpoint returns Nak if it is not ready to take a new data packet of an OUT transaction, or it is not ready to deliver a data packet for an IN transaction. The host controller should retry this transaction some other time. The device is not allowed to respond to the host with a Nak packet for a SETUP transaction.

An interrupt (INT) endpoint returns Nak if there has been no event of interest. Transactions for an INT endpoint "retries" periodically [8.5.3:167].

D. Isochronous Transactions

There is no handshake packet for an isochronous transaction [8.5.4]. Thus 00H is returned in XDStatus for a successful OUT isochronous transaction.

Error and Timeout for an IN transaction should be ignored by user software. Since data sequence is not tracked for isochronous transactions, data sequence bit of XDStatus is meaningless.

E. Data Sequence

USB employs a mechanism called *data toggle synchronization* for transactions targeted to non-isochronous endpoints, which must be tracked by the host controller [8.6:168]. For each successful transaction to/from such an endpoint, the data sequence toggle should be flipped. The handling here is designed per USB specification.

Note the difference in the way data sequence toggle is handled for IN and OUT transactions. For a successful OUT transaction, the endpoint's data sequence is always advanced (toggled). For an IN transaction, the data sequence for that endpoint is advanced only if the InDataSeq bit of XDStatus agrees with what the host is expected. Otherwise, the received data packet is ignored.

SETUP transactions targeted to a control endpoint always carry data sequence DATA0.

F. Overflow

This bit is asserted in XDStatus if the data packet of the transaction contains more data than anticipated in XDBufLength. If this happens, the excessive data bytes are truncated. It is a good practice to use the size of the endpoint buffer for XDBufLength for an IN transaction, even if the reserved data buffer may not be completely filled.

G. System Error

If this happens, it is a UHC124 system error, and the problem should be reported to TransDimension's technical support department.

H. Transaction Successful

This signifies the success of the transaction. Note that for IN transactions, the actual data is processed by user software (most likely, simply copied out of the UHC124) *after* the analysis of the transaction outcome; whereas for OUT transactions, the actual data is prepared, (most likely, simply copied), into UHC124 data memory *before* the transaction is dispatched.



Fig. 21 Interpretation and handling of XDStatus for SETUP transactions



Fig. 22 Interpretation and handling of XDStatus for OUT transactions



Fig. 23 Interpretation and handling of XDStatus for IN transactions

### 10.6 USB Requests (Control Transfers)

Per USB specification [8.5.2:164], a USB *request*, also known as a *control transfer*, consists of three stages: a *setup stage*, an optional *data stage*, and finally a *status stage*.

The setup stage is a SETUP transaction with a data packet of exactly 8 bytes, known as the *SETUP packet* serving as a command to the designated device. It always carries data sequence DATA0 for the control endpoint. The SETUP packet, issued by user software according to the USB specification [9.3:183], contains information on whether the request involves a data stage, and if so, data transfer direction (host to device, or device to host), as well as the number of bytes to be transferred.

Due to the size limitation of the endpoint buffer, a data stage may have to be decomposed into several transactions. DATA1 will be carried by the first transaction in the data stage. The data sequence for the control endpoint advances (toggles) each time a transaction to this endpoint is successful.

A USB request always ends with its status stage, which is

- an OUT transaction with a null, DATA1 data packet if the transfer direction in its data stage is from device to host (IN), irrelevant to the data sequence carried by the last transaction; or
- an IN transaction with a null, DATA1 data packet if its data stage calls for OUT (host to device) transactions, irrelevant to that carried by the last transaction; or if the request has no data stage.

Fig. 24 summarizes this discussion.



Fig. 24 USB requests (control transfers)

A null data packet of a transaction is an ordinary data packet with data length zero.

It should be emphasized that USB requests can only be applied to control endpoints. Each USB device has at least one control endpoint, i.e., EP0.

Users should consult Ch. 9 of the USB specification 1.1 for standard USB requests as well as Ch.11 for hub class requests. Knowledge on these requests is required for understanding material presented in the following discussion.

#### 10.7 UHC124 Operation

Step-by-step software procedures are given below that guide the UHC124 to work, from power on (or MasterReset), to a point where user software may effectively interact with an external USB device. The intention here is not to take place of the USB specification, which must be consulted from time to time by programmers. We hope it helps to gain confidence on the UHC124 and its interface to the MCU, especially for those who are going through the learning curve for USB host programming.

The notation for transactions and packets used in the following discussion should be selfexplanatory. For clear presentation, packets generated by devices are in *italic*, numbers in data packets are always in hexadecimal, and we assume that devices respond without complications.

Step1: System Initialization

- Generate a /UHCRST (i.e., an active low pulse on the /RESET pin) for at least 200 ns.
- Wait for at least 50 ms.
- Issue command USBOperational (write a '1' to Bit 1 of the UhcControl register).

The user program should verify whether the system is indeed in state USBOPERATIONAL before it proceeds to Step 2.

Step 2: Root Hub Enumeration

- Issue USB standard request SET\_ADDRESS with address 01H [9.4.6:192]. This assigns address DEV1 (01H) to the root hub. Notice that it is done through EP0 of DEV0.

Setup Stage: <SETUP, DEV0, EP0> <DATA0, [00, 05, 01, 00, 00, 00, 00]> <*ACK*> Status Stage: <IN, DEV0, EP0> <*DATA1*, []> <ACK>

There is no data stage for this request.

- Issue USB standard request SET\_CONFIGURATION to DEV1 (the root hub) with configuration number 1 [9.4.7:193].

Setup Stage: <SETUP, DEV1, EP0><DATA0, [00, 09, 01, 00, 00, 00, 00]><*ACK*> Status Stage: <IN, DEV1, EP0><*DATA1*, //><ACK>

- Verify whether the root hub is in fact configured. Issue a USB standard request GET CONFIGURATION with device address 1 [9.4.2:189].

 Setup Stage:
 <SETUP, DEV1, EP0><DATA0, [80, 08, 00, 00, 00, 00, 00, 00]><ACK>

 Data Stage:
 <IN, DEV1, EP0> <DATA1, [01]> <ACK>

 Status Stage:
 <OUT, DEV1, EP0> <DATA1, []> <ACK>

If the root hub returns in the data stage a single byte data packet containing a 1, as shown above, it is in working condition.

Step 3: Down Stream Port Initialization

- Turn on the power for each of the four downstream ports by issuing a hub class request, SetPortFeature with feature PORT\_POWER [11.16.2.9:279]. The request should be repeated four times, each for a different port.

Setup Stage: <SETUP, DEV1, EP0><DATA0, [23, 03, 08, 00, 0x, 00, 00]><*ACK*> Status Stage: <IN, DEV1, EP0><*DATA1, []*><ACK>

where x must be replaced with a port number (1, 2, 3 or 4). The user software should wait for 10 ms to ensure power is actually turned on for that port. It is also possible to first apply the request to each of the four ports, and then wait 10 ms for all ports.

To check whether the power has actually turned on for each port, hub class request GetPortStatus is issued:

| Setup Stage:  | <setup, dev1,="" ep0=""><data0, 00,="" 00]="" 04,="" 0x,="" [a3,="">&lt;<i>ACK</i>&gt;</data0,></setup,> |
|---------------|----------------------------------------------------------------------------------------------------------|
| Data Stage:   | <in, dev1,="" ep0=""><data1, 00,="" 00]="" 01,="" [00,=""><ack></ack></data1,></in,>                     |
| Status Stage: | <out, dev1,="" ep0=""><data1, []="">&lt;<i>ACK</i>&gt;</data1,></out,>                                   |

where x must be replaced with a port number (1, 2, 3, or 4).

- If the external device is not connected, plug it into the designated port. Make sure that there is only one USB device in the system that is attached, but yet to be assigned an address.

Hub class request GetPortStatus may be used again to check whether the port has in fact detected the connection of the device [11.16.2.6:273].

| Setup Stage:  | <setup, dev1,="" ep0=""><data0, 00,="" 00]="" 04,="" 0x,="" [a3,="">&lt;<i>ACK</i>&gt;</data0,></setup,> |
|---------------|----------------------------------------------------------------------------------------------------------|
| Data Stage:   | <in, dev1,="" ep0="">&lt;<i>DATA1, [01, 0X, 01, 00]</i>&gt;<ack></ack></in,>                             |
| Status Stage: | <out, dev1,="" ep0=""><data1, []="">&lt;<i>ACK</i>&gt;</data1,></out,>                                   |

where x must be replaced with a port number (1, 2, 3, or 4), and X is 1 for a full speed device, or 3 for a low speed device.

- Reset and enable the designated port by issuing a hub class request, SetPortFeature to that specific port of the root hub, with feature PORT\_RESET.

Setup Stage: <SETUP, DEV1, EP0><DATA0, [23, 03, 04, 00, 0x, 00, 00]><*ACK*> Status Stage: <IN, DEV1, EP0><*DATA1, []*><ACK>

where x must be replaced by a port number (1, 2, 3, or 4). User software must pause for 20 ms to ensure the device is reset, and the port is enabled.

- Verify port status by issuing hub class request GetPortStatus to the specific port of the root hub [11.16.2.6:273].

| Setup Stage:  | <setup, dev1,="" ep0=""><data0, 00,="" 00]="" 04,="" 0x,="" [a3,=""><ack></ack></data0,></setup,> |
|---------------|---------------------------------------------------------------------------------------------------|
| Data Stage:   | <in, dev1,="" ep0=""><data1, 00]="" 0x,="" 11,="" [03,=""><ack></ack></data1,></in,>              |
| Status Stage: | <out, dev1,="" ep0=""><data1, []="">&lt;<i>ACK</i>&gt;</data1,></out,>                            |

where x must be replaced by a port number (1, 2, 3, or 4), and X is 1 for a full speed device, and 3 for a low speed device. The four bytes returned in the data stage should indicate that the port is now powered, connected, and enabled.

Step 4: Device Enumeration

- Issue standard USB request GET\_DESCRIPTOR with DEVICE as the descriptor type [9.4.3:189]. The request should target to DEV0.

 Setup Stage:
 <SETUP, DEV0, EP0><DATA0, [80, 06, 00, 01, 00, 00, 08, 00]><ACK>

 Data Stage:
 <IN, DEV0, EP0><DATA1, [12, 01, 00, 01, 07, 01, 02, 40]><ACK>

 Status Stage:
 <OUT, DEV0, EP0><DATA1, []><ACK>

Note that here we did not ask for all 18 bytes of the device descriptor. All we want to know at this time is to get bMaxPacketSize0 (endpoint buffer size of EP0) of the device [9.6.1:196]. If this is known for the targeted device, this step can be omitted.

In this case, we have assumed that the device plugged in is Epson<sup>™</sup> 740 printer, whose bMaxPacketSize0, as indicated above, is 64 (40H) bytes.

- Assign an address to the connected device, say 07H, by issuing standard USB request SET\_ADDRESS [9.4.6:192]:

Setup Stage: <SETUP, DEV0, EP0><DATA0, [00, 05, 07, 00, 00, 00, 00]><*ACK*> Status Stage: <IN, DEV0, EP0><*DATA1, []*><ACK> - Issue a standard USB request GET\_DESCRIPOR with descriptor type DEVICE. This time, the request should be sent to EP0 of DEV7, and we will ask for a full device descriptor of 18 bytes.

| Setup Stage:  | <setup, dev7,="" ep0=""><data0, 00,="" 00]="" 01,="" 06,="" 12,="" [80,=""><ack></ack></data0,></setup,> |
|---------------|----------------------------------------------------------------------------------------------------------|
| Data Stage:   | <in, dev7,="" ep0="">&lt;<i>DATA1</i>, [12, 01, 00, 01, 07, 01, 02, 40,</in,>                            |
|               | <i>B8, 04, 01, 00, 01, 01, 02, 00, 01]</i> > <ack></ack>                                                 |
| Status Stage: | <out, dev7,="" ep0=""><data1, []="">&lt;<i>ACK</i>&gt;</data1,></out,>                                   |

In general, user software should verify the 18-byte device descriptor very carefully, and make sure it correctly identifies the attached USB device.

At this point, we have gained confidence that the UHC124 is indeed talking to the device, and the device enumeration may continue. But this is largely application dependent.

#### 10.8 Software Support

TransDimension has a line of system software products that allow OEMs to develop USB host software with ease. While some of these software tools are made to interface with several state-of-the-art real time operating systems, others support purely embedded USB host applications. These software tools are crucial for OEMs to significantly shorten USB learning curves, and speed time-to-market for their product. You may wish to contact TDI sales department for more information.

# 11. Bus Cycle Timing

### 11.1 Memory Write Cycle



Fig. 25 UHC124 write cycle timing specification

| Symbol           | Parameter                             | Min | Max  | Unit |
|------------------|---------------------------------------|-----|------|------|
| t <sub>WCE</sub> | Write cycle enable time               | 80  |      | ns   |
| t <sub>ACR</sub> | Access cycle recovery time            | 25  |      | ns   |
| t <sub>WAS</sub> | Write cycle address setup time        | *   | 12.6 | ns   |
| t <sub>WDS</sub> | Write cycle data setup time           | *   | 12.6 | ns   |
| t <sub>WHD</sub> | Write cycle address/data holding time | 73  |      | ns   |

\* This number can be negative.

### 11.2 Memory Read Cycle



Fig. 26 UHC124 read cycle timing specification

| Symbol           | Parameter                     | Min | Max  | Unit |
|------------------|-------------------------------|-----|------|------|
| t <sub>RCE</sub> | Read cycle enable time        | 80  |      | ns   |
| t <sub>ACR</sub> | Access cycle recovery time    | 25  |      | ns   |
| t <sub>RAS</sub> | Read cycle address setup time | *   | 12.6 | ns   |
| t <sub>RDA</sub> | Read cycle data access time   |     | 73   | ns   |
| t <sub>RDH</sub> | Read cycle data holding time  | 1.9 | 4.2  | ns   |

\* This number can be negative.

# 12. Electrical Ratings

The following are preliminary and pending test on the chip.

#### 12.1 Absolute Maximum Ratings

Stresses beyond those listed below may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Symbol          | Parameter             | Condition | Min  | Max                  | Unit |
|-----------------|-----------------------|-----------|------|----------------------|------|
| V <sub>DD</sub> | DC Supply Voltage     |           | -0.3 | 3.6                  | V    |
| VI              | DC Input Voltage      |           | -0.3 | $V_{DD}$ +0.5        | V    |
| Vo              | DC output voltage     |           | -0.3 | V <sub>DD</sub> +0.5 | V    |
| To              | Operating temperature |           | -40  | +85                  | °C   |
| Ts              | Storage temperature   |           | -65  | +150                 | °C   |

### 12.2 Recommended/Normal Operating Conditions

| Power | Supp  | ly/Consu | mption |
|-------|-------|----------|--------|
| 10000 | Supp. | ry/Consu | inpuon |

| Symbol            | Parameter                 | Condition                                    | Min | Max  | Unit |
|-------------------|---------------------------|----------------------------------------------|-----|------|------|
| V <sub>DD</sub>   | 3.3 V Supply Voltage      |                                              | 3.0 | 3.6  | V    |
| I <sub>DDO</sub>  | Operational State Current | $V_{DD} = 3.3 V$ , no devices                |     | 16   | mA   |
| I <sub>DDF</sub>  | Full USB Traffic Current  | $V_{DD} = 3.3 V$ , one full-<br>speed device |     | ~20  | mA   |
| I <sub>DDS</sub>  | Suspend State Current     | $V_{DD} = 3.3 V$ , no devices                |     | 11   | mA   |
| I <sub>DDPS</sub> | Power Save State Current  | $V_{DD} = 3.3 V$                             | 100 | ~200 | μΑ   |

### 12.3 D.C. Characteristics

#### USB I/O Signals: DPn, DMn

| Symbol           | Parameter                   | Condition                           | Min | Max             | Unit |
|------------------|-----------------------------|-------------------------------------|-----|-----------------|------|
| $V_{IH}$         | Input Level High (driven)   |                                     | 2.0 |                 | V    |
| $V_{IHZ}$        | Input Level High (floating) |                                     | 2.7 |                 | V    |
| V <sub>IL</sub>  | Input Level Low             |                                     |     | 0.8             | V    |
| $V_{DI}$         | Diff. Input Sensitivity     | $DP_n$ and $DM_n$                   | 0.2 |                 | V    |
| $V_{CM}$         | Diff. Comm. Mode Range      |                                     | 0.8 | 2.5             | V    |
| V <sub>OL</sub>  | Static Output Low           | $R_L$ of 1.5 k $\Omega$ to $V_{DD}$ |     | 0.3             | V    |
| V <sub>OH</sub>  | Static Output High          | $R_L$ of 15 k $\Omega$ to $V_{SS}$  | 2.8 | V <sub>DD</sub> | V    |
| V <sub>CRS</sub> | Output Signal Crossover     |                                     | 1.3 | 2.0             | V    |
| C <sub>IN</sub>  | Input Capacitance           |                                     |     | 20              | pF   |

## Logic Signals

| Symbol            | Parameter                 | Condition                              | Min                   | Max                | Unit |
|-------------------|---------------------------|----------------------------------------|-----------------------|--------------------|------|
| V <sub>OL</sub>   | Low level output voltage  | $V_{DD} = 3V, I_{OL} = 0.3 \text{ mA}$ |                       | $V_{SS} + 0.1$     | V    |
| V <sub>OH</sub>   | High level output voltage | $V_{DD} = 3V, I_{OH} = 0.3 \text{ mA}$ | V <sub>DD</sub> - 0.1 |                    | V    |
| C <sub>OUT</sub>  | Output Capacitance        | 1 MHz                                  |                       | 10                 | pF   |
| V <sub>IL</sub>   | Low level input voltage   | $V_{DD} = 3.0 - 3.6 V$                 | -0.3                  | $0.3 \cdot V_{DD}$ | V    |
| $V_{\mathrm{IH}}$ | High level input voltage  | $V_{DD} = 3.0 - 3.6 V$                 | $0.7 \cdot V_{DD}$    | V <sub>DD</sub>    | V    |
| C <sub>IN</sub>   | Input capacitance         | 1 MHz                                  |                       | 10                 | pF   |

### Oscillator Circuits: OSC1, OSC2

| Symbol          | Parameter                | Condition                                                                | Min  | Max  | Unit |
|-----------------|--------------------------|--------------------------------------------------------------------------|------|------|------|
| V <sub>LH</sub> | OSC1 switching level     |                                                                          | 0.47 | 1.20 | V    |
| V <sub>HL</sub> | OSC1 switching level     |                                                                          | 0.67 | 1.44 | V    |
| CX1             | Input capacitance, OSC1  |                                                                          |      | 17   | pF   |
| CX <sub>2</sub> | Output capacitance, OSC2 |                                                                          |      | 17   | pF   |
| C <sub>12</sub> | OSC1/2 capacitance       |                                                                          |      | 1    | pF   |
| $t_{SU}$        | Start-up time            | 6 MHz, fundamental                                                       |      | 2    | ms   |
| DL              | Drive level              | $V_{DD} = 3.3V, 6 MHz$<br>crystal, 100 $\Omega$ equiv<br>series resistor |      | 150  | μW   |

\* OSC<sub>2</sub> must not be used to drive other circuitry.

### 12.4 A.C. Characteristics

Unless otherwise specified. Measurements are under the following conditions:

- $-V_{DD} = 3.3V$
- Ambient Temperature =  $25 \circ C$
- Clock edge switching time (from  $V_{SS}$  to  $V_{DD}$  or from  $V_{DD}$  to  $V_{SS}$ ) = 1.0 ns.

## DP<sub>n</sub>, DM<sub>n</sub> Driver Characteristics (Full Speed)

| Symbol           | Parameter                  | Condition             | Min | Max | Unit |
|------------------|----------------------------|-----------------------|-----|-----|------|
| t <sub>R</sub>   | Rise time                  | $C_L = 50 \text{ pF}$ | 4   | 20  | ns   |
| t <sub>F</sub>   | Fall time                  | $C_L = 50 \text{ pF}$ | 4   | 20  | ns   |
| t <sub>RFM</sub> | $T_R/T_F$ matching         |                       | 90  | 110 | %    |
| Z <sub>DRV</sub> | Driver output resistance * | Steady state drive    | 28  | 44  | Ω    |

\* With external  $22\Omega$  series resistor.

#### DPn, DMn Driver Characteristics (Low Speed)

| Symbol           | Parameter          | Condition                       | Min | Max | Unit |
|------------------|--------------------|---------------------------------|-----|-----|------|
| t <sub>R</sub>   | Rise time          | $C_{\rm L} = 200 - 600  \rm pF$ | 75  | 300 | ns   |
| t <sub>F</sub>   | Fall time          | $C_{\rm L} = 200 - 600  \rm pF$ | 75  | 300 | ns   |
| T <sub>RFM</sub> | $T_R/T_F$ matching |                                 | 80  | 125 | %    |

# 13. Packaging, Soldering and Storage

### 13.1 Package Diagram

64-Pin Low-profile Quad Flat Pack (LQFP): 10mm x10mm 1.4 mm thick.



Fig. 27 UHC124 package

## 13.2 Packaging Dimensions

All units are in mm unless otherwise specified.

| Symbol | Min                             | Nom      | Max  |  |  |
|--------|---------------------------------|----------|------|--|--|
| с      | 0.09                            |          | 0.20 |  |  |
| c1     | 0.09                            |          | 0.16 |  |  |
| L      | 0.45                            | 0.60     | 0.75 |  |  |
| L1     |                                 | 1.00 REF |      |  |  |
| R2     | 0.08                            |          | 0.20 |  |  |
| R1     | 0.08                            |          |      |  |  |
| S      | 0.2                             |          |      |  |  |
| θ      | 0°                              | 3.5°     | 7°   |  |  |
| θ1     | 0°                              |          |      |  |  |
| θ2     | 11°                             | 12°      | 13°  |  |  |
| θ3     | 11°                             | 12°      | 13°  |  |  |
| А      |                                 |          | 1.60 |  |  |
| В      | 0.17                            | 0.22     | 0.27 |  |  |
| b1     | 0.17                            | 0.20     | 0.23 |  |  |
| D      |                                 | 12.0 BSC |      |  |  |
| Е      |                                 | 12.0 BSC |      |  |  |
| D1     |                                 | 10.0 BSC |      |  |  |
| E1     |                                 | 10.0 BSC |      |  |  |
| D2     |                                 | 7.5 BSC  |      |  |  |
| E2     |                                 | 7.5 BSC  |      |  |  |
| e      |                                 | 0.50 BSC |      |  |  |
| A1     | 0.05                            |          | 0.15 |  |  |
| A2     | 1.35                            | 1.40     | 1.45 |  |  |
| Tolera | Tolerances of form and position |          |      |  |  |
| aaa    |                                 | 0.20     |      |  |  |
| bbb    |                                 | 0.20     |      |  |  |
| ссс    |                                 | 0.10     |      |  |  |
| ddd    |                                 | 0.08     |      |  |  |

## 13.3 Landing Pattern



Fig. 28 UHC124 recommended landing pattern. All units are in mm.

## 13.4 Soldering Profile

The following soldering profile from J-STD-20 are recommended :

| Parameters                                 | Convection or IR/Convection | VPR (Vapor Phase) |
|--------------------------------------------|-----------------------------|-------------------|
| Average ramp-up rate (183°C to Peak)       | 3°C /s max.                 | 10°C /s           |
| Preheat temperature 125 ±25 °C             | 120s max.                   |                   |
| Temperature maintained above 183°C         | 60-150s                     |                   |
| Time within 5°C of actual peak temperature | 10-20s                      | 60s               |
| Peak temperature range                     | 235 +5/-0°C                 | 235 +5/-0°C       |
| Ramp-down rate                             | 6°C /s                      | 10°C /s           |
| Time 25°C to peak temperature              | 6min max.                   |                   |

A maximum of three reflow passes is allowed per component.

### 13.5 Storage Conditions

Dry packed products must not be stored for more than 1 year at 40°C and 90% RH.

A longer storage period is allowed taking into account the following conditions: 5 years max. at  $25^{\circ}C \pm 5^{\circ}C$ , 50% RH.

From opening the packs, the product must be assembled within 168 hours (the worst in process storage condition assumed: 30°C, 60% RH).

If the product cannot be soldered within this time period, then the product must be dried at 125°C for 24 hours. Only one drying is allowed.

## 14. Sales Offices:

#### **North American Sales Offices**

#### Headquarters

TransDimension Inc., 2 Venture Irvine, CA 92618 Phone: 949-727-2020 x274 Fax: 949-727-3232 ptodd@transdimension.com Pete Todd V.P. of Worldwide Sales

#### **European Sales Office**

7 The Orchard Hilton Derbyshire UK DE65 5JF Phone:+44 (1283 730045 Fax:+44 1283 730045 Mobile: +44 7812 189333 <u>nhuntingdon@transdimension.com</u> Neil Huntingdon, European Sales Director

#### **Asian Sales Office**

OYA Bldg. 5 3 Chome-9-6, Nishishinjuku, Shinjuku-ku, Tokyo, Japan Phone: 81-3-5308-7525 Fax: 81-3-5308-7526 Mobile: 81-90-3141-7966 <u>sugane@alto.ocn.ne.jp</u> Masanori Sugane, Japan VP of Sales & Marketing

Worldwide distributors/representatives: See detailed listing by viewing http://www.transdimension.com